1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
- From: deepak1556 <[email protected]>
- Date: Sat, 24 Apr 2021 18:07:09 -0700
- Subject: web_contents.patch
- This allows overriding the RenderViewHostDelegateView of a WebContents, which
- is needed for OSR.
- Originally landed in https://github.com/electron/libchromiumcontent/pull/226.
- diff --git a/content/browser/web_contents/web_contents_impl.cc b/content/browser/web_contents/web_contents_impl.cc
- index 74e6928041145fd6f37ec4ce7acc6be0649b944d..3eaf29f3ab74de6159bba1578ba0810bd9467922 100644
- --- a/content/browser/web_contents/web_contents_impl.cc
- +++ b/content/browser/web_contents/web_contents_impl.cc
- @@ -2983,6 +2983,13 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params,
- site_instance.get(), params.renderer_initiated_creation,
- params.main_frame_name, GetOriginalOpener(), primary_main_frame_policy);
-
- + if (params.view && params.delegate_view) {
- + view_.reset(params.view);
- + render_view_host_delegate_view_ = params.delegate_view;
- + }
- +
- + if (!view_) {
- +
- WebContentsViewDelegate* delegate =
- GetContentClient()->browser()->GetWebContentsViewDelegate(this);
-
- @@ -2993,6 +3000,7 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params,
- view_.reset(CreateWebContentsView(this, delegate,
- &render_view_host_delegate_view_));
- }
- + } // !view_
- CHECK(render_view_host_delegate_view_);
- CHECK(view_.get());
-
- diff --git a/content/public/browser/web_contents.h b/content/public/browser/web_contents.h
- index 1b21d5241ea671e4ead260f170e6a0512efea89a..ac9bce453ff812679d8c77d661729ea681977061 100644
- --- a/content/public/browser/web_contents.h
- +++ b/content/public/browser/web_contents.h
- @@ -93,10 +93,13 @@ class BrowserContext;
- class BrowserPluginGuestDelegate;
- class RenderFrameHost;
- class RenderViewHost;
- +class RenderViewHostDelegateView;
- class RenderWidgetHostView;
- +class RenderWidgetHostViewBase;
- class ScreenOrientationDelegate;
- class SiteInstance;
- class WebContentsDelegate;
- +class WebContentsView;
- class WebUI;
- struct DropData;
- struct MHTMLGenerationParams;
- @@ -234,6 +237,10 @@ class WebContents : public PageNavigator,
- network::mojom::WebSandboxFlags starting_sandbox_flags =
- network::mojom::WebSandboxFlags::kNone;
-
- + // Optionally specify the view and delegate view.
- + content::WebContentsView* view = nullptr;
- + content::RenderViewHostDelegateView* delegate_view = nullptr;
- +
- // Value used to set the last time the WebContents was made active, this is
- // the value that'll be returned by GetLastActiveTime(). If this is left
- // default initialized then the value is not passed on to the WebContents
|