Socket
Socket
Sign inDemoInstall

child-process-ext

Package Overview
Dependencies
28
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

child-process-ext

Extensions to Node.js child_process module


Version published
Maintainers
1
Weekly downloads
1,317,345
decreased by-18.34%
Install size
1.04 MB

Weekly downloads

Package description

What is child-process-ext?

The child-process-ext package is a Node.js module that extends the core 'child_process' module with additional functionality and convenience methods. It simplifies working with child processes in Node.js by providing enhanced features for spawning, executing, and managing child processes.

What are child-process-ext's main functionalities?

Spawn with Promises

This feature allows you to spawn a child process and work with it using promises, making it easier to handle the asynchronous nature of child process execution. The example shows how to list the contents of the '/usr' directory.

const { spawn } = require('child-process-ext');

async function runCommand() {
  try {
    const result = await spawn('ls', ['-lh', '/usr']);
    console.log(`stdout: ${result.stdout}`);
  } catch (error) {
    console.error(`Error: ${error.message}`);
  }
}

runCommand();

Execute with Enhanced Output Handling

This feature simplifies executing a command and directly handling its output. It enhances the default 'exec' by providing a more straightforward way to access stdout and stderr. The example demonstrates checking the Node.js version installed.

const { exec } = require('child-process-ext');

async function executeCommand() {
  try {
    const { stdout, stderr } = await exec('node -v');
    console.log(`Node Version: ${stdout}`);
  } catch (error) {
    console.error(`Error: ${stderr}`);
  }
}

executeCommand();

Other packages similar to child-process-ext

Readme

Source

Build status Tests coverage npm version

child-process-ext

Node.js child_process extensions

Installation

npm install child-process-ext

API

spawn(command[, args[, options]])

Cross system compliant spawn (backed by cross-spawn).

Works exactly same way as node's spawn with difference that promise is returned that resolves once process exits.

Following properties are exposed on return promise:

  • child - child process
  • stdout - stdout stream (decorated so it can also be used as promise)
  • stderr - stderr stream (decorated so it can also be used as promise)
  • std - Merged stdout & stderr stream (decorated so it can also be used as promise)
  • stdoutBuffer - Buffer that exposes so far written stdout
  • stderrBuffer - Buffer that exposes so far written stderrr
  • stdBuffer - Buffer that exposes so far written std

Promise resolves with object with three properties:

  • code - Exit code of a child proces
  • signal - Signal that terminated the process
  • stdoutBuffer - Buffer containing gathered stdout content
  • stderrBuffer - Buffer containing gathered stderr content
  • stdBuffer - Buffer containing gathered stderr content

If process exits with non zero code, then promise is rejected with an error exposing same properties as above

Non standard options
split bool (default: false)

Whether stdout data should be split by lines. If set to true, then stdout and stderr on promise expose mappers of original stdout and stderr that emit each line with distinct data event

shouldCloseStdin bool (default: false)

Whether stdin should be closed. Applicable for spawned processes where stdin is set to other than 'inherit' mode, and underlying processes is reading from stdin. Not providing any stdin output, may produce stall if process logic waits for an input. See: get-stdin#13 for more information

Tests

npm test

Keywords

FAQs

Last updated on 22 Aug 2023

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc