From 8ededf630ae3e6b9e013cb044105ced8c08235a7 Mon Sep 17 00:00:00 2001 From: Sam Atkins Date: Fri, 12 Apr 2024 12:48:23 +0100 Subject: [PATCH] Guard use of `process` with checks that we're running on Node `process` only exists when running in Node. Notably, `if (process)` is still a ReferenceError, so the existing check in readline.js needs modifying too. Unfortunately we don't have access to the platform name there, so we just check if `process` exists. --- src/ansi-shell/ANSIShell.js | 2 +- src/ansi-shell/pipeline/Pipeline.js | 6 ++++-- src/ansi-shell/readline/readline.js | 2 +- 3 files changed, 6 insertions(+), 4 deletions(-) diff --git a/src/ansi-shell/ANSIShell.js b/src/ansi-shell/ANSIShell.js index 3ee3fab..0eb151e 100644 --- a/src/ansi-shell/ANSIShell.js +++ b/src/ansi-shell/ANSIShell.js @@ -113,7 +113,7 @@ export class ANSIShell extends EventTarget { } async doPromptIteration() { - if ( globalThis.force_eot ) { + if ( globalThis.force_eot && this.ctx.platform.name === 'node' ) { process.exit(0); } const { readline } = this.ctx.externs; diff --git a/src/ansi-shell/pipeline/Pipeline.js b/src/ansi-shell/pipeline/Pipeline.js index 0314d9e..8ef1073 100644 --- a/src/ansi-shell/pipeline/Pipeline.js +++ b/src/ansi-shell/pipeline/Pipeline.js @@ -288,8 +288,10 @@ export class PreparedCommand { // but for some reason Node crashes first, unless we set this handler, // EVEN IF IT DOES NOTHING. I also can't find a place to safely remove it, // so apologies if it makes debugging promises harder. - const rejectionCatcher = (reason, promise) => {}; - process.on('unhandledRejection', rejectionCatcher); + if (ctx.platform.name === 'node') { + const rejectionCatcher = (reason, promise) => { }; + process.on('unhandledRejection', rejectionCatcher); + } let exit_code = 0; try { diff --git a/src/ansi-shell/readline/readline.js b/src/ansi-shell/readline/readline.js index 2ac42c7..e7f816d 100644 --- a/src/ansi-shell/readline/readline.js +++ b/src/ansi-shell/readline/readline.js @@ -74,7 +74,7 @@ const ReadlineProcessorBuilder = builder => builder externs.out.write('^C\n'); // Exit if input line is empty // FIXME: Check for 'process' is so we only do this on Node. How should we handle exiting in Puter terminal? - if ( process && ctx.vars.result.length === 0 ) { + if ( typeof process !== 'undefined' && ctx.vars.result.length === 0 ) { process.exit(1); return; }