/thenable-generator

Create generators implemented the PromiseLike interface so that they can be awaited in async contexts.

Primary LanguageTypeScriptMIT LicenseMIT

Thenable Generator

Create generators implemented the PromiseLike interface so that they can be awaited in async contexts.

This module is meant to pack any function to a ThenableGeneratorFunction, so that it can be used in both async functions and for (await)...of... loops. Depends on the statement, the generator returns/yields different values.

Example

import { create } from "thenable-generator";
// Or in Deno
import { create } from "https://deno.land/x/thenable_generator/index.ts";

var normalFn = create(() => {
    return "Hello, World!";
});

var asyncFn = create(async () => {
    return "Hello, World!";
});

var genFn = create(function* () {
    yield "Hello";
    yield "World";
    return "Hello, World!";
});

var asyncGenFn = create(async function* () {
    yield "Hello";
    yield "World";
    return "Hello, World!";
});

(async () => {
    // Hello, World
    console.log(await normalFn());
    console.log(await asyncFn());
    console.log(await genFn());
    console.log(await asyncGenFn());

    // Hello
    // World
    let iter = genFn();
    for (let item of iter) {
        console.log(item);
    }

    console.log(await iter); // Hello, World!

    // Hello
    // World
    let asyncIter = asyncGenFn();
    for await (let item of asyncIter) {
        console.log(item);
    }

    console.log(await asyncIter); // Hello, World!
})();

Tip

After the iterator has been traveled in a for (await)...of... loop, using await can reach the returning value of the generator, however, if await is called before the for (await)...of... loop, that will cause the generator to close early and the for block will never be executed.

For full API, please checkout the source file.