Skip to content
/ it-pipe Public
forked from alanshaw/it-pipe

🚇 Utility to "pipe" async iterables together

License

Notifications You must be signed in to change notification settings

mikeal/it-pipe

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

it-pipe

Build Status dependencies Status JavaScript Style Guide

Utility to "pipe" async iterables together

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.

Install

npm i it-pipe

Usage

const pipe = require('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).

Contribute

Feel free to dive in! Open an issue or submit PRs.

License

MIT © Alan Shaw

About

🚇 Utility to "pipe" async iterables together

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%