through2-filter

WebJar for through2-filter

License

License

MIT
Categories

Categories

H2 Data Databases
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

through2-filter
Last Version

Last Version

3.0.0
Release Date

Release Date

Type

Type

jar
Description

Description

through2-filter
WebJar for through2-filter
Project URL

Project URL

http://webjars.org
Source Code Management

Source Code Management

https://github.com/brycebaril/through2-filter

Download through2-filter

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/through2-filter/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>through2-filter</artifactId>
    <version>3.0.0</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/through2-filter/
implementation 'org.webjars.npm:through2-filter:3.0.0'
// https://jarcasting.com/artifacts/org.webjars.npm/through2-filter/
implementation ("org.webjars.npm:through2-filter:3.0.0")
'org.webjars.npm:through2-filter:jar:3.0.0'
<dependency org="org.webjars.npm" name="through2-filter" rev="3.0.0">
  <artifact name="through2-filter" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='through2-filter', version='3.0.0')
)
libraryDependencies += "org.webjars.npm" % "through2-filter" % "3.0.0"
[org.webjars.npm/through2-filter "3.0.0"]

Dependencies

compile (2)

Group / Artifact Type Version
org.webjars.npm : through2 jar [2.0.0,2.1)
org.webjars.npm : xtend jar [4.0.0,4.1)

Project Modules

There are no modules declared in this project.

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

Versions

Version
3.0.0
2.0.0
1.4.0