| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  | From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | 
					
						
							|  |  |  | From: Jeremy Apthorp <nornagon@nornagon.net> | 
					
						
							|  |  |  | Date: Wed, 15 Jan 2020 16:35:18 -0800 | 
					
						
							|  |  |  | Subject: add DidInstallConditionalFeatures | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This adds a hook on script context creation _after conditional features | 
					
						
							|  |  |  | have been installed_. Electron uses this to run preload scripts and | 
					
						
							|  |  |  | various other initialization. This is necessary because at the time | 
					
						
							|  |  |  | DidCreateScriptContext is called, not all JS APIs are available in the | 
					
						
							|  |  |  | context, which can cause some preload scripts to trip. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | diff --git a/content/public/renderer/render_frame_observer.h b/content/public/renderer/render_frame_observer.h
 | 
					
						
							| 
									
										
										
										
											2023-01-05 21:35:34 -05:00
										 |  |  | index 7eaed5e4ce1f8a46d1e25f8838cf52b3676a7fb5..8f2bd75d29acfc212f2e680caf63c428aedb16b9 100644
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  | --- a/content/public/renderer/render_frame_observer.h
 | 
					
						
							|  |  |  | +++ b/content/public/renderer/render_frame_observer.h
 | 
					
						
							| 
									
										
										
										
											2022-10-17 10:22:24 -04:00
										 |  |  | @@ -136,6 +136,8 @@ class CONTENT_EXPORT RenderFrameObserver : public IPC::Listener,
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  |    virtual void DidHandleOnloadEvents() {} | 
					
						
							|  |  |  |    virtual void DidCreateScriptContext(v8::Local<v8::Context> context, | 
					
						
							|  |  |  |                                        int32_t world_id) {} | 
					
						
							|  |  |  | +  virtual void DidInstallConditionalFeatures(v8::Local<v8::Context> context,
 | 
					
						
							|  |  |  | +                                             int32_t world_id) {}
 | 
					
						
							|  |  |  |    virtual void WillReleaseScriptContext(v8::Local<v8::Context> context, | 
					
						
							|  |  |  |                                          int32_t world_id) {} | 
					
						
							|  |  |  |    virtual void DidClearWindowObject() {} | 
					
						
							|  |  |  | diff --git a/content/renderer/render_frame_impl.cc b/content/renderer/render_frame_impl.cc
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | index a0123eac7193282dbfba9712f0d88b2b87fccd9f..137c78c4441d58d9e8822aa87a2389126a80e1aa 100644
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  | --- a/content/renderer/render_frame_impl.cc
 | 
					
						
							|  |  |  | +++ b/content/renderer/render_frame_impl.cc
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | @@ -4407,6 +4407,12 @@ void RenderFrameImpl::DidCreateScriptContext(v8::Local<v8::Context> context,
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  |      observer.DidCreateScriptContext(context, world_id); | 
					
						
							|  |  |  |  } | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | +void RenderFrameImpl::DidInstallConditionalFeatures(
 | 
					
						
							|  |  |  | +    v8::Local<v8::Context> context, int world_id) {
 | 
					
						
							|  |  |  | +  for (auto& observer : observers_)
 | 
					
						
							|  |  |  | +    observer.DidInstallConditionalFeatures(context, world_id);
 | 
					
						
							|  |  |  | +}
 | 
					
						
							|  |  |  | +
 | 
					
						
							|  |  |  |  void RenderFrameImpl::WillReleaseScriptContext(v8::Local<v8::Context> context, | 
					
						
							|  |  |  |                                                 int world_id) { | 
					
						
							|  |  |  |    for (auto& observer : observers_) | 
					
						
							|  |  |  | diff --git a/content/renderer/render_frame_impl.h b/content/renderer/render_frame_impl.h
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | index c0d24c1715b4714c5f179dbba4f0d91cddef1946..c819e1429630342cb34476847b3c25b140dfc593 100644
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  | --- a/content/renderer/render_frame_impl.h
 | 
					
						
							|  |  |  | +++ b/content/renderer/render_frame_impl.h
 | 
					
						
							| 
									
										
										
										
											2023-01-05 21:35:34 -05:00
										 |  |  | @@ -603,6 +603,8 @@ class CONTENT_EXPORT RenderFrameImpl
 | 
					
						
							|  |  |  |    void DidObserveLayoutShift(double score, bool after_input_or_scroll) override; | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  |    void DidCreateScriptContext(v8::Local<v8::Context> context, | 
					
						
							|  |  |  |                                int world_id) override; | 
					
						
							|  |  |  | +  void DidInstallConditionalFeatures(v8::Local<v8::Context> context,
 | 
					
						
							|  |  |  | +                                     int world_id) override;
 | 
					
						
							|  |  |  |    void WillReleaseScriptContext(v8::Local<v8::Context> context, | 
					
						
							|  |  |  |                                  int world_id) override; | 
					
						
							|  |  |  |    void DidChangeScrollOffset() override; | 
					
						
							|  |  |  | diff --git a/third_party/blink/public/web/web_local_frame_client.h b/third_party/blink/public/web/web_local_frame_client.h
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | index 9fa27d4f1c63599d5cfeb095e74a72a88db1d8a2..0d37864c44495615103f5c1dca623c1e181a6460 100644
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  | --- a/third_party/blink/public/web/web_local_frame_client.h
 | 
					
						
							|  |  |  | +++ b/third_party/blink/public/web/web_local_frame_client.h
 | 
					
						
							| 
									
										
										
										
											2023-01-05 21:35:34 -05:00
										 |  |  | @@ -592,6 +592,9 @@ class BLINK_EXPORT WebLocalFrameClient {
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  |    virtual void DidCreateScriptContext(v8::Local<v8::Context>, | 
					
						
							|  |  |  |                                        int32_t world_id) {} | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | +  virtual void DidInstallConditionalFeatures(v8::Local<v8::Context>,
 | 
					
						
							|  |  |  | +                                             int32_t world_id) {}
 | 
					
						
							|  |  |  | +
 | 
					
						
							|  |  |  |    // WebKit is about to release its reference to a v8 context for a frame. | 
					
						
							|  |  |  |    virtual void WillReleaseScriptContext(v8::Local<v8::Context>, | 
					
						
							|  |  |  |                                          int32_t world_id) {} | 
					
						
							|  |  |  | diff --git a/third_party/blink/renderer/bindings/core/v8/local_window_proxy.cc b/third_party/blink/renderer/bindings/core/v8/local_window_proxy.cc
 | 
					
						
							| 
									
										
										
										
											2022-10-27 12:37:04 -04:00
										 |  |  | index 9736b31c03a32635fb8fde581321cc10ec11b11a..c9fd2170a25a7970648b8210ebe94e225f4ee3aa 100644
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  | --- a/third_party/blink/renderer/bindings/core/v8/local_window_proxy.cc
 | 
					
						
							|  |  |  | +++ b/third_party/blink/renderer/bindings/core/v8/local_window_proxy.cc
 | 
					
						
							| 
									
										
										
										
											2022-10-27 12:37:04 -04:00
										 |  |  | @@ -197,6 +197,7 @@ void LocalWindowProxy::Initialize() {
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  |    } | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  |    InstallConditionalFeatures(); | 
					
						
							|  |  |  | +  GetFrame()->Client()->DidInstallConditionalFeatures(context, world_->GetWorldId());
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  |    if (World().IsMainWorld()) { | 
					
						
							|  |  |  |      GetFrame()->Loader().DispatchDidClearWindowObjectInMainWorld(); | 
					
						
							| 
									
										
										
										
											2020-10-27 17:33:04 -07:00
										 |  |  | diff --git a/third_party/blink/renderer/core/frame/local_frame_client.h b/third_party/blink/renderer/core/frame/local_frame_client.h
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | index bbcc1a23378d86d716171cf695f641212e64a30a..06b10cdfa96473731958c4a7e6d0839e79714ad3 100644
 | 
					
						
							| 
									
										
										
										
											2020-10-27 17:33:04 -07:00
										 |  |  | --- a/third_party/blink/renderer/core/frame/local_frame_client.h
 | 
					
						
							|  |  |  | +++ b/third_party/blink/renderer/core/frame/local_frame_client.h
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | @@ -308,6 +308,8 @@ class CORE_EXPORT LocalFrameClient : public FrameClient {
 | 
					
						
							| 
									
										
										
										
											2020-10-27 17:33:04 -07:00
										 |  |  |   | 
					
						
							|  |  |  |    virtual void DidCreateScriptContext(v8::Local<v8::Context>, | 
					
						
							|  |  |  |                                        int32_t world_id) = 0; | 
					
						
							|  |  |  | +  virtual void DidInstallConditionalFeatures(v8::Local<v8::Context>,
 | 
					
						
							|  |  |  | +                                             int32_t world_id) = 0;
 | 
					
						
							|  |  |  |    virtual void WillReleaseScriptContext(v8::Local<v8::Context>, | 
					
						
							|  |  |  |                                          int32_t world_id) = 0; | 
					
						
							|  |  |  |    virtual bool AllowScriptExtensions() = 0; | 
					
						
							|  |  |  | diff --git a/third_party/blink/renderer/core/frame/local_frame_client_impl.cc b/third_party/blink/renderer/core/frame/local_frame_client_impl.cc
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | index 77850c10195719e320b1fdfc4f13c805a802d4ef..98955dd3da64a2f4b7036466d9e1eefd1704727d 100644
 | 
					
						
							| 
									
										
										
										
											2020-10-27 17:33:04 -07:00
										 |  |  | --- a/third_party/blink/renderer/core/frame/local_frame_client_impl.cc
 | 
					
						
							|  |  |  | +++ b/third_party/blink/renderer/core/frame/local_frame_client_impl.cc
 | 
					
						
							| 
									
										
										
										
											2023-01-05 21:35:34 -05:00
										 |  |  | @@ -283,6 +283,13 @@ void LocalFrameClientImpl::DidCreateScriptContext(
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  |      web_frame_->Client()->DidCreateScriptContext(context, world_id); | 
					
						
							|  |  |  |  } | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | +void LocalFrameClientImpl::DidInstallConditionalFeatures(
 | 
					
						
							|  |  |  | +    v8::Local<v8::Context> context,
 | 
					
						
							|  |  |  | +    int32_t world_id) {
 | 
					
						
							|  |  |  | +  if (web_frame_->Client())
 | 
					
						
							|  |  |  | +    web_frame_->Client()->DidInstallConditionalFeatures(context, world_id);
 | 
					
						
							|  |  |  | +}
 | 
					
						
							|  |  |  | +
 | 
					
						
							|  |  |  |  void LocalFrameClientImpl::WillReleaseScriptContext( | 
					
						
							|  |  |  |      v8::Local<v8::Context> context, | 
					
						
							|  |  |  |      int32_t world_id) { | 
					
						
							| 
									
										
										
										
											2020-10-27 17:33:04 -07:00
										 |  |  | diff --git a/third_party/blink/renderer/core/frame/local_frame_client_impl.h b/third_party/blink/renderer/core/frame/local_frame_client_impl.h
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | index d3f976c53e4ad894bfb808c1184f949871c3df2f..00d95e053dcc274036fc7300ad0b946df969d5fa 100644
 | 
					
						
							| 
									
										
										
										
											2020-10-27 17:33:04 -07:00
										 |  |  | --- a/third_party/blink/renderer/core/frame/local_frame_client_impl.h
 | 
					
						
							|  |  |  | +++ b/third_party/blink/renderer/core/frame/local_frame_client_impl.h
 | 
					
						
							| 
									
										
										
										
											2022-10-27 12:37:04 -04:00
										 |  |  | @@ -82,6 +82,8 @@ class CORE_EXPORT LocalFrameClientImpl final : public LocalFrameClient {
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  |   | 
					
						
							|  |  |  |    void DidCreateScriptContext(v8::Local<v8::Context>, | 
					
						
							|  |  |  |                                int32_t world_id) override; | 
					
						
							|  |  |  | +  void DidInstallConditionalFeatures(v8::Local<v8::Context>,
 | 
					
						
							|  |  |  | +                                     int32_t world_id) override;
 | 
					
						
							|  |  |  |    void WillReleaseScriptContext(v8::Local<v8::Context>, | 
					
						
							|  |  |  |                                  int32_t world_id) override; | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | diff --git a/third_party/blink/renderer/core/loader/empty_clients.h b/third_party/blink/renderer/core/loader/empty_clients.h
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | index 163e228075b5c6a1dcdb33896570258e14f5b5b3..e0ca34b36b2d6b98f9394f4022645f084cae3a58 100644
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  | --- a/third_party/blink/renderer/core/loader/empty_clients.h
 | 
					
						
							|  |  |  | +++ b/third_party/blink/renderer/core/loader/empty_clients.h
 | 
					
						
							| 
									
										
										
										
											2023-02-03 12:43:42 +01:00
										 |  |  | @@ -373,6 +373,8 @@ class CORE_EXPORT EmptyLocalFrameClient : public LocalFrameClient {
 | 
					
						
							| 
									
										
										
										
											2020-02-07 09:45:13 -08:00
										 |  |  |   | 
					
						
							|  |  |  |    void DidCreateScriptContext(v8::Local<v8::Context>, | 
					
						
							|  |  |  |                                int32_t world_id) override {} | 
					
						
							|  |  |  | +  void DidInstallConditionalFeatures(v8::Local<v8::Context>,
 | 
					
						
							|  |  |  | +                                     int32_t world_id) override {}
 | 
					
						
							|  |  |  |    void WillReleaseScriptContext(v8::Local<v8::Context>, | 
					
						
							|  |  |  |                                  int32_t world_id) override {} | 
					
						
							|  |  |  |    bool AllowScriptExtensions() override { return false; } |