Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1314)

Unified Diff: content/browser/renderer_host/render_message_filter.cc

Issue 2363573002: Move ViewHostMsg_CreateWindow to mojom (Closed)
Patch Set: . Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/browser/renderer_host/render_message_filter.cc
diff --git a/content/browser/renderer_host/render_message_filter.cc b/content/browser/renderer_host/render_message_filter.cc
index 29b8c8a1a9020d17e256e28e6c51e813e8c08fe2..6679aaf43c651887f89dcb1bdce654e8b2ee230a 100644
--- a/content/browser/renderer_host/render_message_filter.cc
+++ b/content/browser/renderer_host/render_message_filter.cc
@@ -44,6 +44,7 @@
#include "content/common/child_process_messages.h"
#include "content/common/content_constants_internal.h"
#include "content/common/host_shared_bitmap_manager.h"
+#include "content/common/render_message_filter.mojom.h"
#include "content/common/render_process_messages.h"
#include "content/common/view_messages.h"
#include "content/public/browser/browser_child_process_host.h"
@@ -166,7 +167,6 @@ RenderMessageFilter::~RenderMessageFilter() {
bool RenderMessageFilter::OnMessageReceived(const IPC::Message& message) {
bool handled = true;
IPC_BEGIN_MESSAGE_MAP(RenderMessageFilter, message)
- IPC_MESSAGE_HANDLER(ViewHostMsg_CreateWindow, OnCreateWindow)
IPC_MESSAGE_HANDLER(ViewHostMsg_CreateWidget, OnCreateWidget)
IPC_MESSAGE_HANDLER(ViewHostMsg_CreateFullscreenWidget,
OnCreateFullscreenWidget)
@@ -240,64 +240,65 @@ void RenderMessageFilter::OverrideThreadForMessage(const IPC::Message& message,
*thread = BrowserThread::UI;
}
-void RenderMessageFilter::OnCreateWindow(
- const ViewHostMsg_CreateWindow_Params& params,
- ViewHostMsg_CreateWindow_Reply* reply) {
- bool no_javascript_access;
+void RenderMessageFilter::OnCreateWidget(int opener_id,
+ blink::WebPopupType popup_type,
+ int* route_id) {
+ render_widget_helper_->CreateNewWidget(opener_id, popup_type, route_id);
+}
+void RenderMessageFilter::OnCreateFullscreenWidget(int opener_id,
+ int* route_id) {
+ render_widget_helper_->CreateNewFullscreenWidget(opener_id, route_id);
+}
+
+void RenderMessageFilter::GenerateRoutingID(
+ const GenerateRoutingIDCallback& callback) {
+ callback.Run(render_widget_helper_->GetNextRoutingID());
+}
+
+void RenderMessageFilter::CreateNewWindow(
+ mojom::CreateNewWindowParamsPtr params,
+ const CreateNewWindowCallback& callback) {
+ bool no_javascript_access;
bool can_create_window =
GetContentClient()->browser()->CanCreateWindow(
- params.opener_url,
- params.opener_top_level_frame_url,
- params.opener_security_origin,
- params.window_container_type,
- params.target_url,
- params.referrer,
- params.frame_name,
- params.disposition,
- params.features,
- params.user_gesture,
- params.opener_suppressed,
+ params->opener_url,
+ params->opener_top_level_frame_url,
+ params->opener_security_origin,
+ params->window_container_type,
+ params->target_url,
+ params->referrer,
+ params->frame_name,
+ params->disposition,
+ params->features,
+ params->user_gesture,
+ params->opener_suppressed,
resource_context_,
render_process_id_,
- params.opener_id,
- params.opener_render_frame_id,
+ params->opener_id,
+ params->opener_render_frame_id,
&no_javascript_access);
+ mojom::CreateNewWindowReplyPtr reply = mojom::CreateNewWindowReply::New();
if (!can_create_window) {
reply->route_id = MSG_ROUTING_NONE;
reply->main_frame_route_id = MSG_ROUTING_NONE;
reply->main_frame_widget_route_id = MSG_ROUTING_NONE;
reply->cloned_session_storage_namespace_id = 0;
- return;
+ return callback.Run(std::move(reply));
}
// This will clone the sessionStorage for namespace_id_to_clone.
scoped_refptr<SessionStorageNamespaceImpl> cloned_namespace =
new SessionStorageNamespaceImpl(dom_storage_context_.get(),
- params.session_storage_namespace_id);
+ params->session_storage_namespace_id);
reply->cloned_session_storage_namespace_id = cloned_namespace->id();
render_widget_helper_->CreateNewWindow(
- params, no_javascript_access, PeerHandle(), &reply->route_id,
+ std::move(params), no_javascript_access, PeerHandle(), &reply->route_id,
&reply->main_frame_route_id, &reply->main_frame_widget_route_id,
cloned_namespace.get());
-}
-
-void RenderMessageFilter::OnCreateWidget(int opener_id,
- blink::WebPopupType popup_type,
- int* route_id) {
- render_widget_helper_->CreateNewWidget(opener_id, popup_type, route_id);
-}
-
-void RenderMessageFilter::OnCreateFullscreenWidget(int opener_id,
- int* route_id) {
- render_widget_helper_->CreateNewFullscreenWidget(opener_id, route_id);
-}
-
-void RenderMessageFilter::GenerateRoutingID(
- const GenerateRoutingIDCallback& callback) {
- callback.Run(render_widget_helper_->GetNextRoutingID());
+ callback.Run(std::move(reply));
ncarter (slow) 2016/09/27 20:32:41 Can we now guarantee that the task posted to the U
Ken Rockot(use gerrit already) 2016/09/27 21:05:41 Yes. Any interfaces (such as mojom::RenderMessageF
ncarter (slow) 2016/09/27 22:47:52 Thanks, and awesome that we have this safety guara
}
#if defined(OS_MACOSX)

Powered by Google App Engine
This is Rietveld 408576698