🤸♀️ More iterator adaptors.
This crate provides some useful iterator adaptors and functions. Unlike
itertools this crate provides a separate
extension trait for each adaptor. Additionally, each type of adaptor is
feature flagged so you only have to compile the features you need.
Add the crate to Cargo manifest.
cargo add itermore --features fullAnd bring the extension traits into scope.
use itermore::prelude::*;Now you can use extension methods like array_windows on any iterator.
for [a, b, c] in iter.array_windows() {
    println!("{} {} {}", a, b, c)
}
// Outputs
//    1 2 3
//    2 3 4
//    3 4 5It is recommended to only enable the features that you need. For example if
you only want the array_combinations adaptor you would add the following
to your Cargo manifest.
[dependencies]
itermore = { version = "*", features = ["array_combinations"]}- collect_array: Collects an iterator into an array.
- min_maxand friends: Returns the minimum and maximum element of an iterator.
- next_chunk: Returns the next- Nelements of the iterator as an array.
- sortedand friends: Returns a new iterator with all elements sorted.
- array_chunksreturns an iterator over- Nelements of the iterator at a time.
- array_windowsreturns an iterator over all contiguous windows of length- N.
- array_combinationsreturns an iterator over- Klength combinations of all the elements in the underlying iterator.
- array_combinations_with_repsreturns an iterator over- Klength combinations with repetitions/replacements of all the elements in the underlying iterator.
- cartesian_productreturns an iterator over the cartesian product of the element sets of two iterators.
- circular_array_windowsreturns an iterator over all contiguous windows of length- Nthat wraps around at the end.
- combinationsreturns an iterator over- klength combinations of all the elements in the underlying iterator.
- combinations_with_repsreturns an iterator over- klength combinations with repetitions/replacements of all the elements in the underlying iterator.
This project is distributed under the terms of both the MIT license and the Apache License (Version 2.0).
See LICENSE-APACHE and LICENSE-MIT for details.