1.0.0[][src]Trait prcn_lib::prelude::__std_iter::DoubleEndedIterator

pub trait DoubleEndedIterator: Iterator {
    fn next_back(&mut self) -> Option<Self::Item>;

    fn nth_back(&mut self, n: usize) -> Option<Self::Item> { ... }
fn try_rfold<B, F, R>(&mut self, init: B, f: F) -> R
    where
        F: FnMut(B, Self::Item) -> R,
        R: Try<Ok = B>
, { ... }
fn rfold<B, F>(self, accum: B, f: F) -> B
    where
        F: FnMut(B, Self::Item) -> B
, { ... }
fn rfind<P>(&mut self, predicate: P) -> Option<Self::Item>
    where
        P: FnMut(&Self::Item) -> bool
, { ... } }

An iterator able to yield elements from both ends.

Something that implements DoubleEndedIterator has one extra capability over something that implements Iterator: the ability to also take Items from the back, as well as the front.

It is important to note that both back and forth work on the same range, and do not cross: iteration is over when they meet in the middle.

In a similar fashion to the Iterator protocol, once a DoubleEndedIterator returns None from a next_back(), calling it again may or may not ever return Some again. next() and next_back() are interchangeable for this purpose.

Examples

Basic usage:

let numbers = vec![1, 2, 3, 4, 5, 6];

let mut iter = numbers.iter();

assert_eq!(Some(&1), iter.next());
assert_eq!(Some(&6), iter.next_back());
assert_eq!(Some(&5), iter.next_back());
assert_eq!(Some(&2), iter.next());
assert_eq!(Some(&3), iter.next());
assert_eq!(Some(&4), iter.next());
assert_eq!(None, iter.next());
assert_eq!(None, iter.next_back());

Required methods

fn next_back(&mut self) -> Option<Self::Item>

Removes and returns an element from the end of the iterator.

Returns None when there are no more elements.

The trait-level docs contain more details.

Examples

Basic usage:

let numbers = vec![1, 2, 3, 4, 5, 6];

let mut iter = numbers.iter();

assert_eq!(Some(&1), iter.next());
assert_eq!(Some(&6), iter.next_back());
assert_eq!(Some(&5), iter.next_back());
assert_eq!(Some(&2), iter.next());
assert_eq!(Some(&3), iter.next());
assert_eq!(Some(&4), iter.next());
assert_eq!(None, iter.next());
assert_eq!(None, iter.next_back());
Loading content...

Provided methods

fn nth_back(&mut self, n: usize) -> Option<Self::Item>1.37.0

Returns the nth element from the end of the iterator.

This is essentially the reversed version of nth. Although like most indexing operations, the count starts from zero, so nth_back(0) returns the first value from the end, nth_back(1) the second, and so on.

Note that all elements between the end and the returned element will be consumed, including the returned element. This also means that calling nth_back(0) multiple times on the same iterator will return different elements.

nth_back() will return None if n is greater than or equal to the length of the iterator.

Examples

Basic usage:

let a = [1, 2, 3];
assert_eq!(a.iter().nth_back(2), Some(&1));

Calling nth_back() multiple times doesn't rewind the iterator:

let a = [1, 2, 3];

let mut iter = a.iter();

assert_eq!(iter.nth_back(1), Some(&2));
assert_eq!(iter.nth_back(1), None);

Returning None if there are less than n + 1 elements:

let a = [1, 2, 3];
assert_eq!(a.iter().nth_back(10), None);

fn try_rfold<B, F, R>(&mut self, init: B, f: F) -> R where
    F: FnMut(B, Self::Item) -> R,
    R: Try<Ok = B>, 
1.27.0

This is the reverse version of try_fold(): it takes elements starting from the back of the iterator.

Examples

Basic usage:

let a = ["1", "2", "3"];
let sum = a.iter()
    .map(|&s| s.parse::<i32>())
    .try_rfold(0, |acc, x| x.and_then(|y| Ok(acc + y)));
assert_eq!(sum, Ok(6));

Short-circuiting:

let a = ["1", "rust", "3"];
let mut it = a.iter();
let sum = it
    .by_ref()
    .map(|&s| s.parse::<i32>())
    .try_rfold(0, |acc, x| x.and_then(|y| Ok(acc + y)));
assert!(sum.is_err());

// Because it short-circuited, the remaining elements are still
// available through the iterator.
assert_eq!(it.next_back(), Some(&"1"));

fn rfold<B, F>(self, accum: B, f: F) -> B where
    F: FnMut(B, Self::Item) -> B, 
1.27.0

An iterator method that reduces the iterator's elements to a single, final value, starting from the back.

This is the reverse version of fold(): it takes elements starting from the back of the iterator.

rfold() takes two arguments: an initial value, and a closure with two arguments: an 'accumulator', and an element. The closure returns the value that the accumulator should have for the next iteration.

The initial value is the value the accumulator will have on the first call.

After applying this closure to every element of the iterator, rfold() returns the accumulator.

This operation is sometimes called 'reduce' or 'inject'.

Folding is useful whenever you have a collection of something, and want to produce a single value from it.

Examples

Basic usage:

let a = [1, 2, 3];

// the sum of all of the elements of a
let sum = a.iter()
           .rfold(0, |acc, &x| acc + x);

assert_eq!(sum, 6);

This example builds a string, starting with an initial value and continuing with each element from the back until the front:

let numbers = [1, 2, 3, 4, 5];

let zero = "0".to_string();

let result = numbers.iter().rfold(zero, |acc, &x| {
    format!("({} + {})", x, acc)
});

assert_eq!(result, "(1 + (2 + (3 + (4 + (5 + 0)))))");

fn rfind<P>(&mut self, predicate: P) -> Option<Self::Item> where
    P: FnMut(&Self::Item) -> bool
1.27.0

Searches for an element of an iterator from the back that satisfies a predicate.

rfind() takes a closure that returns true or false. It applies this closure to each element of the iterator, starting at the end, and if any of them return true, then rfind() returns Some(element). If they all return false, it returns None.

rfind() is short-circuiting; in other words, it will stop processing as soon as the closure returns true.

Because rfind() takes a reference, and many iterators iterate over references, this leads to a possibly confusing situation where the argument is a double reference. You can see this effect in the examples below, with &&x.

Examples

Basic usage:

let a = [1, 2, 3];

assert_eq!(a.iter().rfind(|&&x| x == 2), Some(&2));

assert_eq!(a.iter().rfind(|&&x| x == 5), None);

Stopping at the first true:

let a = [1, 2, 3];

let mut iter = a.iter();

assert_eq!(iter.rfind(|&&x| x == 2), Some(&2));

// we can still use `iter`, as there are more elements.
assert_eq!(iter.next_back(), Some(&1));
Loading content...

Implementations on Foreign Types

impl DoubleEndedIterator for Args[src]

impl<'a> DoubleEndedIterator for Iter<'a>[src]

impl DoubleEndedIterator for ArgsOs[src]

impl<'a> DoubleEndedIterator for Components<'a>[src]

impl<'a, T> DoubleEndedIterator for Windows<'a, T>[src]

impl<'a, T> DoubleEndedIterator for IterMut<'a, T>[src]

impl<'a, P> DoubleEndedIterator for RMatches<'a, P> where
    P: Pattern<'a>,
    <P as Pattern<'a>>::Searcher: DoubleEndedSearcher<'a>, 
[src]

impl<'a, T> DoubleEndedIterator for RChunksExact<'a, T>[src]

impl DoubleEndedIterator for EscapeDefault[src]

impl<'a, T> DoubleEndedIterator for ChunksExact<'a, T>[src]

impl<'a, T, P> DoubleEndedIterator for RSplit<'a, T, P> where
    P: FnMut(&T) -> bool
[src]

impl<'a> DoubleEndedIterator for Lines<'a>[src]

impl<'a, T, P> DoubleEndedIterator for RSplitMut<'a, T, P> where
    P: FnMut(&T) -> bool
[src]

impl<'a> DoubleEndedIterator for Chars<'a>[src]

impl<'a, P> DoubleEndedIterator for MatchIndices<'a, P> where
    P: Pattern<'a>,
    <P as Pattern<'a>>::Searcher: DoubleEndedSearcher<'a>, 
[src]

impl<T> DoubleEndedIterator for IntoIter<T>[src]

impl<'a> DoubleEndedIterator for CharIndices<'a>[src]

impl<'_> DoubleEndedIterator for Bytes<'_>[src]

impl<'a, P> DoubleEndedIterator for SplitTerminator<'a, P> where
    P: Pattern<'a>,
    <P as Pattern<'a>>::Searcher: DoubleEndedSearcher<'a>, 
[src]

impl<'a, T> DoubleEndedIterator for ChunksExactMut<'a, T>[src]

impl<'a, T> DoubleEndedIterator for ChunksMut<'a, T>[src]

impl<'a, P> DoubleEndedIterator for RSplit<'a, P> where
    P: Pattern<'a>,
    <P as Pattern<'a>>::Searcher: DoubleEndedSearcher<'a>, 
[src]

impl<'a, T> DoubleEndedIterator for Chunks<'a, T>[src]

impl<'a, A> DoubleEndedIterator for Iter<'a, A>[src]

impl<'a, P> DoubleEndedIterator for RMatchIndices<'a, P> where
    P: Pattern<'a>,
    <P as Pattern<'a>>::Searcher: DoubleEndedSearcher<'a>, 
[src]

impl<'a, T, P> DoubleEndedIterator for SplitInclusiveMut<'a, T, P> where
    P: FnMut(&T) -> bool
[src]

impl<'a, T> DoubleEndedIterator for RChunks<'a, T>[src]

impl<A> DoubleEndedIterator for Range<A> where
    A: Step
[src]

impl<'a, T> DoubleEndedIterator for RChunksExactMut<'a, T>[src]

impl<'a> DoubleEndedIterator for LinesAny<'a>[src]

impl<'a> DoubleEndedIterator for SplitWhitespace<'a>[src]

impl<'a, I> DoubleEndedIterator for &'a mut I where
    I: DoubleEndedIterator + ?Sized
[src]

impl<'a, P> DoubleEndedIterator for SplitInclusive<'a, P> where
    P: Pattern<'a>,
    <P as Pattern<'a>>::Searcher: ReverseSearcher<'a>, 
[src]

impl<'a, T> DoubleEndedIterator for IterMut<'a, T>[src]

impl<'a, T> DoubleEndedIterator for Iter<'a, T>[src]

impl<const N: usize, T> DoubleEndedIterator for IntoIter<T, N> where
    [T; N]: LengthAtMost32
[src]

impl<'a, P> DoubleEndedIterator for RSplitTerminator<'a, P> where
    P: Pattern<'a>,
    <P as Pattern<'a>>::Searcher: DoubleEndedSearcher<'a>, 
[src]

impl<'a, T> DoubleEndedIterator for Iter<'a, T>[src]

impl<'a, T, P> DoubleEndedIterator for SplitInclusive<'a, T, P> where
    P: FnMut(&T) -> bool
[src]

impl<A> DoubleEndedIterator for RangeInclusive<A> where
    A: Step
[src]

impl<'a, T, P> DoubleEndedIterator for SplitMut<'a, T, P> where
    P: FnMut(&T) -> bool
[src]

impl<'a, P> DoubleEndedIterator for Split<'a, P> where
    P: Pattern<'a>,
    <P as Pattern<'a>>::Searcher: DoubleEndedSearcher<'a>, 
[src]

impl<'a, P> DoubleEndedIterator for Matches<'a, P> where
    P: Pattern<'a>,
    <P as Pattern<'a>>::Searcher: DoubleEndedSearcher<'a>, 
[src]

impl<'a, T, P> DoubleEndedIterator for Split<'a, T, P> where
    P: FnMut(&T) -> bool
[src]

impl<'a, A> DoubleEndedIterator for IterMut<'a, A>[src]

impl<'a, T> DoubleEndedIterator for RChunksMut<'a, T>[src]

impl<'a> DoubleEndedIterator for SplitAsciiWhitespace<'a>[src]

impl<A> DoubleEndedIterator for IntoIter<A>[src]

impl<T> DoubleEndedIterator for IntoIter<T>[src]

impl<T> DoubleEndedIterator for IntoIter<T>[src]

impl<'a, T> DoubleEndedIterator for Range<'a, T>[src]

impl<'_> DoubleEndedIterator for Drain<'_>[src]

impl<'a, K, V> DoubleEndedIterator for Keys<'a, K, V>[src]

impl<'a, T> DoubleEndedIterator for IterMut<'a, T>[src]

impl<'a, T> DoubleEndedIterator for Iter<'a, T>[src]

impl<'_, I> DoubleEndedIterator for Splice<'_, I> where
    I: Iterator
[src]

impl<'a, K, V> DoubleEndedIterator for Range<'a, K, V>[src]

impl<'a, K, V> DoubleEndedIterator for Values<'a, K, V>[src]

impl<'_, T> DoubleEndedIterator for Drain<'_, T>[src]

impl<'_, T> DoubleEndedIterator for Drain<'_, T>[src]

impl<T> DoubleEndedIterator for IntoIter<T>[src]

impl<'a, K, V> DoubleEndedIterator for ValuesMut<'a, K, V>[src]

impl<'a, T> DoubleEndedIterator for Iter<'a, T>[src]

impl<K, V> DoubleEndedIterator for IntoIter<K, V>[src]

impl<'a, K, V> DoubleEndedIterator for IterMut<'a, K, V> where
    K: 'a,
    V: 'a, 
[src]

impl<'a, T> DoubleEndedIterator for Iter<'a, T>[src]

impl<T> DoubleEndedIterator for IntoIter<T>[src]

impl<'a, K, V> DoubleEndedIterator for Iter<'a, K, V> where
    K: 'a,
    V: 'a, 
[src]

impl<'_, T> DoubleEndedIterator for Drain<'_, T>[src]

impl<'a, K, V> DoubleEndedIterator for RangeMut<'a, K, V>[src]

impl<'a, T> DoubleEndedIterator for Iter<'a, T>[src]

impl<T> DoubleEndedIterator for IntoIter<T>[src]

impl<I> DoubleEndedIterator for Box<I> where
    I: DoubleEndedIterator + ?Sized
[src]

impl<'a, T> DoubleEndedIterator for IterMut<'a, T>[src]

impl<A> DoubleEndedIterator for RangeInclusive<A> where
    A: Sub<A, Output = A> + Integer + Clone + ToPrimitive
[src]

impl<A> DoubleEndedIterator for Range<A> where
    A: Integer + Clone + ToPrimitive
[src]

Integer is required to ensure the range will be the same regardless of the direction it is consumed.

impl<'a> DoubleEndedIterator for CharsRef<'a>[src]

impl<'a> DoubleEndedIterator for Chars<'a>[src]

impl<'a> DoubleEndedIterator for CharsMut<'a>[src]

impl<'a, A> DoubleEndedIterator for RangedIter<'a, A> where
    A: 'a + Ord
[src]

impl<'a, A> DoubleEndedIterator for IterMut<'a, A> where
    A: 'a + Clone
[src]

fn next_back(&mut self) -> Option<<IterMut<'a, A> as Iterator>::Item>[src]

Remove and return an element from the back of the iterator.

Time: O(1)*

impl<'a, K, V> DoubleEndedIterator for Keys<'a, K, V> where
    K: 'a + Ord,
    V: 'a, 
[src]

impl<'a, A> DoubleEndedIterator for Chunks<'a, A> where
    A: Clone
[src]

fn next_back(&mut self) -> Option<<Chunks<'a, A> as Iterator>::Item>[src]

Remove and return an element from the back of the iterator.

Time: O(1)*

impl<'a, A> DoubleEndedIterator for Iter<'a, A> where
    A: 'a + Ord
[src]

impl<'a, A> DoubleEndedIterator for ChunksMut<'a, A> where
    A: Clone
[src]

fn next_back(&mut self) -> Option<<ChunksMut<'a, A> as Iterator>::Item>[src]

Remove and return an element from the back of the iterator.

Time: O(1)*

impl<'a, A> DoubleEndedIterator for Iter<'a, A> where
    A: Clone
[src]

fn next_back(&mut self) -> Option<<Iter<'a, A> as Iterator>::Item>[src]

Advance the iterator and return the next value.

Time: O(1)*

impl<'a, K, V> DoubleEndedIterator for Values<'a, K, V> where
    K: 'a + Ord,
    V: 'a, 
[src]

impl<'a, A> DoubleEndedIterator for Iter<'a, A> where
    A: 'a + BTreeValue, 
[src]

impl<A> DoubleEndedIterator for ConsumingIter<A> where
    A: BTreeValue + Clone
[src]

impl<'a, A> DoubleEndedIterator for Iter<'a, A> where
    A: 'a + BTreeValue, 
[src]

impl<A> DoubleEndedIterator for ConsumingIter<A> where
    A: Clone
[src]

fn next_back(&mut self) -> Option<<ConsumingIter<A> as Iterator>::Item>[src]

Remove and return an element from the back of the iterator.

Time: O(1)*

impl<A, T> DoubleEndedIterator for Iter<A, T>

impl<'a, A, N> DoubleEndedIterator for Iter<'a, A, N> where
    N: ChunkLength<A>, 

impl<'a, A, N> DoubleEndedIterator for IterMut<'a, A, N> where
    N: ChunkLength<A>, 

impl<'a, A, N> DoubleEndedIterator for Drain<'a, A, N> where
    A: 'a,
    N: ChunkLength<A> + 'a, 

impl<'a, A, T> DoubleEndedIterator for Drain<'a, A, T>

impl<A, N> DoubleEndedIterator for Iter<A, N> where
    N: ChunkLength<A>, 

impl<'a, A, N> DoubleEndedIterator for Drain<'a, A, N> where
    A: 'a,
    N: 'a + ChunkLength<A>, 

impl<A, N> DoubleEndedIterator for OwnedIter<A, N> where
    N: ChunkLength<A>, 

impl<'a, K, V> DoubleEndedIterator for IntoIter<K, V>[src]

impl<'a, K, V> DoubleEndedIterator for Iter<'a, K, V>[src]

impl<'a, T, S> DoubleEndedIterator for Intersection<'a, T, S> where
    S: BuildHasher,
    T: Eq + Hash
[src]

impl<'a, K, V> DoubleEndedIterator for ValuesMut<'a, K, V>[src]

impl<'a, K, V> DoubleEndedIterator for IterMut<'a, K, V>[src]

impl<'a, K, V> DoubleEndedIterator for Drain<'a, K, V>[src]

impl<'a, K, V> DoubleEndedIterator for Values<'a, K, V>[src]

impl<T> DoubleEndedIterator for IntoIter<T>[src]

impl<'a, T, S> DoubleEndedIterator for Difference<'a, T, S> where
    S: BuildHasher,
    T: Eq + Hash
[src]

impl<'a, T> DoubleEndedIterator for Iter<'a, T>[src]

impl<'a, K, V> DoubleEndedIterator for Keys<'a, K, V>[src]

impl<'a, T> DoubleEndedIterator for Drain<'a, T>[src]

impl<'a, T, S> DoubleEndedIterator for Union<'a, T, S> where
    S: BuildHasher,
    T: Eq + Hash
[src]

impl<'a, T, S1, S2> DoubleEndedIterator for SymmetricDifference<'a, T, S1, S2> where
    S1: BuildHasher,
    S2: BuildHasher,
    T: Eq + Hash
[src]

impl<F> DoubleEndedIterator for Linspace<F> where
    F: Float
[src]

impl<T, N> DoubleEndedIterator for GenericArrayIter<T, N> where
    N: ArrayLength<T>, 

impl<'a, A, D> DoubleEndedIterator for AxisChunksIter<'a, A, D> where
    D: Dimension
[src]

impl<'a, A, D> DoubleEndedIterator for AxisChunksIterMut<'a, A, D> where
    D: Dimension
[src]

impl<'a, A> DoubleEndedIterator for IterMut<'a, A, Dim<[usize; 1]>>[src]

impl<'a, A, D> DoubleEndedIterator for AxisIterMut<'a, A, D> where
    D: Dimension
[src]

impl<'a, A> DoubleEndedIterator for Iter<'a, A, Dim<[usize; 1]>>[src]

impl<'a, D> DoubleEndedIterator for Axes<'a, D> where
    D: Dimension
[src]

impl<'a, A, D> DoubleEndedIterator for AxisIter<'a, A, D> where
    D: Dimension
[src]

impl<T, U> DoubleEndedIterator for ZipLongest<T, U> where
    T: DoubleEndedIterator + ExactSizeIterator,
    U: DoubleEndedIterator + ExactSizeIterator
[src]

impl<X, Iter, E, F, G, H> DoubleEndedIterator for ConsTuples<Iter, ((E, F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((E, F, G, H), X)>, 
[src]

impl<I, F> DoubleEndedIterator for PadUsing<I, F> where
    F: FnMut(usize) -> <I as Iterator>::Item,
    I: DoubleEndedIterator + ExactSizeIterator
[src]

impl<I, F> DoubleEndedIterator for Positions<I, F> where
    F: FnMut(<I as Iterator>::Item) -> bool,
    I: DoubleEndedIterator + ExactSizeIterator
[src]

impl<I, F> DoubleEndedIterator for Update<I, F> where
    F: FnMut(&mut <I as Iterator>::Item),
    I: DoubleEndedIterator
[src]

impl<I, R> DoubleEndedIterator for MapInto<I, R> where
    I: DoubleEndedIterator,
    <I as Iterator>::Item: Into<R>, 
[src]

impl<X, Iter, D, E, F, G, H> DoubleEndedIterator for ConsTuples<Iter, ((D, E, F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((D, E, F, G, H), X)>, 
[src]

impl<X, Iter, C, D, E, F, G, H> DoubleEndedIterator for ConsTuples<Iter, ((C, D, E, F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((C, D, E, F, G, H), X)>, 
[src]

impl<X, Iter, F, G, H> DoubleEndedIterator for ConsTuples<Iter, ((F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((F, G, H), X)>, 
[src]

impl<X, Iter, G, H> DoubleEndedIterator for ConsTuples<Iter, ((G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((G, H), X)>, 
[src]

impl<A> DoubleEndedIterator for RepeatN<A> where
    A: Clone
[src]

impl<X, Iter, B, C, D, E, F, G, H> DoubleEndedIterator for ConsTuples<Iter, ((B, C, D, E, F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((B, C, D, E, F, G, H), X)>, 
[src]

impl<'a, N, E, Ty> DoubleEndedIterator for AllEdges<'a, N, E, Ty> where
    E: 'a,
    N: 'a + NodeTrait,
    Ty: EdgeType
[src]

impl<'a, N, Ix> DoubleEndedIterator for NodeReferences<'a, N, Ix> where
    Ix: IndexType
[src]

impl<'a, E, Ix> DoubleEndedIterator for EdgeReferences<'a, E, Ix> where
    Ix: IndexType
[src]

impl<'a, E, Ix> DoubleEndedIterator for EdgeReferences<'a, E, Ix> where
    Ix: IndexType
[src]

impl<'a, N, E, Ty> DoubleEndedIterator for AllEdgesMut<'a, N, E, Ty> where
    E: 'a,
    N: 'a + NodeTrait,
    Ty: EdgeType
[src]

impl<'a, E, Ix> DoubleEndedIterator for EdgeIndices<'a, E, Ix> where
    Ix: IndexType
[src]

impl<Ix> DoubleEndedIterator for EdgeIndices<Ix> where
    Ix: IndexType
[src]

impl<'a, N, Ix> DoubleEndedIterator for NodeIndices<'a, N, Ix> where
    Ix: IndexType
[src]

impl<'a, N, Ix> DoubleEndedIterator for NodeReferences<'a, N, Ix> where
    Ix: IndexType
[src]

impl<Ix> DoubleEndedIterator for NodeIndices<Ix> where
    Ix: IndexType
[src]

impl DoubleEndedIterator for SetMatchesIntoIter[src]

impl<'a> DoubleEndedIterator for SetMatchesIter<'a>[src]

impl DoubleEndedIterator for SetMatchesIntoIter[src]

impl<'a> DoubleEndedIterator for SetMatchesIter<'a>[src]

impl<'a> DoubleEndedIterator for Memchr2<'a>[src]

impl<'a> DoubleEndedIterator for Memchr3<'a>[src]

impl<'a> DoubleEndedIterator for Memchr<'a>[src]

impl<'a, T> DoubleEndedIterator for Drain<'a, T> where
    T: 'a + Array
[src]

impl<A> DoubleEndedIterator for IntoIter<A> where
    A: Array
[src]

Loading content...

Implementors

impl<'a, I, T> DoubleEndedIterator for Cloned<I> where
    I: DoubleEndedIterator<Item = &'a T>,
    T: 'a + Clone
[src]

impl<'a, I, T> DoubleEndedIterator for Copied<I> where
    I: DoubleEndedIterator<Item = &'a T>,
    T: 'a + Copy
[src]

impl<A> DoubleEndedIterator for Repeat<A> where
    A: Clone
[src]

impl<A> DoubleEndedIterator for prcn_lib::prelude::RepeatN<A> where
    A: Clone
[src]

impl<A, B> DoubleEndedIterator for Chain<A, B> where
    A: DoubleEndedIterator,
    B: DoubleEndedIterator<Item = <A as Iterator>::Item>, 
[src]

impl<A, B> DoubleEndedIterator for Zip<A, B> where
    A: DoubleEndedIterator + ExactSizeIterator,
    B: DoubleEndedIterator + ExactSizeIterator
[src]

impl<A, F> DoubleEndedIterator for OnceWith<F> where
    F: FnOnce() -> A, 
[src]

impl<B, I, F> DoubleEndedIterator for FilterMap<I, F> where
    F: FnMut(<I as Iterator>::Item) -> Option<B>,
    I: DoubleEndedIterator
[src]

impl<B, I, F> DoubleEndedIterator for Map<I, F> where
    F: FnMut(<I as Iterator>::Item) -> B,
    I: DoubleEndedIterator
[src]

impl<I> DoubleEndedIterator for Enumerate<I> where
    I: ExactSizeIterator + DoubleEndedIterator
[src]

impl<I> DoubleEndedIterator for Fuse<I> where
    I: DoubleEndedIterator
[src]

impl<I> DoubleEndedIterator for Peekable<I> where
    I: DoubleEndedIterator
[src]

impl<I> DoubleEndedIterator for Rev<I> where
    I: DoubleEndedIterator
[src]

impl<I> DoubleEndedIterator for Skip<I> where
    I: DoubleEndedIterator + ExactSizeIterator
[src]

impl<I> DoubleEndedIterator for StepBy<I> where
    I: DoubleEndedIterator + ExactSizeIterator
[src]

impl<I> DoubleEndedIterator for Take<I> where
    I: DoubleEndedIterator + ExactSizeIterator
[src]

impl<I> DoubleEndedIterator for RcIter<I> where
    I: DoubleEndedIterator
[src]

impl<I, F> DoubleEndedIterator for Inspect<I, F> where
    F: FnMut(&<I as Iterator>::Item),
    I: DoubleEndedIterator
[src]

impl<I, F> DoubleEndedIterator for prcn_lib::prelude::PadUsing<I, F> where
    F: FnMut(usize) -> <I as Iterator>::Item,
    I: DoubleEndedIterator + ExactSizeIterator
[src]

impl<I, F> DoubleEndedIterator for prcn_lib::prelude::Positions<I, F> where
    F: FnMut(<I as Iterator>::Item) -> bool,
    I: DoubleEndedIterator + ExactSizeIterator
[src]

impl<I, F> DoubleEndedIterator for prcn_lib::prelude::Update<I, F> where
    F: FnMut(&mut <I as Iterator>::Item),
    I: DoubleEndedIterator
[src]

impl<I, P> DoubleEndedIterator for Filter<I, P> where
    I: DoubleEndedIterator,
    P: FnMut(&<I as Iterator>::Item) -> bool
[src]

impl<I, R> DoubleEndedIterator for prcn_lib::prelude::MapInto<I, R> where
    I: DoubleEndedIterator,
    <I as Iterator>::Item: Into<R>, 
[src]

impl<I, U> DoubleEndedIterator for Flatten<I> where
    I: DoubleEndedIterator,
    U: DoubleEndedIterator,
    <I as Iterator>::Item: IntoIterator,
    <<I as Iterator>::Item as IntoIterator>::IntoIter == U,
    <<I as Iterator>::Item as IntoIterator>::Item == <U as Iterator>::Item
[src]

impl<I, U, F> DoubleEndedIterator for FlatMap<I, U, F> where
    F: FnMut(<I as Iterator>::Item) -> U,
    I: DoubleEndedIterator,
    U: IntoIterator,
    <U as IntoIterator>::IntoIter: DoubleEndedIterator
[src]

impl<L, R> DoubleEndedIterator for Either<L, R> where
    L: DoubleEndedIterator,
    R: DoubleEndedIterator<Item = <L as Iterator>::Item>, 
[src]

impl<T> DoubleEndedIterator for Empty<T>[src]

impl<T> DoubleEndedIterator for Once<T>[src]

impl<T, U> DoubleEndedIterator for prcn_lib::prelude::ZipLongest<T, U> where
    T: DoubleEndedIterator + ExactSizeIterator,
    U: DoubleEndedIterator + ExactSizeIterator
[src]

impl<X, Iter, B, C, D, E, F, G, H> DoubleEndedIterator for prcn_lib::prelude::ConsTuples<Iter, ((B, C, D, E, F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((B, C, D, E, F, G, H), X)>, 
[src]

impl<X, Iter, C, D, E, F, G, H> DoubleEndedIterator for prcn_lib::prelude::ConsTuples<Iter, ((C, D, E, F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((C, D, E, F, G, H), X)>, 
[src]

impl<X, Iter, D, E, F, G, H> DoubleEndedIterator for prcn_lib::prelude::ConsTuples<Iter, ((D, E, F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((D, E, F, G, H), X)>, 
[src]

impl<X, Iter, E, F, G, H> DoubleEndedIterator for prcn_lib::prelude::ConsTuples<Iter, ((E, F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((E, F, G, H), X)>, 
[src]

impl<X, Iter, F, G, H> DoubleEndedIterator for prcn_lib::prelude::ConsTuples<Iter, ((F, G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((F, G, H), X)>, 
[src]

impl<X, Iter, G, H> DoubleEndedIterator for prcn_lib::prelude::ConsTuples<Iter, ((G, H), X)> where
    Iter: DoubleEndedIterator<Item = ((G, H), X)>, 
[src]

Loading content...