mirror of https://github.com/nodejs/node.git
lib: delay access to CLI option to pre-execution
CLI options should not be added through the config binding, instead they are already available in the JS land via `require('internal/options')`. Also CLI options in principle should be processed in pre-execution instead of bootstrap scripts. PR-URL: https://github.com/nodejs/node/pull/30778 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Yongsheng Zhang <zyszys98@gmail.com> Reviewed-By: Rich Trott <rtrott@gmail.com>
This commit is contained in:
parent
7113d999dc
commit
28efa4fe95
|
@ -157,9 +157,6 @@ function NativeModule(id) {
|
|||
this.loaded = false;
|
||||
this.loading = false;
|
||||
this.canBeRequiredByUsers = !id.startsWith('internal/');
|
||||
|
||||
if (id === 'wasi')
|
||||
this.canBeRequiredByUsers = !!internalBinding('config').experimentalWasi;
|
||||
}
|
||||
|
||||
// To be called during pre-execution when --expose-internals is on.
|
||||
|
|
|
@ -61,6 +61,7 @@ function prepareMainThreadExecution(expandArgv1 = false) {
|
|||
initializeClusterIPC();
|
||||
|
||||
initializeDeprecations();
|
||||
initializeWASI();
|
||||
initializeCJSLoader();
|
||||
initializeESMLoader();
|
||||
|
||||
|
@ -399,6 +400,14 @@ function initializePolicy() {
|
|||
}
|
||||
}
|
||||
|
||||
function initializeWASI() {
|
||||
if (getOptionValue('--experimental-wasi-unstable-preview0')) {
|
||||
const { NativeModule } = require('internal/bootstrap/loaders');
|
||||
const mod = NativeModule.map.get('wasi');
|
||||
mod.canBeRequiredByUsers = true;
|
||||
}
|
||||
}
|
||||
|
||||
function initializeCJSLoader() {
|
||||
const CJSLoader = require('internal/modules/cjs/loader');
|
||||
CJSLoader.Module._initPaths();
|
||||
|
@ -456,5 +465,6 @@ module.exports = {
|
|||
setupTraceCategoryState,
|
||||
setupInspectorHooks,
|
||||
initializeReport,
|
||||
initializeCJSLoader
|
||||
initializeCJSLoader,
|
||||
initializeWASI
|
||||
};
|
||||
|
|
|
@ -14,6 +14,7 @@ const {
|
|||
setupWarningHandler,
|
||||
setupDebugEnv,
|
||||
initializeDeprecations,
|
||||
initializeWASI,
|
||||
initializeCJSLoader,
|
||||
initializeESMLoader,
|
||||
initializeFrozenIntrinsics,
|
||||
|
@ -109,6 +110,7 @@ port.on('message', (message) => {
|
|||
require('internal/process/policy').setup(manifestSrc, manifestURL);
|
||||
}
|
||||
initializeDeprecations();
|
||||
initializeWASI();
|
||||
initializeCJSLoader();
|
||||
initializeESMLoader();
|
||||
|
||||
|
|
|
@ -15,11 +15,14 @@ using v8::Number;
|
|||
using v8::Object;
|
||||
using v8::Value;
|
||||
|
||||
// The config binding is used to provide an internal view of compile or runtime
|
||||
// The config binding is used to provide an internal view of compile time
|
||||
// config options that are required internally by lib/*.js code. This is an
|
||||
// alternative to dropping additional properties onto the process object as
|
||||
// has been the practice previously in node.cc.
|
||||
|
||||
// Command line arguments are already accessible in the JS land via
|
||||
// require('internal/options').getOptionValue('--some-option'). Do not add them
|
||||
// here.
|
||||
static void Initialize(Local<Object> target,
|
||||
Local<Value> unused,
|
||||
Local<Context> context,
|
||||
|
@ -84,9 +87,6 @@ static void Initialize(Local<Object> target,
|
|||
|
||||
READONLY_PROPERTY(target, "hasCachedBuiltins",
|
||||
v8::Boolean::New(isolate, native_module::has_code_cache));
|
||||
|
||||
if (env->options()->experimental_wasi)
|
||||
READONLY_TRUE_PROPERTY(target, "experimentalWasi");
|
||||
} // InitConfig
|
||||
|
||||
} // namespace node
|
||||
|
|
Loading…
Reference in New Issue