• Parameters

    • kernelStorage: SwingStoreKernelStorage = ...
    • deviceEndowments: Record<string, unknown> = {}
    • runtimeOptions: {
          bundleHandler?: BundleHandler;
          debugPrefix?: string;
          debugVats?: string[];
          env?: Record<string, undefined | string>;
          kernelBundle?: Bundle;
          overrideVatManagerOptions?: unknown;
          profileVats?: string[];
          slogCallbacks?: unknown;
          slogSender?: SlogSender;
          spawn?: {
              (command: string, options?: SpawnOptionsWithoutStdio): ChildProcessWithoutNullStreams;
              (command: string, options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>): ChildProcessByStdio<Writable, Readable, Readable>;
              (command: string, options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>): ChildProcessByStdio<Writable, Readable, null>;
              (command: string, options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>): ChildProcessByStdio<Writable, null, Readable>;
              (command: string, options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>): ChildProcessByStdio<null, Readable, Readable>;
              (command: string, options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>): ChildProcessByStdio<Writable, null, null>;
              (command: string, options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>): ChildProcessByStdio<null, Readable, null>;
              (command: string, options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>): ChildProcessByStdio<null, null, Readable>;
              (command: string, options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>): ChildProcessByStdio<null, null, null>;
              (command: string, options: SpawnOptions): ChildProcess;
              (command: string, args?: readonly string[], options?: SpawnOptionsWithoutStdio): ChildProcessWithoutNullStreams;
              (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>): ChildProcessByStdio<Writable, Readable, Readable>;
              (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>): ChildProcessByStdio<Writable, Readable, null>;
              (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>): ChildProcessByStdio<Writable, null, Readable>;
              (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>): ChildProcessByStdio<null, Readable, Readable>;
              (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>): ChildProcessByStdio<Writable, null, null>;
              (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>): ChildProcessByStdio<null, Readable, null>;
              (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>): ChildProcessByStdio<null, null, Readable>;
              (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>): ChildProcessByStdio<null, null, null>;
              (command: string, args: readonly string[], options: SpawnOptions): ChildProcess;
          };
          testTrackDecref?: unknown;
          verbose?: boolean;
          warehousePolicy?: VatWarehousePolicy;
          xsnapBundleData?: {
              getLockdownBundle: (() => Promise<Bundle>);
              getLockdownBundleSHA256: (() => Promise<string>);
              getSupervisorBundle: (() => Promise<Bundle>);
              getSupervisorBundleSHA256: (() => Promise<string>);
          };
      } = {}
      • OptionalbundleHandler?: BundleHandler
      • OptionaldebugPrefix?: string
      • OptionaldebugVats?: string[]
      • Optionalenv?: Record<string, undefined | string>
      • OptionalkernelBundle?: Bundle
      • OptionaloverrideVatManagerOptions?: unknown
      • OptionalprofileVats?: string[]
      • OptionalslogCallbacks?: unknown
      • OptionalslogSender?: SlogSender
      • Optionalspawn?: {
            (command: string, options?: SpawnOptionsWithoutStdio): ChildProcessWithoutNullStreams;
            (command: string, options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>): ChildProcessByStdio<Writable, Readable, Readable>;
            (command: string, options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>): ChildProcessByStdio<Writable, Readable, null>;
            (command: string, options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>): ChildProcessByStdio<Writable, null, Readable>;
            (command: string, options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>): ChildProcessByStdio<null, Readable, Readable>;
            (command: string, options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>): ChildProcessByStdio<Writable, null, null>;
            (command: string, options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>): ChildProcessByStdio<null, Readable, null>;
            (command: string, options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>): ChildProcessByStdio<null, null, Readable>;
            (command: string, options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>): ChildProcessByStdio<null, null, null>;
            (command: string, options: SpawnOptions): ChildProcess;
            (command: string, args?: readonly string[], options?: SpawnOptionsWithoutStdio): ChildProcessWithoutNullStreams;
            (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>): ChildProcessByStdio<Writable, Readable, Readable>;
            (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>): ChildProcessByStdio<Writable, Readable, null>;
            (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>): ChildProcessByStdio<Writable, null, Readable>;
            (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>): ChildProcessByStdio<null, Readable, Readable>;
            (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>): ChildProcessByStdio<Writable, null, null>;
            (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>): ChildProcessByStdio<null, Readable, null>;
            (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>): ChildProcessByStdio<null, null, Readable>;
            (command: string, args: readonly string[], options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>): ChildProcessByStdio<null, null, null>;
            (command: string, args: readonly string[], options: SpawnOptions): ChildProcess;
        }
          • (command, options?): ChildProcessWithoutNullStreams
          • The child_process.spawn() method spawns a new process using the given command, with command-line arguments in args. If omitted, args defaults to an empty array.

            If the shell option is enabled, do not pass unsanitized user input to this function. Any input containing shell metacharacters may be used to trigger arbitrary command execution.

            A third argument may be used to specify additional options, with these defaults:

            const defaults = {
            cwd: undefined,
            env: process.env,
            };

            Use cwd to specify the working directory from which the process is spawned. If not given, the default is to inherit the current working directory. If given, but the path does not exist, the child process emits an ENOENT error and exits immediately. ENOENT is also emitted when the command does not exist.

            Use env to specify environment variables that will be visible to the new process, the default is process.env.

            undefined values in env will be ignored.

            Example of running ls -lh /usr, capturing stdout, stderr, and the exit code:

            const { spawn } = require('node:child_process');
            const ls = spawn('ls', ['-lh', '/usr']);

            ls.stdout.on('data', (data) => {
            console.log(`stdout: ${data}`);
            });

            ls.stderr.on('data', (data) => {
            console.error(`stderr: ${data}`);
            });

            ls.on('close', (code) => {
            console.log(`child process exited with code ${code}`);
            });

            Example: A very elaborate way to run ps ax | grep ssh

            const { spawn } = require('node:child_process');
            const ps = spawn('ps', ['ax']);
            const grep = spawn('grep', ['ssh']);

            ps.stdout.on('data', (data) => {
            grep.stdin.write(data);
            });

            ps.stderr.on('data', (data) => {
            console.error(`ps stderr: ${data}`);
            });

            ps.on('close', (code) => {
            if (code !== 0) {
            console.log(`ps process exited with code ${code}`);
            }
            grep.stdin.end();
            });

            grep.stdout.on('data', (data) => {
            console.log(data.toString());
            });

            grep.stderr.on('data', (data) => {
            console.error(`grep stderr: ${data}`);
            });

            grep.on('close', (code) => {
            if (code !== 0) {
            console.log(`grep process exited with code ${code}`);
            }
            });

            Example of checking for failed spawn:

            const { spawn } = require('node:child_process');
            const subprocess = spawn('bad_command');

            subprocess.on('error', (err) => {
            console.error('Failed to start subprocess.');
            });

            Certain platforms (macOS, Linux) will use the value of argv[0] for the process title while others (Windows, SunOS) will use command.

            Node.js overwrites argv[0] with process.execPath on startup, so process.argv[0] in a Node.js child process will not match the argv0 parameter passed to spawn from the parent. Retrieve it with the process.argv0 property instead.

            If the signal option is enabled, calling .abort() on the corresponding AbortController is similar to calling .kill() on the child process except the error passed to the callback will be an AbortError:

            const { spawn } = require('node:child_process');
            const controller = new AbortController();
            const { signal } = controller;
            const grep = spawn('grep', ['ssh'], { signal });
            grep.on('error', (err) => {
            // This will be called with err being an AbortError if the controller aborts
            });
            controller.abort(); // Stops the child process

            Parameters

            • command: string

              The command to run.

            • Optionaloptions: SpawnOptionsWithoutStdio

            Returns ChildProcessWithoutNullStreams

            v0.1.90

          • (command, options): ChildProcessByStdio<Writable, Readable, Readable>
          • Parameters

            • command: string
            • options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>

            Returns ChildProcessByStdio<Writable, Readable, Readable>

          • (command, options): ChildProcessByStdio<Writable, Readable, null>
          • Parameters

            • command: string
            • options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>

            Returns ChildProcessByStdio<Writable, Readable, null>

          • (command, options): ChildProcessByStdio<Writable, null, Readable>
          • Parameters

            • command: string
            • options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>

            Returns ChildProcessByStdio<Writable, null, Readable>

          • (command, options): ChildProcessByStdio<null, Readable, Readable>
          • Parameters

            • command: string
            • options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>

            Returns ChildProcessByStdio<null, Readable, Readable>

          • (command, options): ChildProcessByStdio<Writable, null, null>
          • Parameters

            • command: string
            • options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>

            Returns ChildProcessByStdio<Writable, null, null>

          • (command, options): ChildProcessByStdio<null, Readable, null>
          • Parameters

            • command: string
            • options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>

            Returns ChildProcessByStdio<null, Readable, null>

          • (command, options): ChildProcessByStdio<null, null, Readable>
          • Parameters

            • command: string
            • options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>

            Returns ChildProcessByStdio<null, null, Readable>

          • (command, options): ChildProcessByStdio<null, null, null>
          • Parameters

            • command: string
            • options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>

            Returns ChildProcessByStdio<null, null, null>

          • (command, options): ChildProcess
          • Parameters

            • command: string
            • options: SpawnOptions

            Returns ChildProcess

          • (command, args?, options?): ChildProcessWithoutNullStreams
          • Parameters

            • command: string
            • Optionalargs: readonly string[]
            • Optionaloptions: SpawnOptionsWithoutStdio

            Returns ChildProcessWithoutNullStreams

          • (command, args, options): ChildProcessByStdio<Writable, Readable, Readable>
          • Parameters

            • command: string
            • args: readonly string[]
            • options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>

            Returns ChildProcessByStdio<Writable, Readable, Readable>

          • (command, args, options): ChildProcessByStdio<Writable, Readable, null>
          • Parameters

            • command: string
            • args: readonly string[]
            • options: SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>

            Returns ChildProcessByStdio<Writable, Readable, null>

          • (command, args, options): ChildProcessByStdio<Writable, null, Readable>
          • Parameters

            • command: string
            • args: readonly string[]
            • options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>

            Returns ChildProcessByStdio<Writable, null, Readable>

          • (command, args, options): ChildProcessByStdio<null, Readable, Readable>
          • Parameters

            • command: string
            • args: readonly string[]
            • options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>

            Returns ChildProcessByStdio<null, Readable, Readable>

          • (command, args, options): ChildProcessByStdio<Writable, null, null>
          • Parameters

            • command: string
            • args: readonly string[]
            • options: SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>

            Returns ChildProcessByStdio<Writable, null, null>

          • (command, args, options): ChildProcessByStdio<null, Readable, null>
          • Parameters

            • command: string
            • args: readonly string[]
            • options: SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>

            Returns ChildProcessByStdio<null, Readable, null>

          • (command, args, options): ChildProcessByStdio<null, null, Readable>
          • Parameters

            • command: string
            • args: readonly string[]
            • options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>

            Returns ChildProcessByStdio<null, null, Readable>

          • (command, args, options): ChildProcessByStdio<null, null, null>
          • Parameters

            • command: string
            • args: readonly string[]
            • options: SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>

            Returns ChildProcessByStdio<null, null, null>

          • (command, args, options): ChildProcess
          • Parameters

            • command: string
            • args: readonly string[]
            • options: SpawnOptions

            Returns ChildProcess

      • OptionaltestTrackDecref?: unknown
      • Optionalverbose?: boolean
      • OptionalwarehousePolicy?: VatWarehousePolicy
      • OptionalxsnapBundleData?: {
            getLockdownBundle: (() => Promise<Bundle>);
            getLockdownBundleSHA256: (() => Promise<string>);
            getSupervisorBundle: (() => Promise<Bundle>);
            getSupervisorBundleSHA256: (() => Promise<string>);
        }
        • getLockdownBundle: (() => Promise<Bundle>)
            • (): Promise<Bundle>
            • Returns Promise<Bundle>

        • getLockdownBundleSHA256: (() => Promise<string>)
            • (): Promise<string>
            • Returns Promise<string>

        • getSupervisorBundle: (() => Promise<Bundle>)
            • (): Promise<Bundle>
            • Returns Promise<Bundle>

        • getSupervisorBundleSHA256: (() => Promise<string>)
            • (): Promise<string>
            • Returns Promise<string>

    Returns Promise<{
        debug: {
            addDeviceHook: ((deviceName: any, hookName: any, hook: any) => void);
        };
        injectQueuedUpgradeEvents: (() => void);
        validateAndInstallBundle: ((bundle: EndoZipBase64Bundle, allegedBundleID??: string) => Promise<string>);
        writeSlogObject: ((obj: any) => void);
        changeKernelOptions(options: any): void;
        deviceNameToID(deviceName: any): undefined | string;
        dump(): {
            acceptanceQueue: any[];
            gcActions: any[];
            kernelTable: any[];
            log: string[];
            objects: (undefined | string | number)[][];
            promises: ({
                decider: undefined | string;
                id: string;
                policy: string;
                queue: string[];
                refCount: number;
                state: "unresolved";
                subscribers: string[];
            } | {
                data: SwingSetCapData;
                id: string;
                refCount: number;
                state: "rejected" | "fulfilled";
            })[];
            reapQueue: any;
            runQueue: any[];
            vatTables: {
                state: {
                    transcript: [number, TranscriptEntry][];
                };
                vatID: string;
            }[];
        };
        getActivityhash(): string;
        getStats(): {};
        getStatus(): {
            activeVats: {
                id: string;
                options: RecordedVatOptions;
            }[];
        };
        kpRegisterInterest(kpid: any): void;
        kpResolution(kpid: any, options: any): SwingSetCapData;
        kpStatus(kpid: any):
            | "rejected"
            | "fulfilled"
            | "unknown"
            | "unresolved";
        log(str: any): void;
        pinVatRoot(vatName: any): string;
        queueToVatObject(target: any, method: string | symbol, args?: unknown[], resultPolicy?: ResolutionPolicy): undefined | string;
        queueToVatRoot(vatName: string, method: string | symbol, args?: unknown[], resultPolicy?: ResolutionPolicy): undefined | string;
        reapAllVats(): void;
        run(policy?: RunPolicy): Promise<number>;
        shutdown(): Promise<void>;
        step(): Promise<0 | 1>;
        terminateVat(vatID: string, reasonCD: SwingSetCapData): void;
        upgradeStaticVat(vatName: any, shouldPauseFirst: any, bundleID: any, options?: {}): undefined | string;
        vatNameToID(vatName: any): string;
        verboseDebugMode(flag: any): void;
    }>