buffered-spawn

Buffered child process#spawn.

MIT 21 个版本
安装
npm install buffered-spawn
yarn add buffered-spawn
pnpm add buffered-spawn
bun add buffered-spawn
README

buffered-spawn

NPM version Downloads Build Status Dependency status Dev Dependency status

Buffered child_process#spawn.

Installation

$ npm install buffered-spawn

Why

  • Easy to use
  • Uses cross-spawn by default, which fixes windows issues
  • Supports callback & promise style

Usage

In terms of arguments, they are equal to node's spawn.

const bufferedSpawn = require('buffered-spawn');

// Callback style
bufferedSpawn('git', ['clone', 'git@github.com/bower/bower'], { cwd: '.' }, (err, stdout, stderr) => {
    if (err) {
        // Both stdout and stderr are also set on the error object
        return console.error(`Command failed with error code of #${err.status}`);
    }

    console.log(stdout);
    console.log(stderr);
});

// ...or Promise style
bufferedSpawn('git', ['clone', 'git@github.com/bower/bower'], { cwd: '.' })
.then((output) => {
    console.log(output.stdout);
    console.log(output.stderr);
}, (err) => {
    // Both stdout and stderr are also set on the error object
    console.error(`Command failed with error code of #${err.status}`);
});

The actual child process is available if necessary:

const buffspawn('buffered-spawn');

// Callback style
const cp = buffspawn('git', ['clone', 'git@github.com/bower/bower'], () => {}};

// ...or Promise style
const promise = buffspawn('git', ['clone', 'git@github.com/bower/bower']);
const cp = promise.cp;

As said before, buffered-spawn uses cross-spawn to actually spawn the process. If you are having trouble running Windows such as wmic which has its own arguments parser, you may disable like so:

const cp = buffspawn('wmic', [
    'logicaldisk', 'where', 'DeviceID="Z:"',
    'get' 'freeSpace,size'
], { crossSpawn: false }, () => {}};

Tests

$ npm test

License

Released under the MIT License.

版本列表
3.3.2 2016-09-14
3.3.1 2016-09-14
3.3.0 2016-09-14
3.2.0 2016-04-13
3.1.0 2016-04-06
3.0.0 2016-02-20
2.0.4 2016-02-10
2.0.2 2016-01-03
2.0.1 2016-01-02
2.0.0 2016-01-02
1.1.2 2015-07-11
1.1.1 2015-06-22
1.1.0 2015-03-23
1.0.1 2015-02-08
1.0.0 2014-08-14
0.2.2 2014-07-09
0.2.1 2014-06-30
0.2.0 2014-06-30
0.1.2 2014-06-30
0.1.1 2014-06-30
0.1.0 2014-06-30