about summary refs log tree commit diff
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2013-02-12 10:35:12 -0800
committerbors <bors@rust-lang.org>2013-02-12 10:35:12 -0800
commit210fa2d0172c10112196e8fcf640e32ee54944fe (patch)
tree6cafd04f544999faab963bfe9b00d45a61393603
parent1c487b18f3ff2ea55e377c3e8be99227c8257136 (diff)
parent99ff74c1bd4d982cfc49f8ed962cd31f3c8d9ae7 (diff)
downloadrust-210fa2d0172c10112196e8fcf640e32ee54944fe.tar.gz
rust-210fa2d0172c10112196e8fcf640e32ee54944fe.zip
auto merge of #4874 : thestinger/rust/option, r=catamorphism
-rw-r--r--src/libcore/option.rs4
-rw-r--r--src/libstd/treemap.rs8
2 files changed, 6 insertions, 6 deletions
diff --git a/src/libcore/option.rs b/src/libcore/option.rs
index cfc2cba9226..c2af5f8b73b 100644
--- a/src/libcore/option.rs
+++ b/src/libcore/option.rs
@@ -201,7 +201,7 @@ pub pure fn map_default<T, U>(opt: &r/Option<T>, def: U,
 }
 
 #[inline(always)]
-pub pure fn iter<T>(opt: &Option<T>, f: fn(x: &T)) {
+pub pure fn iter<T>(opt: &r/Option<T>, f: fn(x: &r/T)) {
     //! Performs an operation on the contained value by reference
     match *opt { None => (), Some(ref t) => f(t) }
 }
@@ -313,7 +313,7 @@ impl<T> Option<T> {
 
     /// Performs an operation on the contained value by reference
     #[inline(always)]
-    pure fn iter(&self, f: fn(x: &T)) { iter(self, f) }
+    pure fn iter(&self, f: fn(x: &self/T)) { iter(self, f) }
 
     /**
     Gets an immutable reference to the value inside an option.
diff --git a/src/libstd/treemap.rs b/src/libstd/treemap.rs
index d3583828f9a..26bf232adf5 100644
--- a/src/libstd/treemap.rs
+++ b/src/libstd/treemap.rs
@@ -561,18 +561,18 @@ impl <K: Ord, V> TreeNode<K, V> {
 
 pure fn each<K: Ord, V>(node: &r/Option<~TreeNode<K, V>>,
                         f: fn(&(&r/K, &r/V)) -> bool) {
-    do node.map |x| {
+    do node.iter |x| {
         each(&x.left, f);
         if f(&(&x.key, &x.value)) { each(&x.right, f) }
-    };
+    }
 }
 
 pure fn each_reverse<K: Ord, V>(node: &r/Option<~TreeNode<K, V>>,
                                 f: fn(&(&r/K, &r/V)) -> bool) {
-    do node.map |x| {
+    do node.iter |x| {
         each_reverse(&x.right, f);
         if f(&(&x.key, &x.value)) { each_reverse(&x.left, f) }
-    };
+    }
 }
 
 // Remove left horizontal link by rotating right