新增: - backend/venv/ - Python 虚拟环境 - backend/start.sh - 启动脚本(使用虚拟环境) - backend/requirements.txt - 依赖列表 - .gitignore - 忽略虚拟环境和缓存文件 说明: - 每个项目使用独立虚拟环境 - 避免依赖冲突 - 启动脚本自动创建和激活虚拟环境
38 lines
1.2 KiB
JavaScript
38 lines
1.2 KiB
JavaScript
'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, { ...options, ndjson: false })
|
|
.then(data => callback(null, data))
|
|
.catch(error => callback(error))
|
|
|
|
return jsonstream
|
|
}
|