Skip to content

Commit fe841f3

Browse files
committed
implement ReverseIter for SmallIntMap
1 parent a2f922f commit fe841f3

File tree

1 file changed

+13
-1
lines changed

1 file changed

+13
-1
lines changed

src/libstd/smallintmap.rs

Lines changed: 13 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@
1414
*/
1515

1616
use core::container::{Container, Mutable, Map, Set};
17-
use core::iter::BaseIter;
17+
use core::iter::{BaseIter, ReverseIter};
1818
use core::option::{Some, None};
1919
use core::prelude::*;
2020

@@ -36,6 +36,18 @@ impl<V> SmallIntMap<V>: BaseIter<(uint, &V)> {
3636
pure fn size_hint(&self) -> Option<uint> { Some(self.len()) }
3737
}
3838

39+
impl<V> SmallIntMap<V>: ReverseIter<(uint, &V)> {
40+
/// Visit all key-value pairs in reverse order
41+
pure fn each_reverse(&self, it: fn(&(uint, &self/V)) -> bool) {
42+
for uint::range_rev(self.v.len(), 0) |i| {
43+
match self.v[i - 1] {
44+
Some(ref elt) => if !it(&(i - 1, elt)) { break },
45+
None => ()
46+
}
47+
}
48+
}
49+
}
50+
3951
impl<V> SmallIntMap<V>: Container {
4052
/// Return the number of elements in the map
4153
pure fn len(&self) -> uint {

0 commit comments

Comments
 (0)