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

Side by Side Diff: content/browser/devtools/render_view_devtools_agent_host.cc

Issue 508973003: DevTools: Protocol handler generator for content (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Allow command->params()==NULL Created 6 years, 2 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "content/browser/devtools/render_view_devtools_agent_host.h" 5 #include "content/browser/devtools/render_view_devtools_agent_host.h"
6 6
7 #include "base/basictypes.h" 7 #include "base/basictypes.h"
8 #include "base/lazy_instance.h" 8 #include "base/lazy_instance.h"
9 #include "base/strings/utf_string_conversions.h" 9 #include "base/strings/utf_string_conversions.h"
10 #include "content/browser/child_process_security_policy_impl.h" 10 #include "content/browser/child_process_security_policy_impl.h"
11 #include "content/browser/devtools/devtools_manager.h" 11 #include "content/browser/devtools/devtools_manager.h"
12 #include "content/browser/devtools/devtools_power_handler.h" 12 #include "content/browser/devtools/devtools_power_handler.h"
13 #include "content/browser/devtools/devtools_protocol.h" 13 #include "content/browser/devtools/devtools_protocol.h"
14 #include "content/browser/devtools/devtools_protocol_constants.h" 14 #include "content/browser/devtools/devtools_protocol_constants.h"
15 #include "content/browser/devtools/devtools_tracing_handler.h" 15 #include "content/browser/devtools/devtools_tracing_handler.h"
16 #include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
16 #include "content/browser/devtools/renderer_overrides_handler.h" 17 #include "content/browser/devtools/renderer_overrides_handler.h"
17 #include "content/browser/renderer_host/render_process_host_impl.h" 18 #include "content/browser/renderer_host/render_process_host_impl.h"
18 #include "content/browser/renderer_host/render_view_host_impl.h" 19 #include "content/browser/renderer_host/render_view_host_impl.h"
19 #include "content/browser/site_instance_impl.h" 20 #include "content/browser/site_instance_impl.h"
20 #include "content/browser/web_contents/web_contents_impl.h" 21 #include "content/browser/web_contents/web_contents_impl.h"
21 #include "content/common/devtools_messages.h" 22 #include "content/common/devtools_messages.h"
22 #include "content/common/view_messages.h" 23 #include "content/common/view_messages.h"
23 #include "content/public/browser/content_browser_client.h" 24 #include "content/public/browser/content_browser_client.h"
24 #include "content/public/browser/devtools_manager_delegate.h" 25 #include "content/public/browser/devtools_manager_delegate.h"
25 #include "content/public/browser/notification_service.h" 26 #include "content/public/browser/notification_service.h"
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after
102 WebContents* web_contents = WebContents::FromRenderViewHost(pending); 103 WebContents* web_contents = WebContents::FromRenderViewHost(pending);
103 RenderViewDevToolsAgentHost* agent_host = FindAgentHost(web_contents); 104 RenderViewDevToolsAgentHost* agent_host = FindAgentHost(web_contents);
104 if (!agent_host) 105 if (!agent_host)
105 return; 106 return;
106 agent_host->DisconnectRenderViewHost(); 107 agent_host->DisconnectRenderViewHost();
107 agent_host->ConnectRenderViewHost(current); 108 agent_host->ConnectRenderViewHost(current);
108 } 109 }
109 110
110 RenderViewDevToolsAgentHost::RenderViewDevToolsAgentHost(RenderViewHost* rvh) 111 RenderViewDevToolsAgentHost::RenderViewDevToolsAgentHost(RenderViewHost* rvh)
111 : render_view_host_(NULL), 112 : render_view_host_(NULL),
113 input_handler_(new devtools::input::InputHandler()),
114 page_handler_(new devtools::page::PageHandler()),
115 handler_impl_(new DevToolsProtocolHandlerImpl()),
112 overrides_handler_(new RendererOverridesHandler()), 116 overrides_handler_(new RendererOverridesHandler()),
113 tracing_handler_( 117 tracing_handler_(
114 new DevToolsTracingHandler(DevToolsTracingHandler::Renderer)), 118 new DevToolsTracingHandler(DevToolsTracingHandler::Renderer)),
115 power_handler_(new DevToolsPowerHandler()), 119 power_handler_(new DevToolsPowerHandler()),
116 reattaching_(false) { 120 reattaching_(false) {
121 handler_impl_->SetInputHandler(input_handler_.get());
122 handler_impl_->SetPageHandler(page_handler_.get());
117 SetRenderViewHost(rvh); 123 SetRenderViewHost(rvh);
118 DevToolsProtocol::Notifier notifier(base::Bind( 124 DevToolsProtocol::Notifier notifier(base::Bind(
119 &RenderViewDevToolsAgentHost::OnDispatchOnInspectorFrontend, 125 &RenderViewDevToolsAgentHost::OnDispatchOnInspectorFrontend,
120 base::Unretained(this))); 126 base::Unretained(this)));
127 handler_impl_->SetNotifier(notifier);
121 overrides_handler_->SetNotifier(notifier); 128 overrides_handler_->SetNotifier(notifier);
122 tracing_handler_->SetNotifier(notifier); 129 tracing_handler_->SetNotifier(notifier);
123 power_handler_->SetNotifier(notifier); 130 power_handler_->SetNotifier(notifier);
124 g_instances.Get().push_back(this); 131 g_instances.Get().push_back(this);
125 AddRef(); // Balanced in RenderViewHostDestroyed. 132 AddRef(); // Balanced in RenderViewHostDestroyed.
126 } 133 }
127 134
128 WebContents* RenderViewDevToolsAgentHost::GetWebContents() { 135 WebContents* RenderViewDevToolsAgentHost::GetWebContents() {
129 return web_contents(); 136 return web_contents();
130 } 137 }
(...skipping 18 matching lines...) Expand all
149 if (overridden_response_value) 156 if (overridden_response_value)
150 overridden_response = DevToolsProtocol::ParseResponse( 157 overridden_response = DevToolsProtocol::ParseResponse(
151 overridden_response_value.get()); 158 overridden_response_value.get());
152 } 159 }
153 if (!overridden_response.get()) 160 if (!overridden_response.get())
154 overridden_response = overrides_handler_->HandleCommand(command); 161 overridden_response = overrides_handler_->HandleCommand(command);
155 if (!overridden_response.get()) 162 if (!overridden_response.get())
156 overridden_response = tracing_handler_->HandleCommand(command); 163 overridden_response = tracing_handler_->HandleCommand(command);
157 if (!overridden_response.get()) 164 if (!overridden_response.get())
158 overridden_response = power_handler_->HandleCommand(command); 165 overridden_response = power_handler_->HandleCommand(command);
166 if (!overridden_response.get())
167 overridden_response = handler_impl_->HandleCommand(command);
159 if (overridden_response.get()) { 168 if (overridden_response.get()) {
160 if (!overridden_response->is_async_promise()) 169 if (!overridden_response->is_async_promise())
161 OnDispatchOnInspectorFrontend(overridden_response->Serialize()); 170 OnDispatchOnInspectorFrontend(overridden_response->Serialize());
162 return; 171 return;
163 } 172 }
164 } 173 }
165 174
166 IPCDevToolsAgentHost::DispatchProtocolMessage(message); 175 IPCDevToolsAgentHost::DispatchProtocolMessage(message);
167 } 176 }
168 177
(...skipping 178 matching lines...) Expand 10 before | Expand all | Expand 10 after
347 overrides_handler_->OnVisibilityChanged(visible); 356 overrides_handler_->OnVisibilityChanged(visible);
348 } 357 }
349 } 358 }
350 359
351 void RenderViewDevToolsAgentHost::SetRenderViewHost(RenderViewHost* rvh) { 360 void RenderViewDevToolsAgentHost::SetRenderViewHost(RenderViewHost* rvh) {
352 DCHECK(!render_view_host_); 361 DCHECK(!render_view_host_);
353 render_view_host_ = static_cast<RenderViewHostImpl*>(rvh); 362 render_view_host_ = static_cast<RenderViewHostImpl*>(rvh);
354 363
355 WebContentsObserver::Observe(WebContents::FromRenderViewHost(rvh)); 364 WebContentsObserver::Observe(WebContents::FromRenderViewHost(rvh));
356 overrides_handler_->SetRenderViewHost(render_view_host_); 365 overrides_handler_->SetRenderViewHost(render_view_host_);
366 input_handler_->SetRenderViewHost(render_view_host_);
367 page_handler_->SetRenderViewHost(render_view_host_);
357 368
358 registrar_.Add( 369 registrar_.Add(
359 this, 370 this,
360 content::NOTIFICATION_RENDER_WIDGET_VISIBILITY_CHANGED, 371 content::NOTIFICATION_RENDER_WIDGET_VISIBILITY_CHANGED,
361 content::Source<RenderWidgetHost>(render_view_host_)); 372 content::Source<RenderWidgetHost>(render_view_host_));
362 } 373 }
363 374
364 void RenderViewDevToolsAgentHost::ClearRenderViewHost() { 375 void RenderViewDevToolsAgentHost::ClearRenderViewHost() {
365 DCHECK(render_view_host_); 376 DCHECK(render_view_host_);
366 registrar_.Remove( 377 registrar_.Remove(
367 this, 378 this,
368 content::NOTIFICATION_RENDER_WIDGET_VISIBILITY_CHANGED, 379 content::NOTIFICATION_RENDER_WIDGET_VISIBILITY_CHANGED,
369 content::Source<RenderWidgetHost>(render_view_host_)); 380 content::Source<RenderWidgetHost>(render_view_host_));
370 render_view_host_ = NULL; 381 render_view_host_ = NULL;
371 overrides_handler_->ClearRenderViewHost(); 382 overrides_handler_->ClearRenderViewHost();
383 input_handler_->SetRenderViewHost(NULL);
384 page_handler_->SetRenderViewHost(NULL);
372 } 385 }
373 386
374 void RenderViewDevToolsAgentHost::DisconnectWebContents() { 387 void RenderViewDevToolsAgentHost::DisconnectWebContents() {
375 DisconnectRenderViewHost(); 388 DisconnectRenderViewHost();
376 } 389 }
377 390
378 void RenderViewDevToolsAgentHost::ConnectWebContents(WebContents* wc) { 391 void RenderViewDevToolsAgentHost::ConnectWebContents(WebContents* wc) {
379 ConnectRenderViewHost(wc->GetRenderViewHost()); 392 ConnectRenderViewHost(wc->GetRenderViewHost());
380 } 393 }
381 394
(...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after
471 } 484 }
472 485
473 void RenderViewDevToolsAgentHost::OnDispatchOnInspectorFrontend( 486 void RenderViewDevToolsAgentHost::OnDispatchOnInspectorFrontend(
474 const std::string& message) { 487 const std::string& message) {
475 if (!render_view_host_) 488 if (!render_view_host_)
476 return; 489 return;
477 SendMessageToClient(message); 490 SendMessageToClient(message);
478 } 491 }
479 492
480 } // namespace content 493 } // namespace content
OLDNEW
« no previous file with comments | « content/browser/devtools/render_view_devtools_agent_host.h ('k') | content/browser/devtools/renderer_overrides_handler.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698