#iterator #next #peekable #peek #extension #element #advancing

peekable_next

An extension for Rust iterators to peek at the next element without advancing

4 releases

0.2.0 Aug 2, 2023
0.1.2 Aug 1, 2023
0.1.1 Aug 1, 2023
0.1.0 Aug 1, 2023

#2574 in Rust patterns

GPL-3.0 license

16KB
131 lines

peekable_next

Crates.io Docs.rs License: GPL-3.0

The peekable_next crate provides an extension for Rust iterators, introducing the PeekableNext struct and associated traits. This extension allows users to peek at the next element of an iterator without advancing it, which can be valuable in various scenarios where you need to inspect upcoming values before making further decisions.

Usage

Add this crate to your Cargo.toml:

[dependencies]
peekable_next = "0.2.0"

Import the `PeekNext` trait into your code:
```rust
 use peekable_next::PeekNext;

Basic Example

let data = vec![1, 2, 3];
let mut iter = data.iter().peekable_next();

// Peeking allows us to see the next value without advancing the iterator
assert_eq!(iter.peek(), Some(&&1));
assert_eq!(iter.peek_next(), Some(&&2));
assert_eq!(iter.next(), Some(&1)); // Advances to the next element (2)

assert_eq!(iter.peek(), Some(&&2));
assert_eq!(iter.next(), Some(&2)); // Advances to the next element (3)

// After the iterator is finished, peek returns None
assert_eq!(iter.peek(), Some(&&3));
assert_eq!(iter.next(), Some(&2));

Documentation

No runtime deps