| 
									
										
										
										
											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-04-27 14:27:34 -07:00
										 |  |  | Date: Sat, 24 Apr 2021 18:07:09 -0700 | 
					
						
							| 
									
										
										
										
											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
 | 
					
						
							| 
									
										
										
										
											2024-08-22 13:16:40 -05:00
										 |  |  | index e3246011d776a8242530b117a55d0c909277a6d5..b35f23dd329f700eb85e5d206ac78cb0be4f2a19 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
 | 
					
						
							| 
									
										
										
										
											2024-08-22 13:16:40 -05:00
										 |  |  | @@ -3640,6 +3640,13 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params,
 | 
					
						
							| 
									
										
										
										
											2022-11-17 14:59:23 -05:00
										 |  |  |        params.main_frame_name, GetOpener(), primary_main_frame_policy, | 
					
						
							|  |  |  |        base::UnguessableToken::Create()); | 
					
						
							| 
									
										
										
										
											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_) {
 | 
					
						
							| 
									
										
										
										
											2022-01-10 17:31:39 -05:00
										 |  |  | +
 | 
					
						
							| 
									
										
										
										
											2022-05-17 12:48:40 -04:00
										 |  |  |    std::unique_ptr<WebContentsViewDelegate> delegate = | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  |        GetContentClient()->browser()->GetWebContentsViewDelegate(this); | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
										
										
											2024-08-22 13:16:40 -05:00
										 |  |  | @@ -3650,6 +3657,7 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params,
 | 
					
						
							| 
									
										
										
										
											2022-05-17 12:48:40 -04:00
										 |  |  |      view_ = CreateWebContentsView(this, std::move(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
 | 
					
						
							| 
									
										
										
										
											2024-08-22 13:16:40 -05:00
										 |  |  | index cb42c99bacb204ef9573b3845673971c72f0344a..5258c9f6b5a1be7e5aa4ee850adcbd3c7d3864f0 100644
 | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  | --- a/content/public/browser/web_contents.h
 | 
					
						
							|  |  |  | +++ b/content/public/browser/web_contents.h
 | 
					
						
							| 
									
										
										
										
											2024-07-02 09:51:33 +02:00
										 |  |  | @@ -109,10 +109,13 @@ 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;
 | 
					
						
							| 
									
										
										
										
											2021-05-19 16:15:47 -07:00
										 |  |  |  class ScreenOrientationDelegate; | 
					
						
							|  |  |  |  class SiteInstance; | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  |  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; | 
					
						
							| 
									
										
										
										
											2024-07-29 09:37:35 -04:00
										 |  |  | @@ -258,6 +261,10 @@ class WebContents : public PageNavigator, public base::SupportsUserData {
 | 
					
						
							| 
									
										
										
										
											2022-01-10 17:31:39 -05:00
										 |  |  |      network::mojom::WebSandboxFlags starting_sandbox_flags = | 
					
						
							|  |  |  |          network::mojom::WebSandboxFlags::kNone; | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  |   | 
					
						
							|  |  |  | +    // Optionally specify the view and delegate view.
 | 
					
						
							| 
									
										
										
										
											2023-05-11 16:07:39 -04:00
										 |  |  | +    raw_ptr<content::WebContentsView> view = nullptr;
 | 
					
						
							|  |  |  | +    raw_ptr<content::RenderViewHostDelegateView> delegate_view = nullptr;
 | 
					
						
							| 
									
										
										
										
											2018-09-13 22:02:16 -07:00
										 |  |  | +
 | 
					
						
							| 
									
										
										
										
											2020-04-13 16:39:26 -07:00
										 |  |  |      // Value used to set the last time the WebContents was made active, this is | 
					
						
							| 
									
										
										
										
											2024-08-08 17:16:59 -05:00
										 |  |  |      // the value that'll be returned by GetLastActiveTimeTicks(). If this is | 
					
						
							|  |  |  |      // left default initialized then the value is not passed on to the |