gossamer/iterator
Types
Values
pub fn drop(
from iterator: Iterator(a, return, next),
up_to count: Int,
) -> Iterator(a, Nil, Nil)
Returns a new iterator that skips the first count values from the source
iterator, then yields the rest.
pub fn every(
in iterator: Iterator(a, return, next),
satisfying predicate: fn(a) -> Bool,
) -> Bool
Consumes the iterator and returns True if the predicate returns True
for every value. Short-circuits on the first non-match.
pub fn filter(
in iterator: Iterator(a, return, next),
keeping predicate: fn(a) -> Bool,
) -> Iterator(a, Nil, Nil)
Returns a new iterator that yields only the values from the source iterator
for which the predicate returns True.
pub fn find(
in iterator: Iterator(a, return, next),
one_that predicate: fn(a) -> Bool,
) -> Result(a, Nil)
Consumes the iterator and returns the first value for which the predicate
returns True. Returns an error if no value matches.
pub fn flat_map(
over iterator: Iterator(a, return, next),
with callback: fn(a) -> Iterator(b, Nil, Nil),
) -> Iterator(b, Nil, Nil)
Returns a new iterator that applies the callback to each value from the source iterator and yields all values from the resulting iterators.
pub fn from_list(list: List(a)) -> Iterator(a, Nil, Nil)
Creates an iterator from a Gleam list.
pub fn map(
over iterator: Iterator(a, return, next),
with callback: fn(a) -> b,
) -> Iterator(b, Nil, Nil)
Returns a new iterator that yields the results of applying the callback to each value from the source iterator.
pub fn new(
next: fn(option.Option(next)) -> iterator_result.IteratorResult(
a,
return,
),
) -> Iterator(a, return, next)
pub fn next(
iterator: Iterator(a, return, next),
) -> iterator_result.IteratorResult(a, return)
pub fn next_with(
iterator: Iterator(a, return, next),
value: next,
) -> iterator_result.IteratorResult(a, return)
pub fn reduce(
over iterator: Iterator(a, return, next),
from initial: b,
with callback: fn(b, a) -> b,
) -> b
Consumes the iterator, calling the reducer with each value and an accumulator. Returns the final accumulator value.
pub fn return(
iterator: Iterator(a, return, next),
) -> Result(iterator_result.IteratorResult(a, return), Nil)
pub fn return_with(
iterator: Iterator(a, return, next),
value: return,
) -> Result(iterator_result.IteratorResult(a, return), Nil)
pub fn some(
in iterator: Iterator(a, return, next),
satisfying predicate: fn(a) -> Bool,
) -> Bool
Consumes the iterator and returns True if the predicate returns True
for any value. Short-circuits on the first match.
pub fn take(
from iterator: Iterator(a, return, next),
up_to limit: Int,
) -> Iterator(a, Nil, Nil)
Returns a new iterator that yields at most limit values from the source
iterator.
pub fn throw(
iterator: Iterator(a, return, next),
reason reason: e,
) -> Result(iterator_result.IteratorResult(a, return), Nil)
pub fn to_list(iterator: Iterator(a, return, next)) -> List(a)
Collects all values from an iterator into a list. Consumes the iterator.
pub fn with_return(
iterator: Iterator(a, return, next),
return: fn(option.Option(return)) -> iterator_result.IteratorResult(
a,
return,
),
) -> Iterator(a, return, next)
pub fn with_throw(
iterator: Iterator(a, return, next),
throw: fn(e) -> iterator_result.IteratorResult(a, return),
) -> Iterator(a, return, next)