diff --git a/patches/common/chromium/.patches b/patches/common/chromium/.patches index 2a0f2a1df..84989b9fc 100644 --- a/patches/common/chromium/.patches +++ b/patches/common/chromium/.patches @@ -26,7 +26,6 @@ web_contents.patch webgl_context_attributes.patch webview_cross_drag.patch worker_context_will_destroy.patch -webui_in_subframes.patch browser_plugin_guest.patch disable_user_gesture_requirement_for_beforeunload_dialogs.patch add_atomic_lib_to_dependencies_even_for_sysroot_builds.patch diff --git a/patches/common/chromium/webui_in_subframes.patch b/patches/common/chromium/webui_in_subframes.patch deleted file mode 100644 index a604a7f08..000000000 --- a/patches/common/chromium/webui_in_subframes.patch +++ /dev/null @@ -1,142 +0,0 @@ -From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 -From: Anonymous -Date: Thu, 20 Sep 2018 17:47:15 -0700 -Subject: webui_in_subframes.patch - - -diff --git a/content/browser/frame_host/render_frame_host_delegate.cc b/content/browser/frame_host/render_frame_host_delegate.cc -index 26b8eec2bb763c6a1e29309abe34c4c068eee609..fb3843168f14fa7b584e2ec52f1c1495aa7dd070 100644 ---- a/content/browser/frame_host/render_frame_host_delegate.cc -+++ b/content/browser/frame_host/render_frame_host_delegate.cc -@@ -99,7 +99,9 @@ RenderFrameHostDelegate::GetFocusedFrameIncludingInnerWebContents() { - } - - std::unique_ptr --RenderFrameHostDelegate::CreateWebUIForRenderFrameHost(const GURL& url) { -+RenderFrameHostDelegate::CreateWebUIForRenderFrameHost( -+ const GURL& url, -+ const std::string& frame_name) { - return nullptr; - } - -diff --git a/content/browser/frame_host/render_frame_host_delegate.h b/content/browser/frame_host/render_frame_host_delegate.h -index 7919ac1e579592815fa96e88f30537c51b110fa9..03f33191521354031357a4886fe7ef3417ba17b6 100644 ---- a/content/browser/frame_host/render_frame_host_delegate.h -+++ b/content/browser/frame_host/render_frame_host_delegate.h -@@ -278,7 +278,8 @@ class CONTENT_EXPORT RenderFrameHostDelegate { - // Creates a WebUI object for a frame navigating to |url|. If no WebUI - // applies, returns null. - virtual std::unique_ptr CreateWebUIForRenderFrameHost( -- const GURL& url); -+ const GURL& url, -+ const std::string& frame_name); - - // Called by |frame| to notify that it has received an update on focused - // element. |bounds_in_root_view| is the rectangle containing the element that -diff --git a/content/browser/frame_host/render_frame_host_impl.cc b/content/browser/frame_host/render_frame_host_impl.cc -index 783dc705f748bc6c9d3b8630ce12ad39ff2fd7d2..9fa14c824032463cedbbf5db41f1dbe3490c4a69 100644 ---- a/content/browser/frame_host/render_frame_host_impl.cc -+++ b/content/browser/frame_host/render_frame_host_impl.cc -@@ -26,6 +26,7 @@ - #include "base/task_scheduler/post_task.h" - #include "base/threading/thread_task_runner_handle.h" - #include "base/time/time.h" -+#include "base/unguessable_token.h" - #include "build/build_config.h" - #include "cc/base/switches.h" - #include "content/browser/accessibility/browser_accessibility_manager.h" -@@ -4314,8 +4315,23 @@ bool RenderFrameHostImpl::UpdatePendingWebUI(const GURL& dest_url, - DCHECK(web_ui_); - should_reuse_web_ui_ = true; - } else { -+ // Give the frame a name if it does not already have one. -+ // The reason is web ui code base the frame look up on the frame name. -+ std::string frame_name = GetFrameName(); -+ if (frame_name.empty() && !frame_tree_node_->IsMainFrame()) { -+ frame_name = base::StringPrintf("frame_%i", frame_tree_node_->frame_tree_node_id()); -+ frame_tree_node_->SetFrameName( -+ frame_name, frame_name + base::UnguessableToken::Create().ToString()); -+ } -+ -+ // If the web ui is in subframes, the parent frame bindings does not have the web ui binding, -+ // so we reset the bindings for the subframes. -+ if (!frame_tree_node_->IsMainFrame() && new_web_ui_type != WebUI::kNoWebUI) { -+ entry_bindings = NavigationEntryImpl::kInvalidBindings; -+ } -+ - // Otherwise create a new pending WebUI. -- pending_web_ui_ = delegate_->CreateWebUIForRenderFrameHost(dest_url); -+ pending_web_ui_ = delegate_->CreateWebUIForRenderFrameHost(dest_url, frame_name); - DCHECK(pending_web_ui_); - pending_web_ui_type_ = new_web_ui_type; - -diff --git a/content/browser/web_contents/web_contents_impl.cc b/content/browser/web_contents/web_contents_impl.cc -index 64ad6ca91d9331a09d09f7e29b7c24a0c12852a2..88211169a7d731cb805f34c48ae4caf2fdcd1c84 100644 ---- a/content/browser/web_contents/web_contents_impl.cc -+++ b/content/browser/web_contents/web_contents_impl.cc -@@ -788,6 +788,25 @@ RenderFrameHostManager* WebContentsImpl::GetRenderManagerForTesting() { - return GetRenderManager(); - } - -+void SendMessageToFrameTreeWebUIs(RenderFrameHostImpl* parent_frame_host, -+ const IPC::Message& message, -+ int& dispatch_count) { -+ // Get the web ui or the pending one if it's not yet commited. -+ WebUIImpl* web_ui = parent_frame_host->web_ui() -+ ? parent_frame_host->web_ui() -+ : parent_frame_host->pending_web_ui(); -+ if (web_ui && web_ui->OnMessageReceived(message, parent_frame_host)) { -+ ++dispatch_count; -+ } -+ -+ size_t child_count = parent_frame_host->frame_tree_node()->child_count(); -+ for (size_t i = 0; i < child_count; ++i) { -+ RenderFrameHostImpl* sub_frame_host = -+ parent_frame_host->frame_tree_node()->child_at(i)->current_frame_host(); -+ SendMessageToFrameTreeWebUIs(sub_frame_host, message, dispatch_count); -+ } -+} -+ - bool WebContentsImpl::OnMessageReceived(RenderViewHostImpl* render_view_host, - const IPC::Message& message) { - for (auto& observer : observers_) { -@@ -823,9 +842,10 @@ bool WebContentsImpl::OnMessageReceived(RenderViewHostImpl* render_view_host, - - bool WebContentsImpl::OnMessageReceived(RenderFrameHostImpl* render_frame_host, - const IPC::Message& message) { -- { -- WebUIImpl* web_ui = render_frame_host->web_ui(); -- if (web_ui && web_ui->OnMessageReceived(message, render_frame_host)) -+ int dispatch_count = 0; -+ if (render_frame_host) { -+ SendMessageToFrameTreeWebUIs(render_frame_host, message, dispatch_count); -+ if (dispatch_count > 0) - return true; - } - -@@ -5974,8 +5994,9 @@ NavigationControllerImpl& WebContentsImpl::GetControllerForRenderManager() { - } - - std::unique_ptr WebContentsImpl::CreateWebUIForRenderFrameHost( -- const GURL& url) { -- return CreateWebUI(url); -+ const GURL& url, -+ const std::string& frame_name) { -+ return CreateWebUI(url/*, frame_name*/); - } - - NavigationEntry* -diff --git a/content/browser/web_contents/web_contents_impl.h b/content/browser/web_contents/web_contents_impl.h -index d16a99122772385e6fcdb13a8080c82ee0695232..907738e0bf80e4a34c5f068e67a6ba15d5d8338d 100644 ---- a/content/browser/web_contents/web_contents_impl.h -+++ b/content/browser/web_contents/web_contents_impl.h -@@ -542,7 +542,8 @@ class CONTENT_EXPORT WebContentsImpl : public WebContents, - SiteInstance* source_site_instance) const override; - void EnsureOpenerProxiesExist(RenderFrameHost* source_rfh) override; - std::unique_ptr CreateWebUIForRenderFrameHost( -- const GURL& url) override; -+ const GURL& url, -+ const std::string& frame_name) override; - void SetFocusedFrame(FrameTreeNode* node, SiteInstance* source) override; - void DidCallFocus() override; - RenderFrameHost* GetFocusedFrameIncludingInnerWebContents() override;