pub struct PeekMoreIterator<I: Iterator> { /* private fields */ }
Expand description

This iterator makes it possible to peek multiple times without consuming a value. In reality the underlying iterator will be consumed, but the values will be stored in a queue. This queue allows us to peek at unconsumed elements (as far as the multi-peek iterator is concerned). When the iterator consumes an element, the element at the front of the queue will be dequeued, and will no longer be peekable.

Implementations§

source§

impl<I: Iterator> PeekMoreIterator<I>

source

pub fn peek(&mut self) -> Option<&I::Item>

Get a reference to the element where the cursor currently points to. If no such element exists, return None will be returned.

If we haven’t advanced our cursor, it will point to the same element as Iterator::next() would return. Note that the cursor can’t point to an element before the first unconsumed element within the iterator. In a sense the cursor moves independently within the iterator. But it can only point to unconsumed elements.

The following illustration aims to show how peek() behaves. i represents the position of the iterator (i.e. the next value that will be returned if next() is called) and j represents the position of the cursor (i.e. the current element referenced if peek() is called). In example code next to the illustrations, the first element 1 is analogous to A, 2 to B, etc.

The example below primarily uses advance_cursor() to move the cursor and peek() to peek at the element the cursor points to, but many often more convenient methods exist to change the element cursor points at, or to peek at those elements.

  • Let’s start:
use peekmore::PeekMore;

// Initialize our iterator.
let iterable = [1, 2, 3, 4];
let mut iterator = iterable.iter().peekmore();
-----     -----      -----     -----
| A | --> | B |  --> | C | --> | D | --> None --> None --> ...
-----     -----      -----     -----
  ^
  i, j
  • Call peek():
let j = iterator.peek();
assert_eq!(j, Some(&&1));
-----     -----      -----     -----
| A | --> | B |  --> | C | --> | D | --> None --> None --> ...
-----     -----      -----     -----
  ^
  i, j
     returns Some(&A)

  • Call advance_cursor()
let iter = iterator.advance_cursor();
-----     -----      -----     -----
| A | --> | B |  --> | C | --> | D | --> None --> None --> ...
-----     -----      -----     -----
  ^         ^
  i         j
  • Call peek()

The reference returned by peek() will not change, similar to the behaviour of core::iter::Peekable::peek. In order to move to the next peekable element, we need to advance the cursor.

let j = iterator.peek();
assert_eq!(j, Some(&&2));

// Calling `peek()` multiple times doesn't shift the position of the cursor;
// a reference to the same element will be returned each call.
assert_eq!(iterator.peek(), Some(&&2));
assert_eq!(iterator.peek(), Some(&&2));
-----     -----      -----     -----
| A | --> | B |  --> | C | --> | D | --> None --> None --> ...
-----     -----      -----     -----
  ^         ^
  i         j
            returns Some(&B)
  • Call next()

By calling next, the underlying iterator will be advanced andthe element represented by A will be consumed. It won’t be possible to peek at A anymore.

let i = iterator.next();
assert_eq!(i, Some(&1));
-----     -----      -----     -----
| A |     | B |  --> | C | --> | D | --> None --> None --> ...
-----     -----      -----     -----
            ^
            i, j
 returns Some(A)
  • Call next().

The underlying iterator is advanced again. As a result, the cursor position also shifts to the next iterator position, which happens if the underlying iterator consumed an element where our cursor pointed at (that is if j < i).

// Show that the cursor still points at the second element.
let j = iterator.peek();
assert_eq!(j, Some(&&2));

// Consume the second element.
let i = iterator.next();
assert_eq!(i, Some(&2));

// Our cursor previously pointed at the element represented by B. Since that element has
// been consumed, the cursor shifts to the next unconsumed element: C.
let j = iterator.peek();
assert_eq!(j, Some(&&3));

-----     -----      -----     -----
| A |     | B |      | C | --> | D | --> None --> None --> ...
-----     -----      -----     -----
                       ^
                       i, j
          returns Some(B)
  • Consume more elements by calling next() until we reach None:
let i = iterator.next();
assert_eq!(i, Some(&3));

let j = iterator.peek();
assert_eq!(j, Some(&&4));

let i = iterator.next();
assert_eq!(i, Some(&4));

let j = iterator.peek();
assert_eq!(j, None);

let i = iterator.next();
assert_eq!(i, None);
source

pub fn peek_first(&mut self) -> Option<&I::Item>

Peeks at the first unconsumed element, regardless of where the cursor currently is.

source

pub fn peek_next(&mut self) -> Option<&I::Item>

Advance the cursor to the next element and return a reference to that value.

source

pub fn peek_previous(&mut self) -> Result<Option<&I::Item>, PeekMoreError>

Try to peek at a previous element. If no such element exists, an Err result containing a PeekMoreError::ElementHasBeenConsumed will be returned.

If a previous element does exist, an option wrapped in an Ok result will be returned.

source

pub fn peek_forward(&mut self, n: usize) -> Option<&I::Item>

Move the cursor n steps forward and peek at the element the cursor then points to.

source

pub fn peek_backward( &mut self, n: usize ) -> Result<Option<&I::Item>, PeekMoreError>

Move the cursor n steps backward and peek at the element the cursor then points to.

If there aren’t n elements prior to the element the cursor currently points at, a PeekMoreError::ElementHasBeenConsumed is returned instead. The cursor will then stay at the position it was prior to calling this method.

If you want to peek at the first unconsumed element instead of returning with an error, you can use the peek_backward_or_first method instead.

source

pub fn peek_backward_or_first(&mut self, n: usize) -> Option<&I::Item>

Move the cursor n steps backward and peek at the element the cursor then points to, or if there aren’t n elements prior to the element the cursor currently points to, peek at the first unconsumed element instead.

source

pub fn peek_nth(&mut self, n: usize) -> Option<&I::Item>

Peek at the nth element without moving the cursor.

source

pub fn advance_cursor(&mut self) -> &mut PeekMoreIterator<I>

Advance the cursor to the next peekable element.

This method does not advance the iterator itself. To advance the iterator, call next() instead.

A mutable reference to the iterator is returned, which allows the operation to be chained.

source

pub fn advance_cursor_by(&mut self, n: usize) -> &mut PeekMoreIterator<I>

Advance the cursor n elements forward.

This does not advance the iterator itself. To advance the iterator, call next() instead.

source

pub fn advance_cursor_while<P: Fn(Option<&I::Item>) -> bool>( &mut self, predicate: P ) -> &mut PeekMoreIterator<I>

Moves the cursor forward until the predicate is no longer true.

After this method returns, the cursor points to the first element that fails predicate. If no peeked elements pass predicate then the cursor will remain unchanged.

This does not advance the iterator itself. To advance the iterator, call next() instead.

source

pub fn move_cursor_back( &mut self ) -> Result<&mut PeekMoreIterator<I>, PeekMoreError>

Move the cursor to the previous peekable element. If such an element doesn’t exist, a PeekMoreError::ElementHasBeenConsumed will be returned.

If we can move to a previous element, a mutable reference to the iterator, wrapped in the Ok variant of Result will be returned.

source

pub fn move_cursor_back_by( &mut self, n: usize ) -> Result<&mut PeekMoreIterator<I>, PeekMoreError>

Move the cursor n elements backward. If there aren’t n unconsumed elements prior to the cursor, an error will be returned instead. In case of an error, the cursor will stay at the position it pointed at prior to calling this method.

If you want to reset the cursor to the first unconsumed element even if there aren’t n unconsumed elements before the cursor position, the move_backward_or_reset method can be used.

source

pub fn move_cursor_back_or_reset( &mut self, n: usize ) -> &mut PeekMoreIterator<I>

Move the cursor n elements backward, or reset its position to the first non-consumed element. The latter happens when the cursor position is smaller than the elements it has to move backwards by.

source

pub fn move_nth(&mut self, n: usize) -> &mut PeekMoreIterator<I>

Move the cursor to the n-th element of the queue.

source

pub fn reset_view(&mut self)

👎Deprecated

Deprecated: use reset_cursor instead.

source

pub fn reset_cursor(&mut self)

Reset the position of the cursor.

If peek is called just after a reset, it will return a reference to the first element.

source

pub fn cursor(&self) -> usize

Return the current cursor position. This is intended for use by code that more finely controls where the iterator resets to.

source

pub fn truncate_iterator_to_cursor(&mut self)

Remove all elements from the start of the iterator until reaching the same position as the cursor by calling Iterator::next().

After calling this method, iter.peek() == iter.next().as_ref().

 use peekmore::PeekMore;

 let iterable = [1, 2, 3, 4];
 let mut iter = iterable.iter().peekmore();

 iter.advance_cursor_by(2);
 assert_eq!(iter.peek(), Some(&&3));
 assert_eq!(iter.next(), Some(&1));
 iter.truncate_iterator_to_cursor();
 assert_eq!(iter.peek(), Some(&&3));
 assert_eq!(iter.next(), Some(&3));
source

pub fn peek_range(&mut self, start: usize, end: usize) -> &[Option<I::Item>]

Returns a view into the next start (inclusive) to end (exclusive) elements.

Note: start and end represent indices and start at 0. These indices always start at the beginning of the queue (the unconsumed iterator) and don’t take the position of the cursor into account.

Panics

Panics if start > end, in which case the range would be negative.

use peekmore::PeekMore;

let iterable = [1, 2, 3, 4];
let mut iter = iterable.iter().peekmore();

match iter.peek_range(1, 3) {
    [Some(2), Some(p)] => println!("Yay! we found number {} after number 2", p),
    _ => println!("Oh noes!"),
}
source

pub fn peek_amount(&mut self, n: usize) -> &[Option<I::Item>]

Returns a view into the next n unconsumed elements of the iterator.

Here, n represents the amount of elements as counted from the start of the unconsumed iterator.

For example, if we created a (peekmore) iterator from the array [1, 2, 3] and consume the first element by calling the regular Iterator::next method, and then call peek_amount(3), the iterator will return &[Some(2), Some(3), None]. Here Some(2) and Some(3) are queued elements which we can peek at, and are not consumed by the iterator yet. None is the last element returned by our view, since our original iterator is sized and doesn’t contain more elements. Thus in the absence of additional elements, we return None. This method is a variation on peek_range. You could instead have called peek_range(0, n) (note that peek_range takes indices as arguments instead of an amount).

Note: This method does not use or modify the position of the cursor.

Example:
use peekmore::PeekMore;

let iterable = [1, 2, 3];
let mut iter = iterable.iter().peekmore();

match iter.peek_amount(4) { // -> &[Option(&1), Option(&2), Option(&3), None]
  [Some(a), Some(b), Some(c), None] => println!("Found a match ({}, {}, {}) ", a, b, c),
  _ => eprintln!("Expected (just) 3 more values"),
}
source

pub fn next_if( &mut self, func: impl FnOnce(&I::Item) -> bool ) -> Option<I::Item>

Consumes and returns the next item of this iterator if a condition is true.

If func returns true for the next item of this iterator, consume and return it. Otherwise, return None.

Note: This function always uses the next item of the iterator and it is independent of the cursor location.

Example:

Consume items one-by-one.

use peekmore::PeekMore;

let mut iter = (1..5).peekmore();

assert_eq!(iter.next_if(|&x| x == 1), Some(1));

// next_eq does not care about the cursor position
let mut iter = iter.advance_cursor();
assert_eq!(iter.peek(), Some(&3));
assert_eq!(iter.next_if(|&x| x == 2), Some(2));

Consume a range of items.

use peekmore::PeekMore;

let mut iter = (1..15).peekmore();

while iter.next_if(|&x| x <= 10).is_some() {}
assert_eq!(iter.next(), Some(11));
source

pub fn next_if_eq<T>(&mut self, expected: &T) -> Option<I::Item>where T: ?Sized, I::Item: PartialEq<T>,

Consumes and returns the next item if it is equal to expected.

Uses next_eq underneath.

Trait Implementations§

source§

impl<I: Clone + Iterator> Clone for PeekMoreIterator<I>where I::Item: Clone,

source§

fn clone(&self) -> PeekMoreIterator<I>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<I: Debug + Iterator> Debug for PeekMoreIterator<I>where I::Item: Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<I: ExactSizeIterator> ExactSizeIterator for PeekMoreIterator<I>

Uses ExactSizeIterator default implementation.

1.0.0 · source§

fn len(&self) -> usize

Returns the exact remaining length of the iterator. Read more
source§

fn is_empty(&self) -> bool

🔬This is a nightly-only experimental API. (exact_size_is_empty)
Returns true if the iterator is empty. Read more
source§

impl<I: Iterator> Iterator for PeekMoreIterator<I>

§

type Item = <I as Iterator>::Item

The type of the elements being iterated over.
source§

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

Advances the iterator and returns the next value. Read more
source§

fn next_chunk<const N: usize>( &mut self ) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>where Self: Sized,

🔬This is a nightly-only experimental API. (iter_next_chunk)
Advances the iterator and returns an array containing the next N values. Read more
1.0.0 · source§

fn size_hint(&self) -> (usize, Option<usize>)

Returns the bounds on the remaining length of the iterator. Read more
1.0.0 · source§

fn count(self) -> usizewhere Self: Sized,

Consumes the iterator, counting the number of iterations and returning it. Read more
1.0.0 · source§

fn last(self) -> Option<Self::Item>where Self: Sized,

Consumes the iterator, returning the last element. Read more
source§

fn advance_by(&mut self, n: usize) -> Result<(), NonZeroUsize>

🔬This is a nightly-only experimental API. (iter_advance_by)
Advances the iterator by n elements. Read more
1.0.0 · source§

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

Returns the nth element of the iterator. Read more
1.28.0 · source§

fn step_by(self, step: usize) -> StepBy<Self>where Self: Sized,

Creates an iterator starting at the same point, but stepping by the given amount at each iteration. Read more
1.0.0 · source§

fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter>where Self: Sized, U: IntoIterator<Item = Self::Item>,

Takes two iterators and creates a new iterator over both in sequence. Read more
1.0.0 · source§

fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter>where Self: Sized, U: IntoIterator,

‘Zips up’ two iterators into a single iterator of pairs. Read more
source§

fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>where Self: Sized, G: FnMut() -> Self::Item,

🔬This is a nightly-only experimental API. (iter_intersperse)
Creates a new iterator which places an item generated by separator between adjacent items of the original iterator. Read more
1.0.0 · source§

fn map<B, F>(self, f: F) -> Map<Self, F>where Self: Sized, F: FnMut(Self::Item) -> B,

Takes a closure and creates an iterator which calls that closure on each element. Read more
1.21.0 · source§

fn for_each<F>(self, f: F)where Self: Sized, F: FnMut(Self::Item),

Calls a closure on each element of an iterator. Read more
1.0.0 · source§

fn filter<P>(self, predicate: P) -> Filter<Self, P>where Self: Sized, P: FnMut(&Self::Item) -> bool,

Creates an iterator which uses a closure to determine if an element should be yielded. Read more
1.0.0 · source§

fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F>where Self: Sized, F: FnMut(Self::Item) -> Option<B>,

Creates an iterator that both filters and maps. Read more
1.0.0 · source§

fn enumerate(self) -> Enumerate<Self>where Self: Sized,

Creates an iterator which gives the current iteration count as well as the next value. Read more
1.0.0 · source§

fn peekable(self) -> Peekable<Self>where Self: Sized,

Creates an iterator which can use the peek and peek_mut methods to look at the next element of the iterator without consuming it. See their documentation for more information. Read more
1.0.0 · source§

fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P>where Self: Sized, P: FnMut(&Self::Item) -> bool,

Creates an iterator that skips elements based on a predicate. Read more
1.0.0 · source§

fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P>where Self: Sized, P: FnMut(&Self::Item) -> bool,

Creates an iterator that yields elements based on a predicate. Read more
1.57.0 · source§

fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P>where Self: Sized, P: FnMut(Self::Item) -> Option<B>,

Creates an iterator that both yields elements based on a predicate and maps. Read more
1.0.0 · source§

fn skip(self, n: usize) -> Skip<Self>where Self: Sized,

Creates an iterator that skips the first n elements. Read more
1.0.0 · source§

fn take(self, n: usize) -> Take<Self>where Self: Sized,

Creates an iterator that yields the first n elements, or fewer if the underlying iterator ends sooner. Read more
1.0.0 · source§

fn scan<St, B, F>(self, initial_state: St, f: F) -> Scan<Self, St, F>where Self: Sized, F: FnMut(&mut St, Self::Item) -> Option<B>,

An iterator adapter which, like fold, holds internal state, but unlike fold, produces a new iterator. Read more
1.0.0 · source§

fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F>where Self: Sized, U: IntoIterator, F: FnMut(Self::Item) -> U,

Creates an iterator that works like map, but flattens nested structure. Read more
1.0.0 · source§

fn fuse(self) -> Fuse<Self>where Self: Sized,

Creates an iterator which ends after the first None. Read more
1.0.0 · source§

fn inspect<F>(self, f: F) -> Inspect<Self, F>where Self: Sized, F: FnMut(&Self::Item),

Does something with each element of an iterator, passing the value on. Read more
1.0.0 · source§

fn by_ref(&mut self) -> &mut Selfwhere Self: Sized,

Borrows an iterator, rather than consuming it. Read more
1.0.0 · source§

fn collect<B>(self) -> Bwhere B: FromIterator<Self::Item>, Self: Sized,

Transforms an iterator into a collection. Read more
source§

fn collect_into<E>(self, collection: &mut E) -> &mut Ewhere E: Extend<Self::Item>, Self: Sized,

🔬This is a nightly-only experimental API. (iter_collect_into)
Collects all the items from an iterator into a collection. Read more
1.0.0 · source§

fn partition<B, F>(self, f: F) -> (B, B)where Self: Sized, B: Default + Extend<Self::Item>, F: FnMut(&Self::Item) -> bool,

Consumes an iterator, creating two collections from it. Read more
source§

fn is_partitioned<P>(self, predicate: P) -> boolwhere Self: Sized, P: FnMut(Self::Item) -> bool,

🔬This is a nightly-only experimental API. (iter_is_partitioned)
Checks if the elements of this iterator are partitioned according to the given predicate, such that all those that return true precede all those that return false. Read more
1.27.0 · source§

fn try_fold<B, F, R>(&mut self, init: B, f: F) -> Rwhere Self: Sized, F: FnMut(B, Self::Item) -> R, R: Try<Output = B>,

An iterator method that applies a function as long as it returns successfully, producing a single, final value. Read more
1.27.0 · source§

fn try_for_each<F, R>(&mut self, f: F) -> Rwhere Self: Sized, F: FnMut(Self::Item) -> R, R: Try<Output = ()>,

An iterator method that applies a fallible function to each item in the iterator, stopping at the first error and returning that error. Read more
1.0.0 · source§

fn fold<B, F>(self, init: B, f: F) -> Bwhere Self: Sized, F: FnMut(B, Self::Item) -> B,

Folds every element into an accumulator by applying an operation, returning the final result. Read more
1.51.0 · source§

fn reduce<F>(self, f: F) -> Option<Self::Item>where Self: Sized, F: FnMut(Self::Item, Self::Item) -> Self::Item,

Reduces the elements to a single one, by repeatedly applying a reducing operation. Read more
source§

fn try_reduce<F, R>( &mut self, f: F ) -> <<R as Try>::Residual as Residual<Option<<R as Try>::Output>>>::TryTypewhere Self: Sized, F: FnMut(Self::Item, Self::Item) -> R, R: Try<Output = Self::Item>, <R as Try>::Residual: Residual<Option<Self::Item>>,

🔬This is a nightly-only experimental API. (iterator_try_reduce)
Reduces the elements to a single one by repeatedly applying a reducing operation. If the closure returns a failure, the failure is propagated back to the caller immediately. Read more
1.0.0 · source§

fn all<F>(&mut self, f: F) -> boolwhere Self: Sized, F: FnMut(Self::Item) -> bool,

Tests if every element of the iterator matches a predicate. Read more
1.0.0 · source§

fn any<F>(&mut self, f: F) -> boolwhere Self: Sized, F: FnMut(Self::Item) -> bool,

Tests if any element of the iterator matches a predicate. Read more
1.0.0 · source§

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

Searches for an element of an iterator that satisfies a predicate. Read more
1.30.0 · source§

fn find_map<B, F>(&mut self, f: F) -> Option<B>where Self: Sized, F: FnMut(Self::Item) -> Option<B>,

Applies function to the elements of iterator and returns the first non-none result. Read more
source§

fn try_find<F, R>( &mut self, f: F ) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryTypewhere Self: Sized, F: FnMut(&Self::Item) -> R, R: Try<Output = bool>, <R as Try>::Residual: Residual<Option<Self::Item>>,

🔬This is a nightly-only experimental API. (try_find)
Applies function to the elements of iterator and returns the first true result or the first error. Read more
1.0.0 · source§

fn position<P>(&mut self, predicate: P) -> Option<usize>where Self: Sized, P: FnMut(Self::Item) -> bool,

Searches for an element in an iterator, returning its index. Read more
1.6.0 · source§

fn max_by_key<B, F>(self, f: F) -> Option<Self::Item>where B: Ord, Self: Sized, F: FnMut(&Self::Item) -> B,

Returns the element that gives the maximum value from the specified function. Read more
1.15.0 · source§

fn max_by<F>(self, compare: F) -> Option<Self::Item>where Self: Sized, F: FnMut(&Self::Item, &Self::Item) -> Ordering,

Returns the element that gives the maximum value with respect to the specified comparison function. Read more
1.6.0 · source§

fn min_by_key<B, F>(self, f: F) -> Option<Self::Item>where B: Ord, Self: Sized, F: FnMut(&Self::Item) -> B,

Returns the element that gives the minimum value from the specified function. Read more
1.15.0 · source§

fn min_by<F>(self, compare: F) -> Option<Self::Item>where Self: Sized, F: FnMut(&Self::Item, &Self::Item) -> Ordering,

Returns the element that gives the minimum value with respect to the specified comparison function. Read more
1.0.0 · source§

fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB)where FromA: Default + Extend<A>, FromB: Default + Extend<B>, Self: Sized + Iterator<Item = (A, B)>,

Converts an iterator of pairs into a pair of containers. Read more
1.36.0 · source§

fn copied<'a, T>(self) -> Copied<Self>where T: 'a + Copy, Self: Sized + Iterator<Item = &'a T>,

Creates an iterator which copies all of its elements. Read more
1.0.0 · source§

fn cloned<'a, T>(self) -> Cloned<Self>where T: 'a + Clone, Self: Sized + Iterator<Item = &'a T>,

Creates an iterator which clones all of its elements. Read more
source§

fn array_chunks<const N: usize>(self) -> ArrayChunks<Self, N>where Self: Sized,

🔬This is a nightly-only experimental API. (iter_array_chunks)
Returns an iterator over N elements of the iterator at a time. Read more
1.11.0 · source§

fn sum<S>(self) -> Swhere Self: Sized, S: Sum<Self::Item>,

Sums the elements of an iterator. Read more
1.11.0 · source§

fn product<P>(self) -> Pwhere Self: Sized, P: Product<Self::Item>,

Iterates over the entire iterator, multiplying all the elements Read more
source§

fn cmp_by<I, F>(self, other: I, cmp: F) -> Orderingwhere Self: Sized, I: IntoIterator, F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Ordering,

🔬This is a nightly-only experimental API. (iter_order_by)
Lexicographically compares the elements of this Iterator with those of another with respect to the specified comparison function. Read more
1.5.0 · source§

fn partial_cmp<I>(self, other: I) -> Option<Ordering>where I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Lexicographically compares the PartialOrd elements of this Iterator with those of another. The comparison works like short-circuit evaluation, returning a result without comparing the remaining elements. As soon as an order can be determined, the evaluation stops and a result is returned. Read more
source§

fn partial_cmp_by<I, F>(self, other: I, partial_cmp: F) -> Option<Ordering>where Self: Sized, I: IntoIterator, F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Option<Ordering>,

🔬This is a nightly-only experimental API. (iter_order_by)
Lexicographically compares the elements of this Iterator with those of another with respect to the specified comparison function. Read more
1.5.0 · source§

fn eq<I>(self, other: I) -> boolwhere I: IntoIterator, Self::Item: PartialEq<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are equal to those of another. Read more
source§

fn eq_by<I, F>(self, other: I, eq: F) -> boolwhere Self: Sized, I: IntoIterator, F: FnMut(Self::Item, <I as IntoIterator>::Item) -> bool,

🔬This is a nightly-only experimental API. (iter_order_by)
Determines if the elements of this Iterator are equal to those of another with respect to the specified equality function. Read more
1.5.0 · source§

fn ne<I>(self, other: I) -> boolwhere I: IntoIterator, Self::Item: PartialEq<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are not equal to those of another. Read more
1.5.0 · source§

fn lt<I>(self, other: I) -> boolwhere I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are lexicographically less than those of another. Read more
1.5.0 · source§

fn le<I>(self, other: I) -> boolwhere I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are lexicographically less or equal to those of another. Read more
1.5.0 · source§

fn gt<I>(self, other: I) -> boolwhere I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are lexicographically greater than those of another. Read more
1.5.0 · source§

fn ge<I>(self, other: I) -> boolwhere I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are lexicographically greater than or equal to those of another. Read more
source§

fn is_sorted_by<F>(self, compare: F) -> boolwhere Self: Sized, F: FnMut(&Self::Item, &Self::Item) -> Option<Ordering>,

🔬This is a nightly-only experimental API. (is_sorted)
Checks if the elements of this iterator are sorted using the given comparator function. Read more
source§

fn is_sorted_by_key<F, K>(self, f: F) -> boolwhere Self: Sized, F: FnMut(Self::Item) -> K, K: PartialOrd<K>,

🔬This is a nightly-only experimental API. (is_sorted)
Checks if the elements of this iterator are sorted using the given key extraction function. Read more
source§

impl<I: FusedIterator> FusedIterator for PeekMoreIterator<I>

Uses FusedIterator default implementation.

Auto Trait Implementations§

§

impl<I> RefUnwindSafe for PeekMoreIterator<I>where I: RefUnwindSafe, <I as Iterator>::Item: RefUnwindSafe,

§

impl<I> Send for PeekMoreIterator<I>where I: Send, <I as Iterator>::Item: Send,

§

impl<I> Sync for PeekMoreIterator<I>where I: Sync, <I as Iterator>::Item: Sync,

§

impl<I> Unpin for PeekMoreIterator<I>where I: Unpin, <I as Iterator>::Item: Unpin,

§

impl<I> UnwindSafe for PeekMoreIterator<I>where I: UnwindSafe, <I as Iterator>::Item: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<I> IntoIterator for Iwhere I: Iterator,

§

type Item = <I as Iterator>::Item

The type of the elements being iterated over.
§

type IntoIter = I

Which kind of iterator are we turning this into?
const: unstable · source§

fn into_iter(self) -> I

Creates an iterator from a value. Read more
source§

impl<I> PeekMore for Iwhere I: Iterator,

source§

fn peekmore(self) -> PeekMoreIterator<I>

Create a multi-peek iterator where we can peek forward multiple times from an existing iterator.
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.