gossamer/iterator

Types

pub type Iterator(a, return, next)

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 for(
  in iterator: Iterator(a, return, next),
  run fun: fn(a) -> any,
) -> Nil
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)
Search Document