Call a function in a specific version of Node. Installs the version if not found.
See also node-version-call-local for a lightweight alternative that uses Node versions already in PATH.
npm install node-version-call
import { callSync, bindSync } from 'node-version-call';
// Immediate call - returns value synchronously
const result = callSync('18', '/path/to/worker.js', {}, arg1, arg2);
// Bound caller for repeated use
const worker = bindSync('>=20', '/path/to/worker.js', {});
const result1 = worker(arg1);
const result2 = worker(arg2);
import call, { bind } from 'node-version-call';
// With callback (last argument is function)
call('18', '/path/to/worker.js', {}, arg1, (err, result) => {
if (err) return console.error(err);
console.log(result);
});
// With Promise (no callback)
const result = await call('18', '/path/to/worker.js', {}, arg1);
// Bound caller with callback
const worker = bind('>=20', '/path/to/worker.js', {});
worker(arg1, (err, result) => { /* ... */ });
// Bound caller with Promise
const result = await worker(arg1);
interface CallOptions {
callbacks?: boolean; // Worker uses callback style (default: false)
spawnOptions?: boolean; // Use spawnOptions for child process env setup (default: true)
storagePath?: string; // Where to install Node versions
env?: NodeJS.ProcessEnv; // Environment variables (default: process.env)
}
true if the worker function uses callback style (fn(...args, callback)) rather than returning a value or Promisetrue, sets up proper environment (PATH, etc.) so child processes spawned by the worker use the correct Node version