diff options
author | Gus Caplan <me@gus.host> | 2019-09-26 15:58:49 -0700 |
---|---|---|
committer | Gus Caplan <me@gus.host> | 2019-10-11 12:33:40 -0700 |
commit | c0305af2c4aba6d6ecd39eb100a59998d87ddc69 (patch) | |
tree | a83ae9edb6421e14160ed8a3ba60164979040145 /lib | |
parent | 06f6d662f679ee04679d97ecd5087e6f17268141 (diff) | |
download | android-node-v8-c0305af2c4aba6d6ecd39eb100a59998d87ddc69.tar.gz android-node-v8-c0305af2c4aba6d6ecd39eb100a59998d87ddc69.tar.bz2 android-node-v8-c0305af2c4aba6d6ecd39eb100a59998d87ddc69.zip |
repl: check for NODE_REPL_EXTERNAL_MODULE
PR-URL: https://github.com/nodejs/node/pull/29778
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: Yongsheng Zhang <zyszys98@gmail.com>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/internal/main/repl.js | 66 |
1 files changed, 36 insertions, 30 deletions
diff --git a/lib/internal/main/repl.js b/lib/internal/main/repl.js index 93b932f0bd..693b7048a3 100644 --- a/lib/internal/main/repl.js +++ b/lib/internal/main/repl.js @@ -19,38 +19,44 @@ prepareMainThreadExecution(); markBootstrapComplete(); -// --input-type flag not supported in REPL -if (getOptionValue('--input-type')) { - // If we can't write to stderr, we'd like to make this a noop, - // so use console.error. - console.error('Cannot specify --input-type for REPL'); - process.exit(1); -} +if (process.env.NODE_REPL_EXTERNAL_MODULE) { + require('internal/modules/cjs/loader') + .Module + ._load(process.env.NODE_REPL_EXTERNAL_MODULE, undefined, true); +} else { + // --input-type flag not supported in REPL + if (getOptionValue('--input-type')) { + // If we can't write to stderr, we'd like to make this a noop, + // so use console.error. + console.error('Cannot specify --input-type for REPL'); + process.exit(1); + } -console.log(`Welcome to Node.js ${process.version}.\n` + - 'Type ".help" for more information.'); + console.log(`Welcome to Node.js ${process.version}.\n` + + 'Type ".help" for more information.'); -const cliRepl = require('internal/repl'); -cliRepl.createInternalRepl(process.env, (err, repl) => { - if (err) { - throw err; - } - repl.on('exit', () => { - if (repl._flushing) { - repl.pause(); - return repl.once('flushHistory', () => { - process.exit(); - }); + const cliRepl = require('internal/repl'); + cliRepl.createInternalRepl(process.env, (err, repl) => { + if (err) { + throw err; } - process.exit(); + repl.on('exit', () => { + if (repl._flushing) { + repl.pause(); + return repl.once('flushHistory', () => { + process.exit(); + }); + } + process.exit(); + }); }); -}); - -// If user passed '-e' or '--eval' along with `-i` or `--interactive`, -// evaluate the code in the current context. -if (getOptionValue('[has_eval_string]')) { - evalScript('[eval]', - getOptionValue('--eval'), - getOptionValue('--inspect-brk'), - getOptionValue('--print')); + + // If user passed '-e' or '--eval' along with `-i` or `--interactive`, + // evaluate the code in the current context. + if (getOptionValue('[has_eval_string]')) { + evalScript('[eval]', + getOptionValue('--eval'), + getOptionValue('--inspect-brk'), + getOptionValue('--print')); + } } |