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

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

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