Skip to content

Commit dbb5399

Browse files
committed
---
yaml --- r: 44372 b: refs/heads/master c: b0f58f6 h: refs/heads/master v: v3
1 parent 1977de7 commit dbb5399

File tree

6 files changed

+39
-31
lines changed

6 files changed

+39
-31
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
---
2-
refs/heads/master: 33ae05871cc4366897e6461a26265ae0e12ef600
2+
refs/heads/master: b0f58f6e684ca9076fac99e8f3917d01eeb5775e
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: a6d9689399d091c3265f00434a69c551a61c28dc
55
refs/heads/try: ef355f6332f83371e4acf04fc4eb940ab41d78d3

trunk/src/libcore/prelude.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,7 @@ pub use path::GenericPath;
3434
pub use path::Path;
3535
pub use path::PosixPath;
3636
pub use path::WindowsPath;
37+
pub use pipes::{GenericChan, GenericPort};
3738
pub use ptr::Ptr;
3839
pub use str::{StrSlice, Trimmable, OwnedStr};
3940
pub use to_bytes::IterBytes;

trunk/src/libcore/private.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@ use cast;
1414
use iter;
1515
use libc;
1616
use option;
17-
use pipes::{GenericChan, GenericPort};
17+
use pipes;
1818
use prelude::*;
1919
use ptr;
2020
use result;

trunk/src/libcore/private/weak_task.rs

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -22,8 +22,7 @@ use option::{Some, None, swap_unwrap};
2222
use private::at_exit::at_exit;
2323
use private::global::global_data_clone_create;
2424
use private::finally::Finally;
25-
use pipes::{Port, Chan, SharedChan, GenericChan, GenericPort,
26-
GenericSmartChan, stream};
25+
use pipes::{Port, Chan, SharedChan, GenericSmartChan, stream};
2726
use task::{Task, task, spawn};
2827
use task::rt::{task_id, get_task_id};
2928
use hashmap::linear::LinearMap;

trunk/src/libcore/run.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@ use io;
1414
use io::ReaderUtil;
1515
use libc;
1616
use libc::{pid_t, c_void, c_int};
17-
use pipes::{stream, SharedChan, GenericChan, GenericPort};
17+
use pipes::{stream, SharedChan};
1818
use option::{Some, None};
1919
use os;
2020
use prelude::*;

trunk/src/libstd/treemap.rs

Lines changed: 34 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -576,53 +576,52 @@ pure fn each_reverse<K: Ord, V>(node: &r/Option<~TreeNode<K, V>>,
576576
}
577577

578578
// Remove left horizontal link by rotating right
579-
fn skew<K: Ord, V>(mut node: ~TreeNode<K, V>) -> ~TreeNode<K, V> {
579+
fn skew<K: Ord, V>(node: &mut ~TreeNode<K, V>) {
580580
if node.left.map_default(false, |x| x.level == node.level) {
581581
let mut save = node.left.swap_unwrap();
582582
node.left <-> save.right; // save.right now None
583-
save.right = Some(node);
584-
save
585-
} else {
586-
node // nothing to do
583+
*node <-> save;
584+
node.right = Some(save);
587585
}
588586
}
589587

590588
// Remove dual horizontal link by rotating left and increasing level of
591589
// the parent
592-
fn split<K: Ord, V>(mut node: ~TreeNode<K, V>) -> ~TreeNode<K, V> {
590+
fn split<K: Ord, V>(node: &mut ~TreeNode<K, V>) {
593591
if node.right.map_default(false,
594592
|x| x.right.map_default(false, |y| y.level == node.level)) {
595593
let mut save = node.right.swap_unwrap();
596594
node.right <-> save.left; // save.left now None
597-
save.left = Some(node);
598595
save.level += 1;
599-
save
600-
} else {
601-
node // nothing to do
596+
*node <-> save;
597+
node.left = Some(save);
602598
}
603599
}
604600

605601
fn insert<K: Ord, V>(node: &mut Option<~TreeNode<K, V>>, key: K,
606602
value: V) -> bool {
607-
if node.is_none() {
608-
*node = Some(~TreeNode::new(key, value));
609-
true
610-
} else {
611-
let mut save = node.swap_unwrap();
603+
match *node {
604+
Some(ref mut save) => {
612605
if key < save.key {
613606
let inserted = insert(&mut save.left, key, value);
614-
*node = Some(split(skew(save))); // re-balance, if necessary
607+
skew(save);
608+
split(save);
615609
inserted
616610
} else if save.key < key {
617611
let inserted = insert(&mut save.right, key, value);
618-
*node = Some(split(skew(save))); // re-balance, if necessary
612+
skew(save);
613+
split(save);
619614
inserted
620615
} else {
621616
save.key = key;
622617
save.value = value;
623-
*node = Some(save);
624618
false
625619
}
620+
}
621+
None => {
622+
*node = Some(~TreeNode::new(key, value));
623+
true
624+
}
626625
}
627626
}
628627

@@ -632,7 +631,7 @@ fn remove<K: Ord, V>(node: &mut Option<~TreeNode<K, V>>, key: &K) -> bool {
632631
// *could* be done without recursion, but it won't borrow check
633632
do child.mutate |mut child| {
634633
if child.right.is_some() {
635-
heir_swap(&mut *node, &mut child.right);
634+
heir_swap(node, &mut child.right);
636635
} else {
637636
node.key <-> child.key;
638637
node.value <-> child.value;
@@ -684,15 +683,24 @@ fn remove<K: Ord, V>(node: &mut Option<~TreeNode<K, V>>, key: &K) -> bool {
684683
do save.right.mutate |mut x| { x.level = save.level; x }
685684
}
686685

687-
save = skew(save);
686+
skew(&mut save);
687+
688+
match save.right {
689+
Some(ref mut right) => {
690+
skew(right);
691+
match right.right {
692+
Some(ref mut x) => { skew(x) },
693+
None => ()
694+
}
695+
}
696+
None => ()
697+
}
688698

689-
do save.right.mutate |mut right| {
690-
right = skew(right);
691-
right.right.mutate(skew);
692-
right
699+
split(&mut save);
700+
match save.right {
701+
Some(ref mut x) => { split(x) },
702+
None => ()
693703
}
694-
save = split(save);
695-
save.right.mutate(split);
696704
}
697705

698706
*node = Some(save);

0 commit comments

Comments
 (0)