Skip to content
Node.js exec function to replace running process; like Ruby's exec.
C++ JavaScript Makefile Python
Latest commit 39208e5 Nov 27, 2015 @jprichardson 2.0.2
Failed to load latest commit information.
src add support for node >= v5.x Nov 27, 2015
test Test cases. Jan 17, 2014
.gitignore Add Node.js v0.11 support Dec 29, 2014
.travis.yml add ci files Oct 21, 2015 2.0.2 Nov 27, 2015
LICENSE Made Node v0.8 compatible. Sep 19, 2012
Makefile explicitly find npm's node-gyp in make Nov 25, 2015
binding.gyp add support for node >= v5.x Nov 27, 2015
circle.yml add ci files Oct 21, 2015

Node.js - kexec

This module causes your current Node.js process to be replaced by the process invoked by the parameter of this function. It's like the Ruby exec function. It currently does not work on Windows.

Fully compatible with Node.js version v0.10 and v0.11.


var kexec = require('kexec');

kexec('top'); //your process now becomes top, can also accept parameters in one string
var kexec = require('kexec');

kexec('du', [ '-sh', '/etc/fstab' ]); //your process now becomes du, with the arguments indicated


kexec can be called in either of two ways, as indicated by the examples, above.

With one argument arg, that argument must be a string. The resulting system call is:

execvp("/bin/sh", [ "/bin/sh", "-c", arg, 0 ]);

With two arguments, the first (cmd) must be a string, and the second (args) an array of strings. The resulting system call is:

execvp(cmd, [ cmd, args[0], args[1], ..., 0 ]);

In the first case, the command is subject to shell parsing, and shell meta characters retain their special meanings. In the second case, the arguments are passed directly to execvp, without an intervening shell.


(The MIT License)

Copyright (c) 2011-2015 JP Richardson

Something went wrong with that request. Please try again.