iter-chunks
iter-chunks extends the standard Iterator trait with a chunks method that yields lending iterators without resorting to interior mutability.
Please read the API documentation on docs.rs for details.
Usage
Add this to your Cargo.toml:
[]
= "0.3"
Examples
Chunks implements a lending iterator, so iteration currently happens via a while let loop.
use IterChunks;
let arr = ;
let expected = ;
let mut chunks = arr.into_iter.chunks;
let mut i = 0;
while let Some = chunks.next
Why create this crate?
itertools provides many awesome extensions, including chunks. It is very handy, but it uses RefCell internally, so the resulting iterator is not Send.
It's a very common usecase in async context, which requires Chunks to be Send:
async
This crate implements chunks without RefCell, so Chunks is both Send and Sync. As a trade-off, Chunks cannot currently implement Iterator because the standard library still lacks a lending iterator abstraction, even though GAT is now stable.
Future works
The lack of the Iterator implementation is inconvenient, and the best solution is to wait for a stable lending iterator trait (either in std or via crates such as lending-iterator). In the short term we can provide more helper adaptors such as nth, for_each, try_for_each, and so on.
Contributions are welcome.
License
Licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.