* chore: bump chromium in DEPS to 121.0.6116.0 * chore: update patches * Update webIDL to support close event. Refs https://chromium-review.googlesource.com/c/chromium/src/+/4970653 * Remove uses of implicit conversion of ScopedTypeRef Refs https://bugs.chromium.org/p/chromium/issues/detail?id=1495439 * Add GlobalRenderFrameHostToken Refs https://chromium-review.googlesource.com/c/chromium/src/+/5001743 * [DevTools] Console Insights: move from build flag to Feature API Refs https://chromium-review.googlesource.com/c/chromium/src/+/5002232 * [Extensions] Use script serialization in scripting API Refs https://chromium-review.googlesource.com/c/chromium/src/+/4968680 Refs https://chromium-review.googlesource.com/c/chromium/src/+/4998265 * [api] Remove AllCan Read/Write https://chromium-review.googlesource.com/c/v8/v8/+/5006387 * chore: update libcxx files * chore: address nan compilation error * spec: use nan dependency from third_party It is easier to get fixes for spec modules depending on nan * ci: publish nan artifact for woa * fix: bad patch update * chore: update nan resolution * Revert "chore: update nan resolution" This reverts commit 786cdb858c9fc8a038a8f3e16068ee5b4a050137. --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: deepak1556 <hop2deep@gmail.com>
		
			
				
	
	
		
			75 lines
		
	
	
	
		
			3.6 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
	
		
			3.6 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | 
						|
From: Samuel Attard <marshallofsound@electronjs.org>
 | 
						|
Date: Wed, 8 Mar 2023 13:04:21 -0800
 | 
						|
Subject: refactor: expose HostImportModuleDynamically and
 | 
						|
 HostGetImportMetaProperties to embedders
 | 
						|
 | 
						|
This is so that Electron can blend Blink's and Node's implementations of these isolate handlers.
 | 
						|
 | 
						|
diff --git a/third_party/blink/renderer/bindings/core/v8/v8_initializer.cc b/third_party/blink/renderer/bindings/core/v8/v8_initializer.cc
 | 
						|
index 822f31cc44a1c3a67b345d81eb220356446e4f82..8f4e4d7e34e6914c187d98d7510741c57b85ac44 100644
 | 
						|
--- a/third_party/blink/renderer/bindings/core/v8/v8_initializer.cc
 | 
						|
+++ b/third_party/blink/renderer/bindings/core/v8/v8_initializer.cc
 | 
						|
@@ -604,7 +604,9 @@ bool JavaScriptCompileHintsMagicEnabledCallback(
 | 
						|
       execution_context);
 | 
						|
 }
 | 
						|
 
 | 
						|
-v8::MaybeLocal<v8::Promise> HostImportModuleDynamically(
 | 
						|
+}
 | 
						|
+
 | 
						|
+v8::MaybeLocal<v8::Promise> V8Initializer::HostImportModuleDynamically(
 | 
						|
     v8::Local<v8::Context> context,
 | 
						|
     v8::Local<v8::Data> v8_host_defined_options,
 | 
						|
     v8::Local<v8::Value> v8_referrer_resource_url,
 | 
						|
@@ -680,7 +682,7 @@ v8::MaybeLocal<v8::Promise> HostImportModuleDynamically(
 | 
						|
 }
 | 
						|
 
 | 
						|
 // https://html.spec.whatwg.org/C/#hostgetimportmetaproperties
 | 
						|
-void HostGetImportMetaProperties(v8::Local<v8::Context> context,
 | 
						|
+void V8Initializer::HostGetImportMetaProperties(v8::Local<v8::Context> context,
 | 
						|
                                  v8::Local<v8::Module> module,
 | 
						|
                                  v8::Local<v8::Object> meta) {
 | 
						|
   ScriptState* script_state = ScriptState::From(context);
 | 
						|
@@ -707,6 +709,8 @@ void HostGetImportMetaProperties(v8::Local<v8::Context> context,
 | 
						|
   meta->CreateDataProperty(context, resolve_key, resolve_value).ToChecked();
 | 
						|
 }
 | 
						|
 
 | 
						|
+namespace {
 | 
						|
+
 | 
						|
 void InitializeV8Common(v8::Isolate* isolate) {
 | 
						|
   // Set up garbage collection before setting up anything else as V8 may trigger
 | 
						|
   // GCs during Blink setup.
 | 
						|
@@ -728,9 +732,9 @@ void InitializeV8Common(v8::Isolate* isolate) {
 | 
						|
       SharedArrayBufferConstructorEnabledCallback);
 | 
						|
   isolate->SetJavaScriptCompileHintsMagicEnabledCallback(
 | 
						|
       JavaScriptCompileHintsMagicEnabledCallback);
 | 
						|
-  isolate->SetHostImportModuleDynamicallyCallback(HostImportModuleDynamically);
 | 
						|
+  isolate->SetHostImportModuleDynamicallyCallback(V8Initializer::HostImportModuleDynamically);
 | 
						|
   isolate->SetHostInitializeImportMetaObjectCallback(
 | 
						|
-      HostGetImportMetaProperties);
 | 
						|
+      V8Initializer::HostGetImportMetaProperties);
 | 
						|
   isolate->SetMetricsRecorder(std::make_shared<V8MetricsRecorder>(isolate));
 | 
						|
 
 | 
						|
 #if BUILDFLAG(IS_WIN)
 | 
						|
diff --git a/third_party/blink/renderer/bindings/core/v8/v8_initializer.h b/third_party/blink/renderer/bindings/core/v8/v8_initializer.h
 | 
						|
index 9e628b96a845322d407f9da30a63c04ef5de9c24..8f5e4602f5e3f6787a9e54d510b39519074d51e6 100644
 | 
						|
--- a/third_party/blink/renderer/bindings/core/v8/v8_initializer.h
 | 
						|
+++ b/third_party/blink/renderer/bindings/core/v8/v8_initializer.h
 | 
						|
@@ -76,6 +76,17 @@ class CORE_EXPORT V8Initializer {
 | 
						|
       v8::Local<v8::Context> context,
 | 
						|
       v8::Local<v8::String> source);
 | 
						|
 
 | 
						|
+  static v8::MaybeLocal<v8::Promise> HostImportModuleDynamically(
 | 
						|
+    v8::Local<v8::Context> context,
 | 
						|
+    v8::Local<v8::Data> v8_host_defined_options,
 | 
						|
+    v8::Local<v8::Value> v8_referrer_resource_url,
 | 
						|
+    v8::Local<v8::String> v8_specifier,
 | 
						|
+    v8::Local<v8::FixedArray> v8_import_assertions);
 | 
						|
+
 | 
						|
+  static void HostGetImportMetaProperties(v8::Local<v8::Context> context,
 | 
						|
+                                          v8::Local<v8::Module> module,
 | 
						|
+                                          v8::Local<v8::Object> meta);
 | 
						|
+
 | 
						|
   static void WasmAsyncResolvePromiseCallback(
 | 
						|
       v8::Isolate* isolate,
 | 
						|
       v8::Local<v8::Context> context,
 |