Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
demurgos-foreground-child
Advanced tools
Run a child as if it's the foreground process. Give it stdio. Exit when it exits.
Run a child as if it's the foreground process. Give it stdio.
Mostly this module is here to support some use cases around wrapping child processes for test coverage and such.
const fg = require('foreground-child')
// cats out this file
const {child, close} = fg('cat', [__filename])
// At this point, it's best to just do nothing else.
// return or whatever.
// If the child gets a signal, or just exits, then this
// parent process will exit in the same way.
// Close is a promise resolved when the child is closed.
// You can use it to inspected its exit code and exit the parent process.
close.then((close) => {
// You can use this handler to perform an action before exiting the
// foreground child.
console.log(close.code);
console.log(close.status);
close(); // Kills the parent process using the result of the child process.
});
The "normal" standard IO file descriptors (0, 1, and 2 for stdin, stdout, and stderr respectively) are shared with the child process. Additionally, if there is an IPC channel set up in the parent, then messages are proxied to the child on file descriptor 3.
However, in Node, it's possible to also map arbitrary file descriptors into a child process. In these cases, foreground-child will not map the file descriptors into the child. If file descriptors 0, 1, or 2 are used for the IPC channel, then strange behavior may happen (like printing IPC messages to stderr, for example).
Note that a SIGKILL will always kill the parent process, and never the child process, because SIGKILL cannot be caught or proxied. The only way to do this would be if Node provided a way to truly exec a process as the new foreground program in the same process space, without forking a separate child process.
The canonical documentation is in the source code. See index.ts.
fg(file, args)
: Original APIfg.compat
: Alias for fg
.fg.spawn(file, args, options)
: New API, based on Node's cp.spawn
.fg.proxy(parent, child)
: Forward IO, IPC and signals from parent to child.FAQs
Run a child as if it's the foreground process. Give it stdio. Exit when it exits.
The npm package demurgos-foreground-child receives a total of 15 weekly downloads. As such, demurgos-foreground-child popularity was classified as not popular.
We found that demurgos-foreground-child demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
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.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.