diff options
| author | Patrick Walton <pcwalton@mimiga.net> | 2011-07-05 17:22:02 -0700 |
|---|---|---|
| committer | Patrick Walton <pcwalton@mimiga.net> | 2011-07-05 17:22:02 -0700 |
| commit | 8261d2e6fb32dd4e811d33b3ef40abde8e67ae3d (patch) | |
| tree | 0bbf6755d2a7c70b490fedc2dd211855db879158 | |
| parent | ee5d7bbc86b63015089a4907afc4c20c1c0559c9 (diff) | |
| download | rust-8261d2e6fb32dd4e811d33b3ef40abde8e67ae3d.tar.gz rust-8261d2e6fb32dd4e811d33b3ef40abde8e67ae3d.zip | |
stdlib: Add filter_map to ivec
| -rw-r--r-- | src/lib/ivec.rs | 12 | ||||
| -rw-r--r-- | src/test/run-pass/lib-ivec.rs | 23 |
2 files changed, 35 insertions, 0 deletions
diff --git a/src/lib/ivec.rs b/src/lib/ivec.rs index c39905b3777..14c5dda83b3 100644 --- a/src/lib/ivec.rs +++ b/src/lib/ivec.rs @@ -171,6 +171,18 @@ fn map[T,U](fn(&T)->U f, &T[mutable?] v) -> U[] { ret result; } +fn filter_map[T,U](fn(&T)->option::t[U] f, &T[mutable?] v) -> U[] { + auto result = ~[]; + for (T elem in v) { + auto elem2 = elem; // satisfies alias checker + alt (f(elem2)) { + case (none) { /* no-op */ } + case (some(?result_elem)) { result += ~[result_elem]; } + } + } + ret result; +} + fn any[T](fn(&T)->bool f, &T[] v) -> bool { for (T elem in v) { if (f(elem)) { ret true; } } ret false; diff --git a/src/test/run-pass/lib-ivec.rs b/src/test/run-pass/lib-ivec.rs index 3653ffb4db5..6949e32b5a0 100644 --- a/src/test/run-pass/lib-ivec.rs +++ b/src/test/run-pass/lib-ivec.rs @@ -2,6 +2,7 @@ use std; import std::ivec; +import std::option; import std::option::none; import std::option::some; @@ -11,6 +12,10 @@ fn square_alias(&uint n) -> uint { ret n * n; } pred is_three(&uint n) -> bool { ret n == 3u; } +fn square_if_odd(&uint n) -> option::t[uint] { + ret if (n % 2u == 1u) { some(n * n) } else { none }; +} + fn test_reserve_and_on_heap() { let int[] v = ~[ 1, 2 ]; assert (!ivec::on_heap(v)); @@ -188,6 +193,23 @@ fn test_map() { assert (w.(4) == 25u); } +fn test_filter_map() { + // Test on-stack filter-map. + auto v = ~[ 1u, 2u, 3u ]; + auto w = ivec::filter_map(square_if_odd, v); + assert (ivec::len(w) == 2u); + assert (w.(0) == 1u); + assert (w.(1) == 9u); + + // Test on-heap filter-map. + v = ~[ 1u, 2u, 3u, 4u, 5u ]; + w = ivec::filter_map(square_if_odd, v); + assert (ivec::len(w) == 3u); + assert (w.(0) == 1u); + assert (w.(1) == 9u); + assert (w.(2) == 25u); +} + fn test_any_and_all() { assert (ivec::any(is_three, ~[ 1u, 2u, 3u ])); assert (!ivec::any(is_three, ~[ 0u, 1u, 2u ])); @@ -220,6 +242,7 @@ fn main() { // Functional utilities test_map(); + test_filter_map(); test_any_and_all(); } |
