// This makes use of a clever hack that brson came up with to // workaround our lack of traits and lack of macros. See core.{rc,rs} for // how this file is used. import inst::{IMPL_T, EACH, SIZE_HINT}; export extensions; impl extensions of iter::base_iter for IMPL_T { fn each(blk: fn(A) -> bool) { EACH(self, blk) } fn size_hint() -> option { SIZE_HINT(self) } } impl extensions of iter::extended_iter for IMPL_T { fn eachi(blk: fn(uint, A) -> bool) { iter::eachi(self, blk) } fn all(blk: fn(A) -> bool) -> bool { iter::all(self, blk) } fn any(blk: fn(A) -> bool) -> bool { iter::any(self, blk) } fn foldl(+b0: B, blk: fn(B, A) -> B) -> B { iter::foldl(self, b0, blk) } fn contains(x: A) -> bool { iter::contains(self, x) } fn count(x: A) -> uint { iter::count(self, x) } fn position(f: fn(A) -> bool) -> option { iter::position(self, f) } } impl extensions of iter::copyable_iter for IMPL_T { fn filter_to_vec(pred: fn(A) -> bool) -> ~[A] { iter::filter_to_vec(self, pred) } fn map_to_vec(op: fn(A) -> B) -> ~[B] { iter::map_to_vec(self, op) } fn to_vec() -> ~[A] { iter::to_vec(self) } // FIXME--bug in resolve prevents this from working (#2611) // fn flat_map_to_vec>(op: fn(A) -> IB) -> ~[B] { // iter::flat_map_to_vec(self, op) // } fn min() -> A { iter::min(self) } fn max() -> A { iter::max(self) } fn find(p: fn(A) -> bool) -> option { for self.each |i| { if p(i) { return some(i) } } return none; } }