| 
									
										
										
										
											2018-10-24 11:24:11 -07:00
										 |  |  | From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | 
					
						
							| 
									
										
										
										
											2020-04-13 16:39:26 -07:00
										 |  |  | From: deepak1556 <hop2deep@gmail.com> | 
					
						
							| 
									
										
										
										
											2021-02-09 12:16:21 -08:00
										 |  |  | Date: Wed, 27 Jan 2021 15:11:19 -0800 | 
					
						
							| 
									
										
										
										
											2018-09-20 17:30:26 -07:00
										 |  |  | Subject: web_contents.patch | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-13 09:18:45 -08:00
										 |  |  | This allows overriding the RenderViewHostDelegateView of a WebContents, which | 
					
						
							|  |  |  | is needed for OSR. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Originally landed in https://github.com/electron/libchromiumcontent/pull/226. | 
					
						
							| 
									
										
										
										
											2018-09-20 17:30:26 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  | diff --git a/content/browser/web_contents/web_contents_impl.cc b/content/browser/web_contents/web_contents_impl.cc
 | 
					
						
							| 
									
										
										
										
											2021-03-04 09:27:05 -08:00
										 |  |  | index e137e4e16941a539346cd248a51c872159765d32..5c06f5d680357028cffa00f3dfdc17ff02a4a560 100644
 | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  | --- a/content/browser/web_contents/web_contents_impl.cc
 | 
					
						
							|  |  |  | +++ b/content/browser/web_contents/web_contents_impl.cc
 | 
					
						
							| 
									
										
										
										
											2021-03-04 09:27:05 -08:00
										 |  |  | @@ -2734,6 +2734,12 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params) {
 | 
					
						
							| 
									
										
										
										
											2021-02-09 12:16:21 -08:00
										 |  |  |    frame_tree_.Init(site_instance.get(), params.renderer_initiated_creation, | 
					
						
							|  |  |  |                     params.main_frame_name); | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  |   | 
					
						
							|  |  |  | +  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); | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
										
										
											2021-03-04 09:27:05 -08:00
										 |  |  | @@ -2744,6 +2750,7 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params) {
 | 
					
						
							| 
									
										
										
										
											2019-12-10 16:22:35 -08:00
										 |  |  |      view_.reset(CreateWebContentsView(this, delegate, | 
					
						
							|  |  |  |                                        &render_view_host_delegate_view_)); | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  |    } | 
					
						
							| 
									
										
										
										
											2021-02-09 12:16:21 -08:00
										 |  |  | +  }  // !view_
 | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  |    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
 | 
					
						
							| 
									
										
										
										
											2021-03-04 09:27:05 -08:00
										 |  |  | index 8a913c6aa050fce21b71a0b493abb6c90d2f2931..79af85209da3ca2d6eb7bc27f97e5becad7312e4 100644
 | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  | --- a/content/public/browser/web_contents.h
 | 
					
						
							|  |  |  | +++ b/content/public/browser/web_contents.h
 | 
					
						
							| 
									
										
										
										
											2021-03-04 09:27:05 -08:00
										 |  |  | @@ -87,8 +87,11 @@ class BrowserContext;
 | 
					
						
							| 
									
										
										
										
											2020-05-26 13:06:26 -07:00
										 |  |  |  class BrowserPluginGuestDelegate; | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  |  class RenderFrameHost; | 
					
						
							|  |  |  |  class RenderViewHost; | 
					
						
							|  |  |  | +class RenderViewHostDelegateView;
 | 
					
						
							|  |  |  |  class RenderWidgetHostView; | 
					
						
							|  |  |  | +class RenderWidgetHostViewBase;
 | 
					
						
							|  |  |  |  class WebContentsDelegate; | 
					
						
							|  |  |  | +class WebContentsView;
 | 
					
						
							| 
									
										
										
										
											2020-03-03 13:35:05 -08:00
										 |  |  |  class WebUI; | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  |  struct DropData; | 
					
						
							| 
									
										
										
										
											2021-02-09 12:16:21 -08:00
										 |  |  |  struct MHTMLGenerationParams; | 
					
						
							| 
									
										
										
										
											2021-03-04 09:27:05 -08:00
										 |  |  | @@ -221,6 +224,10 @@ class WebContents : public PageNavigator,
 | 
					
						
							| 
									
										
										
										
											2020-04-13 16:39:26 -07:00
										 |  |  |      // Sandboxing flags set on the new WebContents. | 
					
						
							|  |  |  |      network::mojom::WebSandboxFlags starting_sandbox_flags; | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  |   | 
					
						
							|  |  |  | +    // Optionally specify the view and delegate view.
 | 
					
						
							|  |  |  | +    content::WebContentsView* view = nullptr;
 | 
					
						
							|  |  |  | +    content::RenderViewHostDelegateView* delegate_view = nullptr;
 | 
					
						
							|  |  |  | +
 | 
					
						
							| 
									
										
										
										
											2020-04-13 16:39:26 -07:00
										 |  |  |      // 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 |