3 releases
0.1.2 | Jun 14, 2022 |
---|---|
0.1.1 | Jun 14, 2022 |
0.1.0 | Jun 14, 2022 |
#2339 in Algorithms
8KB
127 lines
EzIter
Iterators made easy
Usage
Add this line into your Cargo.toml
eziter = "0.1"
and add a use statement at the top of every module using EzIter
use eziter::*;
What is this ?
This crate contains some conveniance wrappers around rust's iterators and std collections.
Theses are essentially useful in the rare cases where you only want to use a single map or
filter on your iterator without the syntactic burden of unrolling a full x.iter().map(f).collect();
.
You can instead write a more appeiling x.map(f);
Only a handful of methods are actually implemented, more might come in the future:
x.map(f);
x.filter(f);
x.filter_map(f);
x.skip_while(f);
x.take_while(f);
x.map_while(f);
Each of theses come in 3 flavors, here an example with map
x.into_map(f);
x.map(f);
x.map_mut(f);
That corresponds to
x.into_iter().map(f).collect();
x.iter().map(f).collect();
x.iter_mut().map(f).collect();
You can use theses wrappers out of the box with the standard collections
HashMap<K, V>
BTreeMap<K, V>
HashSet<K>
BTreeSet<K>
BinaryHeap<T>
LinkedList<T>
Vec<T>
VecDeque<T>
but note that the *_mut()
variations are not available for
HashSet<K>
BTreeSet<K>
BinaryHeap<T>
You also gain usage of all into_*()
wrappers for every implementors of IntoIterator
Example
use eziter::*;
fn main() {
let v = vec![1, 2, 3];
let _res: Vec<_> = v.map(|x| x + 3);
}
Caveats
Please note that theses wrappers don't come for free.
No chainable calls
First, you will lose the ability to chain theses calls together.
I mean, you could chain them, but they would all individually call the .collect()
method,
leaving you with an increasing waste of resources as the chain grows.
The rust's Iterators are the way to go in that case, obviously.
Extra Box<>
allocation
In order for the implementation to hold, only the into_*()
wrappers come really free of charge,
the others produced iterators are wrapped around a Box<dyn Iterator>
. If you don't mind the extra
allocation/deallocation, you are fine.
This might change in the future when rust will allow to return impl
s from trait implementation.