Blame view

node_modules/bfj-node4/src/unpipe.js 1.18 KB
aaac7fed   liuqimichale   add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
  'use strict'
  
  const stream = require('stream')
  const check = require('check-types')
  const parse = require('./parse')
  
  module.exports = unpipe
  
  /**
   * Public function `unpipe`.
   *
   * Returns a writeable stream that can be passed to stream.pipe, then parses JSON
   * data read from the stream. If there are no errors, the callback is invoked with
   * the result as the second argument. If errors occur, the first error is passed to
   * the callback as the first argument.
   *
   * @param callback:   Function that will be called after parsing is complete.
   *
   * @option reviver:   Transformation function, invoked depth-first.
   *
   * @option discard:   The number of characters to process before discarding them
   *                    to save memory. The default value is `1048576`.
   *
   * @option yieldRate: The number of data items to process per timeslice,
   *                    default is 16384.
   **/
  function unpipe (callback, options) {
    check.assert.function(callback, 'Invalid callback argument')
  
    const jsonstream = new stream.PassThrough()
  
    parse(jsonstream, Object.assign({}, options, { ndjson: false }))
      .then(data => callback(null, data))
      .catch(error => callback(error))
  
    return jsonstream
  }