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

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

Issue 182993003: Add the ability for DevTools to wrap network transactions. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Added optional QUIC setup in HttpCache constructor Created 6 years, 9 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 | Annotate | Revision Log
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 "content/browser/child_process_security_policy_impl.h" 9 #include "content/browser/child_process_security_policy_impl.h"
10 #include "content/browser/devtools/devtools_manager_impl.h" 10 #include "content/browser/devtools/devtools_manager_impl.h"
(...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after
134 const IPC::Message& message) { 134 const IPC::Message& message) {
135 RenderViewDevToolsAgentHost* agent_host = FindAgentHost(source); 135 RenderViewDevToolsAgentHost* agent_host = FindAgentHost(source);
136 return agent_host && agent_host->DispatchIPCMessage(message); 136 return agent_host && agent_host->DispatchIPCMessage(message);
137 } 137 }
138 138
139 RenderViewDevToolsAgentHost::RenderViewDevToolsAgentHost( 139 RenderViewDevToolsAgentHost::RenderViewDevToolsAgentHost(
140 RenderViewHost* rvh) 140 RenderViewHost* rvh)
141 : render_view_host_(NULL), 141 : render_view_host_(NULL),
142 overrides_handler_(new RendererOverridesHandler(this)), 142 overrides_handler_(new RendererOverridesHandler(this)),
143 tracing_handler_(new DevToolsTracingHandler()), 143 tracing_handler_(new DevToolsTracingHandler()),
144 power_handler_(new DevToolsPowerHandler()) 144 power_handler_(new DevToolsPowerHandler()),
145 network_disabled_(false)
145 { 146 {
146 SetRenderViewHost(rvh); 147 SetRenderViewHost(rvh);
147 DevToolsProtocol::Notifier notifier(base::Bind( 148 DevToolsProtocol::Notifier notifier(base::Bind(
148 &RenderViewDevToolsAgentHost::OnDispatchOnInspectorFrontend, 149 &RenderViewDevToolsAgentHost::OnDispatchOnInspectorFrontend,
149 base::Unretained(this))); 150 base::Unretained(this)));
150 overrides_handler_->SetNotifier(notifier); 151 overrides_handler_->SetNotifier(notifier);
151 tracing_handler_->SetNotifier(notifier); 152 tracing_handler_->SetNotifier(notifier);
152 power_handler_->SetNotifier(notifier); 153 power_handler_->SetNotifier(notifier);
153 g_instances.Get().push_back(this); 154 g_instances.Get().push_back(this);
154 AddRef(); // Balanced in RenderViewHostDestroyed. 155 AddRef(); // Balanced in RenderViewHostDestroyed.
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
192 if (!render_view_host_) 193 if (!render_view_host_)
193 return; 194 return;
194 195
195 ChildProcessSecurityPolicyImpl::GetInstance()->GrantReadRawCookies( 196 ChildProcessSecurityPolicyImpl::GetInstance()->GrantReadRawCookies(
196 render_view_host_->GetProcess()->GetID()); 197 render_view_host_->GetProcess()->GetID());
197 198
198 // TODO(kaznacheev): Move this call back to DevToolsManagerImpl when 199 // TODO(kaznacheev): Move this call back to DevToolsManagerImpl when
199 // extensions::ProcessManager no longer relies on this notification. 200 // extensions::ProcessManager no longer relies on this notification.
200 DevToolsManagerImpl::GetInstance()->NotifyObservers(this, true); 201 DevToolsManagerImpl::GetInstance()->NotifyObservers(this, true);
201 202
203 UpdateNetworkState(network_disabled_);
204
202 #if defined(OS_ANDROID) 205 #if defined(OS_ANDROID)
203 power_save_blocker_.reset( 206 power_save_blocker_.reset(
204 static_cast<PowerSaveBlockerImpl*>( 207 static_cast<PowerSaveBlockerImpl*>(
205 PowerSaveBlocker::Create( 208 PowerSaveBlocker::Create(
206 PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep, 209 PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep,
207 "DevTools").release())); 210 "DevTools").release()));
208 if (render_view_host_->GetView()) { 211 if (render_view_host_->GetView()) {
209 power_save_blocker_.get()-> 212 power_save_blocker_.get()->
210 InitDisplaySleepBlocker(render_view_host_->GetView()->GetNativeView()); 213 InitDisplaySleepBlocker(render_view_host_->GetView()->GetNativeView());
211 } 214 }
212 #endif 215 #endif
213 } 216 }
214 217
215 void RenderViewDevToolsAgentHost::OnClientDetached() { 218 void RenderViewDevToolsAgentHost::OnClientDetached() {
216 #if defined(OS_ANDROID) 219 #if defined(OS_ANDROID)
217 power_save_blocker_.reset(); 220 power_save_blocker_.reset();
218 #endif 221 #endif
222 UpdateNetworkState(false);
223
219 overrides_handler_->OnClientDetached(); 224 overrides_handler_->OnClientDetached();
220 ClientDetachedFromRenderer(); 225 ClientDetachedFromRenderer();
221 } 226 }
222 227
223 void RenderViewDevToolsAgentHost::ClientDetachedFromRenderer() { 228 void RenderViewDevToolsAgentHost::ClientDetachedFromRenderer() {
224 if (!render_view_host_) 229 if (!render_view_host_)
225 return; 230 return;
226 231
227 bool process_has_agents = false; 232 bool process_has_agents = false;
228 RenderProcessHost* render_process_host = render_view_host_->GetProcess(); 233 RenderProcessHost* render_process_host = render_view_host_->GetProcess();
(...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after
374 379
375 bool handled = true; 380 bool handled = true;
376 IPC_BEGIN_MESSAGE_MAP(RenderViewDevToolsAgentHost, msg) 381 IPC_BEGIN_MESSAGE_MAP(RenderViewDevToolsAgentHost, msg)
377 IPC_MESSAGE_HANDLER(DevToolsClientMsg_DispatchOnInspectorFrontend, 382 IPC_MESSAGE_HANDLER(DevToolsClientMsg_DispatchOnInspectorFrontend,
378 OnDispatchOnInspectorFrontend) 383 OnDispatchOnInspectorFrontend)
379 IPC_MESSAGE_HANDLER(DevToolsHostMsg_SaveAgentRuntimeState, 384 IPC_MESSAGE_HANDLER(DevToolsHostMsg_SaveAgentRuntimeState,
380 OnSaveAgentRuntimeState) 385 OnSaveAgentRuntimeState)
381 IPC_MESSAGE_HANDLER(DevToolsHostMsg_ClearBrowserCache, OnClearBrowserCache) 386 IPC_MESSAGE_HANDLER(DevToolsHostMsg_ClearBrowserCache, OnClearBrowserCache)
382 IPC_MESSAGE_HANDLER(DevToolsHostMsg_ClearBrowserCookies, 387 IPC_MESSAGE_HANDLER(DevToolsHostMsg_ClearBrowserCookies,
383 OnClearBrowserCookies) 388 OnClearBrowserCookies)
389 IPC_MESSAGE_HANDLER(DevToolsHostMsg_DisableNetwork,
390 OnDisableNetwork)
384 IPC_MESSAGE_HANDLER_GENERIC(ViewHostMsg_SwapCompositorFrame, 391 IPC_MESSAGE_HANDLER_GENERIC(ViewHostMsg_SwapCompositorFrame,
385 handled = false; OnSwapCompositorFrame(msg)) 392 handled = false; OnSwapCompositorFrame(msg))
386 IPC_MESSAGE_UNHANDLED(handled = false) 393 IPC_MESSAGE_UNHANDLED(handled = false)
387 IPC_END_MESSAGE_MAP() 394 IPC_END_MESSAGE_MAP()
388 return handled; 395 return handled;
389 } 396 }
390 397
391 void RenderViewDevToolsAgentHost::OnSwapCompositorFrame( 398 void RenderViewDevToolsAgentHost::OnSwapCompositorFrame(
392 const IPC::Message& message) { 399 const IPC::Message& message) {
393 ViewHostMsg_SwapCompositorFrame::Param param; 400 ViewHostMsg_SwapCompositorFrame::Param param;
(...skipping 27 matching lines...) Expand all
421 void RenderViewDevToolsAgentHost::OnClearBrowserCache() { 428 void RenderViewDevToolsAgentHost::OnClearBrowserCache() {
422 if (render_view_host_) 429 if (render_view_host_)
423 GetContentClient()->browser()->ClearCache(render_view_host_); 430 GetContentClient()->browser()->ClearCache(render_view_host_);
424 } 431 }
425 432
426 void RenderViewDevToolsAgentHost::OnClearBrowserCookies() { 433 void RenderViewDevToolsAgentHost::OnClearBrowserCookies() {
427 if (render_view_host_) 434 if (render_view_host_)
428 GetContentClient()->browser()->ClearCookies(render_view_host_); 435 GetContentClient()->browser()->ClearCookies(render_view_host_);
429 } 436 }
430 437
438 void RenderViewDevToolsAgentHost::UpdateNetworkState(bool disable_network) {
439 if (render_view_host_) {
440 GetContentClient()->browser()->DisableNetwork(
441 render_view_host_, GetId(), disable_network);
442 }
443 }
444
445 void RenderViewDevToolsAgentHost::OnDisableNetwork(
446 bool disable_network) {
447 network_disabled_ = disable_network;
448 UpdateNetworkState(disable_network);
449 }
450
431 } // namespace content 451 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698