Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

it-pipe

alanshaw179.8kApache-2.0 OR MIT3.0.1TypeScript support: included

Utility to "pipe" async iterables together

async, await, iterable, iterator, pipe, pipeline, pull, pump, stream

readme

it-pipe

codecov CI

Utility to "pipe" async iterables together

Table of contents

Install

$ npm i it-pipe

Browser <script> tag

Loading this module through a script tag will make it's exports available as ItPipe in the global namespace.

<script src="https://unpkg.com/it-pipe/dist/index.min.js"></script>

Based on this definition of streaming iterables https://gist.github.com/alanshaw/591dc7dd54e4f99338a347ef568d6ee9.

Almost identical to the pipeline function from the streaming-iterables module except that it supports duplex streams and will automatically wrap a "source" as the first param in a function.

Usage

import { pipe } from 'it-pipe'

const result = await pipe(
  // A source is just an iterable, this is shorthand for () => [1, 2, 3]
  [1, 2, 3],
  // A transform takes a source, and returns a source.
  // This transform doubles each value asynchronously.
  function transform (source) {
    return (async function * () { // A generator is async iterable
      for await (const val of source) yield val * 2
    })()
  },
  // A sink, it takes a source and consumes it, optionally returning a value.
  // This sink buffers up all the values from the source and returns them.
  async function collect (source) {
    const vals = []
    for await (const val of source) {
      vals.push(val)
    }
    return vals
  }
)

console.log(result) // 2,4,6

API

pipe(firstFn, ...fns)

Calls firstFn and then every function in fns with the result of the previous function. The final return is the result of the last function in fns.

Note:

  • firstFn may be a Function or an Iterable
  • firstFn or any of fns may be a duplex object (an object with a sink and source).

API Docs

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

changelog

3.0.1 (2023-04-04)

Bug Fixes

  • reuse types from it-stream-types to simplify (#68) (9fa98e1)

3.0.0 (2023-03-31)

⚠ BREAKING CHANGES

  • when the entire pipeline is synchronous, the return value will now be synchronous

Bug Fixes

  • do not create unnecessary async work (#66) (e583174)

2.0.5 (2022-12-06)

Dependencies

  • bump it-merge from 1.0.4 to 2.0.0 (#46) (d434924)
  • dev: bump it-all from 1.0.6 to 2.0.0 (#45) (ca67cc5)
  • dev: bump it-drain from 1.0.5 to 2.0.0 (#47) (3e4da1c)

2.0.4 (2022-08-06)

Bug Fixes

Trivial Changes

Dependencies

2.0.3 (2022-01-15)

Bug Fixes

2.0.2 (2022-01-13)

Bug Fixes

  • propagate duplex transform sink errors (#8) (89df9be)

2.0.1 (2022-01-13)

Trivial Changes

2.0.0 (2022-01-12)

⚠ BREAKING CHANGES

  • !: switch to named exports, ESM only

Features