2012-12-03 16:48:01 -08:00
|
|
|
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
2012-04-11 21:45:18 -07:00
|
|
|
// 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.
|
|
|
|
|
2012-10-03 14:52:09 -07:00
|
|
|
#[forbid(deprecated_mode)];
|
|
|
|
#[forbid(deprecated_pattern)];
|
2012-09-25 17:39:22 -07:00
|
|
|
|
2012-09-04 11:12:17 -07:00
|
|
|
use cmp::{Eq, Ord};
|
2013-01-08 19:37:25 -08:00
|
|
|
use iter::BaseIter;
|
2012-12-23 17:41:37 -05:00
|
|
|
use iter;
|
2013-01-08 19:37:25 -08:00
|
|
|
use kinds::Copy;
|
|
|
|
use option::Option;
|
2012-12-13 13:05:22 -08:00
|
|
|
|
|
|
|
use self::inst::{IMPL_T, EACH, SIZE_HINT};
|
2012-04-11 21:45:18 -07:00
|
|
|
|
2012-08-14 16:54:13 -07:00
|
|
|
impl<A> IMPL_T<A>: iter::BaseIter<A> {
|
2012-12-11 09:06:56 -08:00
|
|
|
pure fn each(&self, blk: fn(v: &A) -> bool) { EACH(self, blk) }
|
|
|
|
pure fn size_hint(&self) -> Option<uint> { SIZE_HINT(self) }
|
2012-07-11 15:00:40 -07:00
|
|
|
}
|
|
|
|
|
2012-08-14 16:54:13 -07:00
|
|
|
impl<A> IMPL_T<A>: iter::ExtendedIter<A> {
|
2012-12-11 09:06:56 -08:00
|
|
|
pure fn eachi(&self, blk: fn(uint, v: &A) -> bool) {
|
|
|
|
iter::eachi(self, blk)
|
2012-04-11 21:45:18 -07:00
|
|
|
}
|
2012-12-11 09:06:56 -08:00
|
|
|
pure fn all(&self, blk: fn(&A) -> bool) -> bool {
|
|
|
|
iter::all(self, blk)
|
|
|
|
}
|
|
|
|
pure fn any(&self, blk: fn(&A) -> bool) -> bool {
|
|
|
|
iter::any(self, blk)
|
|
|
|
}
|
|
|
|
pure fn foldl<B>(&self, b0: B, blk: fn(&B, &A) -> B) -> B {
|
|
|
|
iter::foldl(self, move b0, blk)
|
|
|
|
}
|
|
|
|
pure fn position(&self, f: fn(&A) -> bool) -> Option<uint> {
|
|
|
|
iter::position(self, f)
|
2012-09-13 09:13:03 -07:00
|
|
|
}
|
2012-12-17 20:36:12 -08:00
|
|
|
pure fn map_to_vec<B>(&self, op: fn(&A) -> B) -> ~[B] {
|
|
|
|
iter::map_to_vec(self, op)
|
|
|
|
}
|
|
|
|
pure fn flat_map_to_vec<B,IB:BaseIter<B>>(&self, op: fn(&A) -> IB)
|
|
|
|
-> ~[B] {
|
|
|
|
iter::flat_map_to_vec(self, op)
|
|
|
|
}
|
|
|
|
|
2012-08-27 16:26:35 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
impl<A: Eq> IMPL_T<A>: iter::EqIter<A> {
|
2012-12-11 09:06:56 -08:00
|
|
|
pure fn contains(&self, x: &A) -> bool { iter::contains(self, x) }
|
|
|
|
pure fn count(&self, x: &A) -> uint { iter::count(self, x) }
|
2012-04-11 21:45:18 -07:00
|
|
|
}
|
|
|
|
|
2012-09-07 14:52:28 -07:00
|
|
|
impl<A: Copy> IMPL_T<A>: iter::CopyableIter<A> {
|
2012-12-17 20:36:12 -08:00
|
|
|
pure fn filter_to_vec(&self, pred: fn(&A) -> bool) -> ~[A] {
|
2012-12-11 09:06:56 -08:00
|
|
|
iter::filter_to_vec(self, pred)
|
2012-04-11 21:45:18 -07:00
|
|
|
}
|
2012-12-11 09:06:56 -08:00
|
|
|
pure fn to_vec(&self) -> ~[A] { iter::to_vec(self) }
|
2012-12-17 20:36:12 -08:00
|
|
|
pure fn find(&self, f: fn(&A) -> bool) -> Option<A> {
|
2012-12-11 09:06:56 -08:00
|
|
|
iter::find(self, f)
|
2012-09-28 17:04:39 -07:00
|
|
|
}
|
2012-08-27 16:26:35 -07:00
|
|
|
}
|
|
|
|
|
2012-09-07 14:52:28 -07:00
|
|
|
impl<A: Copy Ord> IMPL_T<A>: iter::CopyableOrderedIter<A> {
|
2012-12-11 09:06:56 -08:00
|
|
|
pure fn min(&self) -> A { iter::min(self) }
|
|
|
|
pure fn max(&self) -> A { iter::max(self) }
|
2012-04-11 21:45:18 -07:00
|
|
|
}
|
2012-08-27 16:26:35 -07:00
|
|
|
|