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 1b3b1b0b3f2b7956b750f559d461e2a41f343448..a716f751687d4b6bb218ae89a8d1e8d761136100 100644
- --- a/content/browser/web_contents/web_contents_impl.cc
- +++ b/content/browser/web_contents/web_contents_impl.cc
- @@ -3521,6 +3521,13 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params,
- params.main_frame_name, GetOpener(), primary_main_frame_policy,
- base::UnguessableToken::Create());
-
- + if (params.view && params.delegate_view) {
- + view_.reset(params.view);
- + render_view_host_delegate_view_ = params.delegate_view;
- + }
- +
- + if (!view_) {
- +
- std::unique_ptr<WebContentsViewDelegate> delegate =
- GetContentClient()->browser()->GetWebContentsViewDelegate(this);
-
- @@ -3531,6 +3538,7 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params,
- view_ = CreateWebContentsView(this, std::move(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 663230421212be4a77032357d2143b5990ae3dde..675e23583cb8abb5e1bebdb2a9804dd37b834b30 100644
- --- a/content/public/browser/web_contents.h
- +++ b/content/public/browser/web_contents.h
- @@ -104,10 +104,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;
- @@ -254,6 +257,10 @@ class WebContents : public PageNavigator,
- network::mojom::WebSandboxFlags starting_sandbox_flags =
- network::mojom::WebSandboxFlags::kNone;
-
- + // Optionally specify the view and delegate view.
- + raw_ptr<content::WebContentsView> view = nullptr;
- + raw_ptr<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
|