Skip to content

Commit

Permalink
auto merge of #5634 : thestinger/rust/dlist, r=brson,thestinger
Browse files Browse the repository at this point in the history
Closes #3549

The issue report has some reasoning, but I'd like to add that I don't think managed pointers belong in core. It's *possible* to write a safe doubly-linked list on top of `unsafe`, but it would be much more limited and I don't think there's much of a use case - it would lose a lot of flexibility. You're probably better off using a vector, hash table, tree, heap or ring buffer in almost every case.
  • Loading branch information
bors committed Mar 31, 2013
2 parents 8e30d3f + 258a367 commit bd7ba1f
Show file tree
Hide file tree
Showing 4 changed files with 6 additions and 12 deletions.
1 change: 0 additions & 1 deletion src/libcore/core.rc
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,6 @@ pub mod container;
pub mod option;
pub mod result;
pub mod either;
pub mod dlist;
pub mod hashmap;
pub mod cell;
pub mod trie;
Expand Down
14 changes: 4 additions & 10 deletions src/libcore/dlist.rs → src/libstd/dlist.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,8 @@ Do not use ==, !=, <, etc on doubly-linked lists -- it may not terminate.
*/

use iter;
use iter::BaseIter;
use kinds::Copy;
use managed;
use option::{None, Option, Some};
use vec;
use core::prelude::*;
use core::managed;

pub type DListLink<T> = Option<@mut DListNode<T>>;

Expand Down Expand Up @@ -540,10 +536,8 @@ impl<T> BaseIter<T> for @mut DList<T> {

#[cfg(test)]
mod tests {
use dlist::{DList, concat, from_vec, new_dlist_node};
use iter;
use option::{None, Some};
use vec;
use super::*;
use core::prelude::*;

#[test]
pub fn test_dlist_concat() {
Expand Down
2 changes: 1 addition & 1 deletion src/libstd/serialize.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,10 @@ Core encoding and decoding interfaces.
#[forbid(non_camel_case_types)];

use core::prelude::*;
use core::dlist::DList;
use core::hashmap::linear::{LinearMap, LinearSet};
use core::trie::{TrieMap, TrieSet};
use deque::Deque;
use dlist::DList;
use treemap::{TreeMap, TreeSet};

pub trait Encoder {
Expand Down
1 change: 1 addition & 0 deletions src/libstd/std.rc
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ pub mod priority_queue;
pub mod rope;
pub mod smallintmap;
pub mod sort;
pub mod dlist;
pub mod treemap;

// And ... other stuff
Expand Down

0 comments on commit bd7ba1f

Please sign in to comment.