diff --git a/lib/internal/per_context.js b/lib/internal/per_context.js new file mode 100644 index 00000000000000..77a44d52b937e1 --- /dev/null +++ b/lib/internal/per_context.js @@ -0,0 +1,16 @@ +'use strict'; + +// node::NewContext calls this script + +(function(global) { + // https://github.com/nodejs/node/issues/14909 + delete global.Intl.v8BreakIterator; + + // https://github.com/nodejs/node/issues/21219 + Object.defineProperty(global.Atomics, 'notify', { + value: global.Atomics.wake, + writable: true, + enumerable: false, + configurable: true, + }); +}(this)); diff --git a/node.gyp b/node.gyp index 461152b05e88c3..300a20b6e306c4 100644 --- a/node.gyp +++ b/node.gyp @@ -25,6 +25,7 @@ 'node_lib_target_name%': 'node_lib', 'node_intermediate_lib_type%': 'static_library', 'library_files': [ + 'lib/internal/per_context.js', 'lib/internal/bootstrap/cache.js', 'lib/internal/bootstrap/loaders.js', 'lib/internal/bootstrap/node.js', diff --git a/src/node.cc b/src/node.cc index d5338d974633e8..7ed25bd2aedcc4 100644 --- a/src/node.cc +++ b/src/node.cc @@ -4046,35 +4046,19 @@ Local NewContext(Isolate* isolate, auto context = Context::New(isolate, nullptr, object_template); if (context.IsEmpty()) return context; HandleScope handle_scope(isolate); + context->SetEmbedderData( ContextEmbedderIndex::kAllowWasmCodeGeneration, True(isolate)); - auto intl_key = FIXED_ONE_BYTE_STRING(isolate, "Intl"); - auto break_iter_key = FIXED_ONE_BYTE_STRING(isolate, "v8BreakIterator"); - Local intl_v; - if (context->Global()->Get(context, intl_key).ToLocal(&intl_v) && - intl_v->IsObject()) { - Local intl = intl_v.As(); - intl->Delete(context, break_iter_key).FromJust(); - } - - // https://github.com/nodejs/node/issues/21219 - // TODO(devsnek): remove when v8 supports Atomics.notify - auto atomics_key = FIXED_ONE_BYTE_STRING(isolate, "Atomics"); - Local atomics_v; - if (context->Global()->Get(context, atomics_key).ToLocal(&atomics_v) && - atomics_v->IsObject()) { - Local atomics = atomics_v.As(); - auto wake_key = FIXED_ONE_BYTE_STRING(isolate, "wake"); - - Local wake = atomics->Get(context, wake_key).ToLocalChecked(); - auto notify_key = FIXED_ONE_BYTE_STRING(isolate, "notify"); - - v8::PropertyDescriptor desc(wake, true); - desc.set_enumerable(false); - desc.set_configurable(true); - - atomics->DefineProperty(context, notify_key, desc).ToChecked(); + { + // Run lib/internal/per_context.js + Context::Scope context_scope(context); + Local per_context = NodePerContextSource(isolate); + v8::ScriptCompiler::Source per_context_src(per_context, nullptr); + Local s = v8::ScriptCompiler::Compile( + context, + &per_context_src).ToLocalChecked(); + s->Run(context).ToLocalChecked(); } return context; diff --git a/src/node.h b/src/node.h index 90b2a8cbf690ce..b551c8bb09baf9 100644 --- a/src/node.h +++ b/src/node.h @@ -241,9 +241,7 @@ class MultiIsolatePlatform : public v8::Platform { // Creates a new isolate with Node.js-specific settings. NODE_EXTERN v8::Isolate* NewIsolate(ArrayBufferAllocator* allocator); -// Creates a new context with Node.js-specific tweaks. Currently, it removes -// the `v8BreakIterator` property from the global `Intl` object if present. -// See https://github.com/nodejs/node/issues/14909 for more info. +// Creates a new context with Node.js-specific tweaks. NODE_EXTERN v8::Local NewContext( v8::Isolate* isolate, v8::Local object_template = diff --git a/src/node_javascript.h b/src/node_javascript.h index d1ad9a25745e9b..00cdc0c0b6c13e 100644 --- a/src/node_javascript.h +++ b/src/node_javascript.h @@ -29,6 +29,7 @@ namespace node { void DefineJavaScript(Environment* env, v8::Local target); +v8::Local NodePerContextSource(v8::Isolate* isolate); v8::Local LoadersBootstrapperSource(Environment* env); v8::Local NodeBootstrapperSource(Environment* env); diff --git a/tools/js2c.py b/tools/js2c.py index 38cf39f81677dd..249df58085dd96 100755 --- a/tools/js2c.py +++ b/tools/js2c.py @@ -189,6 +189,10 @@ def ReadMacros(lines): }} // anonymous namespace +v8::Local NodePerContextSource(v8::Isolate* isolate) {{ + return internal_per_context_value.ToStringChecked(isolate); +}} + v8::Local LoadersBootstrapperSource(Environment* env) {{ return internal_bootstrap_loaders_value.ToStringChecked(env->isolate()); }}