Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/futagoza/node-child-process

A custom async-focused variant of Node's built-in child-process module.
https://github.com/futagoza/node-child-process

Last synced: 12 days ago
JSON representation

A custom async-focused variant of Node's built-in child-process module.

Awesome Lists containing this project

README

        

[![release](https://img.shields.io/npm/v/@futagoza/child-process.svg)](https://www.npmjs.com/package/@futagoza/child-process)
[![History](https://img.shields.io/badge/%40futagoza%2Fchild--process-changelog-yellow)](https://github.com/futagoza/node-child-process/blob/master/CHANGELOG.md)
[![license](https://img.shields.io/badge/license-mit-blue.svg)](https://opensource.org/licenses/MIT)

> This library is developed for use with Node 10+ and may (or may not) work with versions of Node lower then this.

A custom async-focused variant of Node's built-in child-process module, based exclusively around `child_process.spawn()`

All the spawning methods accept the same arguments as `child_process.spawn()`, but in any order.

If an array argument isn't provided, it will try `options.args` or `options.argv`; failing that, the string argument (or `options.command` or `options.file`) will be split (by default `" "` is used, but that can be changed using `options.ws`), and all but the first element will be used as the `argv` argument, setting the first element as the new `command` argument.

### example

```js
const cp = require( "@futagoza/child-process" );

// Spawns a new process.
cp.spawn( command, argv?, options? )

// Spawns a shell, executing the command inside the shell and buffering any generated output.
cp.exec( command, argv?, options? )

// Same as `cp.exec`, but sends any output to the current process instead.
cp.run( command, argv?, options? )

// Confirm if the given error was thrown from a spawn'ed process.
cp.isSpawnError( object? )

// All arguments are optional, apart from the `command`, which can be passed as the
// first argument or as an option (either `command` or `file`)
cp.spawn( "npm", [ "publish", "--access", "public" ] );
cp.spawn( "npm", { args: [ "publish", "--access", "public" ] } );
cp.spawn( "npm publish --access public" );
cp.spawn( { command: "npm publish --access public" } );
```

### options

In addition to the options used by [child_process.spawn()](https://nodejs.org/dist/latest-v10.x/docs/api/child_process.html#child_process_child_process_spawn_command_args_options), the following options are also supported:

| option | description |
| ---------- | ----------- |
| args | Alternative to passing an array as argv argument (using _options.argv_ is preferred) |
| argv | Alternative to passing an array as argv argument |
| buffer1 | On _options.pipe_ this will buffer the results from both `stdout` and `stderr` |
| command | Alternative to passing the command as a string argument |
| encoding1 | Used alongside _options.buffer_, this specifies the character encoding used to decode the results |
| file | Alternative to passing the command as a string argument |
| ignore2 | Will set _options.stdio_ to __ignore__ |
| inherit2 | Will set _options.stdio_ to __inherit__3 |
| input | passed to the child process's `stdin` |
| pipe2 | Will set _options.stdio_ to __pipe__4 |
| ready | A function that will be called with the child process as it's argument once the promise has started waiting |
| silent2 | Will set _options.stdio_ to __pipe__ |
| ws | If there were no _args_ found, then this is used to split the _command_ string and extract the _args_ |

1. The _buffer_ option is only used in `cp.spawn` _(optional)_ and `cp.exec` _(fixed)_
2. Is ignored if the _stdio_ option is already set
3. The fixed option for _stdio_ with `cp.run`
4. The fixed option for _stdio_ with `cp.exec`, and the default for it on `cp.spawn`

## license

Copyright (c) 2018+ [Futago-za Ryuu](http://github.com/futagoza)

The MIT License, [http://opensource.org/licenses/MIT](http://opensource.org/licenses/MIT)