☯️ Transforms to parse and stringify ndjson.
This module also works in the browser using a naive
stream
shim for small Browserify bundles.
To stringify an object stream into ndjson:
const StringifyTransform = require('@studio/ndjson/stringify');
object_stream.pipe(new StringifyTransform()).pipe(process.stdout);
To parse ndjson into an object stream:
const ParseTransform = require('@studio/ndjson/parse');
process.stdin.pipe(new ParseTransform()).pipe(object_stream);
❯ npm i @studio/ndjson
Require the transform you need:
@studio/ndjson/stringify
: Exports theStringifyTransform
class which reads objects and writes strings.@studio/ndjson/parse
: Exports theParseTransform
class which reads strings and writes objects.
The module main exports StringifyTransform
and ParseTransform
if you need
both:
const { StringifyTransform, ParseTransform } = require('@studio/ndjson');
The ParseTransform
constructor accepts an options
object with these
properties:
loose
: Whether to ignore data before the first{
in each line.loose_out
: A stream to receive data that was found before the first{
in each line. Impliesloose
.
If JSON.parse
or JSON.stringify
throw an error, the transform emits an
error
event with the error object having a code
property with
ERR_JSON_PARSE
or ERR_JSON_STRINGIFY
. For parse errors, the line
property
on the error is the string that could not be parsed.
- 👻 Studio Log: This module was refactored out of the logger for JavaScript Studio.
- 💧 Studio Browser Stream is a naive
stream
shim for small Browserify bundles. - 📦 Studio Changes is used to create the changelog for this module.
MIT