GitXplorerGitXplorer
b

through2-filter

public
35 stars
4 forks
1 issues

Commits

List of commits on branch master.
Unverified
65814130b1051b92543f53b7354405fc1684d3c4

Merge branch 'shinnn-bump-deps'

bbrycebaril committed 10 years ago
Unverified
528fb8942eac6d71ede5f77c1988a5a0ebf2d634

Bump through2 and tape

sshinnn committed 10 years ago
Unverified
1c45deaa4e9f4612e97ed7b27ec6d8cf659acb97

1.4.1

bbrycebaril committed 10 years ago
Unverified
0e49319ca49d170a3777c1b15799c79ee50c0c5f

Merge branch 'shinnn-deps'

bbrycebaril committed 10 years ago
Unverified
207fc44cf631b0d62a650b0c426749da49338ee2

Use SVG badges instead of PNG badges

sshinnn committed 10 years ago
Unverified
463e13a8e37dbf3106d72e5bbda194737755b719

Update package settings

sshinnn committed 10 years ago

README

The README file for this repository.

through2-filter

NPM

This is a super thin wrapper around through2 that works like Array.prototype.filter but for streams.

For when through2 is just too verbose 😉

Note you will NOT be able to alter the content of the chunks. This is intended for filtering only. If you want to modify the stream content, use either through2 or through2-map.

var filter = require("through2-filter")

var skip = filter(function (chunk) {
  // skip buffers longer than 100
  return chunk.length < 100
})

// vs. with through2:
var skip = through2(function (chunk, encoding, callback) {
  // skip buffers longer than 100
  if (chunk.length < 100) this.push(chunk)
  return callback()
})

// Then use your filter:
source.pipe(skip).pipe(sink)

// Additionally accepts `wantStrings` argument to conver buffers into strings
var alphanum = new RegExp("^[A-Za-z0-1]+$")
var scrub = filter({wantStrings: true}, function (str) {
  return alphanum.exec(str)
})

// Works like `Array.prototype.filter` meaning you can specify a function that
// takes up to two* arguments: fn(element, index)
var skip10 = filter(function (element, index) {
  return index > 10
})

*Differences from Array.prototype.filter:

  • No third array callback argument. That would require realizing the entire stream, which is generally counter-productive to stream operations.
  • Array.prototype.filter doesn't modify the source Array, which is somewhat nonsensical when applied to streams.

API

require("through2-filter")([options], fn)

Create a through2-filter instance that will call fn(chunk). If fn(chunk) returns "true" the chunk will be passed downstream. Otherwise it will be dropped.

require("through2-filter").ctor([options], fn)

Create a through2-filter Type that can be instantiated via new Type() or Type() to create reusable spies.

require("through2-filter").obj([options], fn)

Create a through2-filter that defaults to objectMode = true.

require("through2-filter").objCtor([options], fn)

Create a through2-filter Type that defaults to objectMode = true.

Options

  • wantStrings: Automatically call chunk.toString() for the super lazy.
  • all other through2 options

LICENSE

MIT