AsyncIterator

Bindings to async iterators, a way to do async iteration in JavaScript.

See async iterator protocols on MDN.

done

RESCRIPT
let done: (~finalValue: 'value=?) => value<'value>

done(~finalValue=?)

Shorthand for creating a value object with the done property set to true, and the provided value as the final value, if any.

Examples

RESCRIPT
let context = ref(0) let asyncIterator = AsyncIterator.make(async () => { let currentValue = context.contents // Increment current value context := currentValue + 1 if currentValue >= 3 { AsyncIterator.done() } else { AsyncIterator.value(currentValue) } })

forEach

RESCRIPT
let forEach: (t<'a>, option<'a> => unit) => promise<unit>

forEach(iterator, fn) consumes all values in the async iterator and runs the callback fn for each value.

See iterator protocols on MDN.

Examples

RESCRIPT
// Let's pretend we get an async iterator returning ints from somewhere. let asyncIterator: AsyncIterator.t<(string, string)> = %raw(` (() => { var map1 = new Map(); map1.set('first', '1'); map1.set('second', '2'); var iterator1 = map1[Symbol.iterator](); return iterator1; })() `) let main = async () => await asyncIterator->AsyncIterator.forEach(v => { switch v { | Some(("second", value)) => value == "2" | _ => () } }) main()->ignore

ignore

RESCRIPT
let ignore: t<'a> => unit

ignore(iterator) ignores the provided async iterator and returns unit.

This helper is useful when you want to discard a value (for example, the result of an operation with side effects) without having to store or process it further.

make

RESCRIPT
let make: (unit => promise<value<'value>>) => t<'value>

make(nextFn)

Creates an async iterator from a function that returns the next value of the iterator.

Examples

  • A simple example, creating an async iterator that returns 1, 2, 3:

RESCRIPT
let context = ref(0) let asyncIterator = AsyncIterator.make(async () => { let currentValue = context.contents // Increment current value context := currentValue + 1 { AsyncIterator.value: Some(currentValue), done: currentValue >= 3, } }) // This will log 1, 2, 3 let main = async () => await asyncIterator->AsyncIterator.forEach(value => switch value { | Some(value) => Console.log(value) | None => () } ) main()->ignore

next

RESCRIPT
let next: t<'a> => promise<value<'a>>

next(asyncIterator)

Returns the next value of the iterator, if any.

See async iterator protocols on MDN.

Examples

  • A simple example, getting the next value:

RESCRIPT
let asyncIterator: AsyncIterator.t<(string, string)> = %raw(` (() => { var map1 = new Map(); map1.set('first', '1'); map1.set('second', '2'); var iterator1 = map1[Symbol.iterator](); return iterator1; })() `) let processMyAsyncIterator = async () => { // ReScript doesn't have `for ... of` loops, but it's easy to mimic using a while loop. let break = ref(false) while !break.contents { // Await the next iterator value let {value, done} = await asyncIterator->AsyncIterator.next // Exit the while loop if the iterator says it's done break := done if done { value->Option.isNone == true } } } processMyAsyncIterator()->ignore

t

RESCRIPT
type t<'a>

The type representing an async iterator.

value

RESCRIPT
type value<'a> = {done: bool, value: option<'a>}

value

RESCRIPT
let value: 'value => value<'value>

value(value)

Shorthand for creating a value object with the provided value, and the done property set to false.

Examples

RESCRIPT
let context = ref(0) let asyncIterator = AsyncIterator.make(async () => { let currentValue = context.contents // Increment current value context := currentValue + 1 if currentValue >= 3 { AsyncIterator.done() } else { AsyncIterator.value(currentValue) } })