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

Package detail

stream-parser

TooTallNate2.1mMIT0.3.1

Generic interruptible "parser" mixin for Transform & Writable streams

readme

node-stream-parser

Generic interruptible "parser" mixin for Transform & Writable streams

Build Status

This module offers the stream-parser mixin, which provides an easy-to-use API for parsing bytes from Writable and/or Transform stream instances. This module is great for implementing streaming parsers for standardized file formats.

For Writable streams, the parser takes control over the _write callback function. For Transform streams, the parser controls the _transform callback function.

Installation

$ npm install stream-parser

Example

Let's create a quick Transform stream subclass that utilizes the parser's _bytes() and _passthrough() functions to parse a theoretical file format that has an 8-byte header we want to parse, and then pass through the rest of the data.

var Parser = require('stream-parser');
var inherits = require('util').inherits;
var Transform = require('stream').Transform;

// create a Transform stream subclass
function MyParser () {
  Transform.call(this);

  // buffer the first 8 bytes written
  this._bytes(8, this.onheader);
}
inherits(MyParser, Transform);

// mixin stream-parser into MyParser's `prototype`
Parser(MyParser.prototype);

// invoked when the first 8 bytes have been received
MyParser.prototype.onheader = function (buffer, output) {
  // parse the "buffer" into a useful "header" object
  var header = {};
  header.type = buffer.readUInt32LE(0);
  header.name = buffer.toString('utf8', 4);
  this.emit('header', header);

  // it's usually a good idea to queue the next "piece" within the callback
  this._passthrough(Infinity);
};


// now we can *use* it!
var parser = new MyParser();
parser.on('header', function (header) {
  console.error('got "header"', header);
});
process.stdin.pipe(parser).pipe(process.stdout);

Here's an example of manually creating a Transform stream and turning it into a "pass through" stream equivalent to the one built into node core:

var Parser = require('stream-parser');
var Transform = require('stream').Transform;

// create a Transform instance and extend it with "stream-parser"
var p = new Transform();
Parser(p);

// pass through `Infinity` bytes... forever...
p._passthrough(Infinity);

// now `p` is equivalent to a stream.PassThrough instance
process.stdin.pipe(p).pipe(process.stdout);

See the test directory for some more example code in the test cases.

A list of known concrete implementations is here (send pull requests for more!):

API

Parser()

The Parser stream mixin works with either Writable or Transform stream instances/subclasses. Provides a convenient generic "parsing" API:

_bytes(n, cb) - buffers "n" bytes and then calls "cb" with the "chunk"
_skipBytes(n, cb) - skips "n" bytes and then calls "cb" when done

If you extend a Transform stream, then the _passthrough() function is also added:

_passthrough(n, cb) - passes through "n" bytes untouched and then calls "cb"

._bytes(n, cb)

Buffers n bytes and then invokes cb once that amount has been collected.

._skipBytes(n, cb)

Skips over the next n bytes and then invokes cb once that amount has been discarded.

._passthrough(n, cb)

Passes through n bytes to the readable side of this stream untouched, then invokes cb once that amount has been passed through. This function is only defined when stream-parser is extending a Transform stream.

changelog

0.3.1 / 2015-06-04

  • package: allow any "debug" v2

0.3.0 / 2014-06-22

  • add a _skipBytes() function
  • History: fix changelog output

0.2.0 / 2014-06-21

  • index: emit an "error" event when data is written with no parsing function is in place
  • package: fix "main" field
  • rename "lib/parser.js" to "index.js"
  • README: use svg for Travis badge

0.1.2 / 2014-06-16

  • parser: use %o debug v1 formatting

0.1.1 / 2014-06-16

  • package: pin "readable-stream" to v1.0
  • package: update "debug" to v1.0.0
  • travis: test node v0.11
  • travis: don't test node v0.9

0.1.0 / 2013-06-04

  • travis: test node v0.10
  • test: add test case from #3
  • parser: add jsdocs for the process() function
  • parser: use a thunk-based "trampoline" technique to prevent stack overflows on synchronous parsers (fixes #3)

0.0.5 / 2013-03-06

  • Update for node v0.9.12 streams2 API Writable/Transform API changes

0.0.4 / 2013-02-23

  • Don't allow _bytes(0)
  • Fix tests on node v0.8.x

0.0.3 / 2013-02-10

  • Allow _passthrough(Infinity)
  • Add MIT license file

0.0.2 / 2013-02-08

  • Add support for asynchronous callback functions

0.0.1 / 2013-02-05

  • Initial release