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

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

Issue 2272213003: DevTools: remove devtools_discovery (merged into content). (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
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 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/devtools_agent_host_impl.h" 5 #include "content/browser/devtools/devtools_agent_host_impl.h"
6 6
7 #include <map> 7 #include <map>
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/guid.h" 10 #include "base/guid.h"
11 #include "base/json/json_writer.h" 11 #include "base/json/json_writer.h"
12 #include "base/lazy_instance.h" 12 #include "base/lazy_instance.h"
13 #include "content/browser/devtools/devtools_manager.h" 13 #include "content/browser/devtools/devtools_manager.h"
14 #include "content/browser/devtools/forwarding_agent_host.h" 14 #include "content/browser/devtools/forwarding_agent_host.h"
15 #include "content/browser/devtools/protocol/devtools_protocol_dispatcher.h" 15 #include "content/browser/devtools/protocol/devtools_protocol_dispatcher.h"
16 #include "content/browser/devtools/render_frame_devtools_agent_host.h" 16 #include "content/browser/devtools/render_frame_devtools_agent_host.h"
17 #include "content/browser/devtools/service_worker_devtools_agent_host.h" 17 #include "content/browser/devtools/service_worker_devtools_agent_host.h"
18 #include "content/browser/devtools/service_worker_devtools_manager.h" 18 #include "content/browser/devtools/service_worker_devtools_manager.h"
19 #include "content/browser/devtools/shared_worker_devtools_agent_host.h" 19 #include "content/browser/devtools/shared_worker_devtools_agent_host.h"
20 #include "content/browser/devtools/shared_worker_devtools_manager.h" 20 #include "content/browser/devtools/shared_worker_devtools_manager.h"
21 #include "content/public/browser/browser_thread.h" 21 #include "content/public/browser/browser_thread.h"
22 22
23 namespace content { 23 namespace content {
24 24
25 namespace { 25 namespace {
26 typedef std::map<std::string, DevToolsAgentHostImpl*> Instances; 26 typedef std::map<std::string, DevToolsAgentHostImpl*> Instances;
27 base::LazyInstance<Instances>::Leaky g_instances = LAZY_INSTANCE_INITIALIZER; 27 base::LazyInstance<Instances>::Leaky g_instances = LAZY_INSTANCE_INITIALIZER;
28 28
29 typedef std::vector<const DevToolsAgentHost::AgentStateCallback*> 29 using AgentStateCallbacks =
30 AgentStateCallbacks; 30 std::vector<const DevToolsAgentHost::AgentStateCallback*>;
31 base::LazyInstance<AgentStateCallbacks>::Leaky g_callbacks = 31 base::LazyInstance<AgentStateCallbacks>::Leaky g_callbacks =
32 LAZY_INSTANCE_INITIALIZER; 32 LAZY_INSTANCE_INITIALIZER;
33 using DiscoveryCallbacks =
34 std::vector<DevToolsAgentHost::DiscoveryCallback>;
35 base::LazyInstance<DiscoveryCallbacks>::Leaky g_providers =
36 LAZY_INSTANCE_INITIALIZER;
33 } // namespace 37 } // namespace
34 38
35 char DevToolsAgentHost::kTypePage[] = "page"; 39 char DevToolsAgentHost::kTypePage[] = "page";
36 char DevToolsAgentHost::kTypeFrame[] = "frame"; 40 char DevToolsAgentHost::kTypeFrame[] = "frame";
37 char DevToolsAgentHost::kTypeSharedWorker[] = "shared_worker"; 41 char DevToolsAgentHost::kTypeSharedWorker[] = "shared_worker";
38 char DevToolsAgentHost::kTypeServiceWorker[] = "service_worker"; 42 char DevToolsAgentHost::kTypeServiceWorker[] = "service_worker";
39 char DevToolsAgentHost::kTypeExternal[] = "external"; 43 char DevToolsAgentHost::kTypeExternal[] = "external";
40 char DevToolsAgentHost::kTypeBrowser[] = "browser"; 44 char DevToolsAgentHost::kTypeBrowser[] = "browser";
41 char DevToolsAgentHost::kTypeOther[] = "other"; 45 char DevToolsAgentHost::kTypeOther[] = "other";
42 46
43 // static 47 // static
48 DevToolsManagerDelegate* DevToolsAgentHost::GetDevToolsManagerDelegate() {
49 DevToolsManager* manager = DevToolsManager::GetInstance();
50 return manager->delegate();
51 }
52
53 // static
44 std::string DevToolsAgentHost::GetProtocolVersion() { 54 std::string DevToolsAgentHost::GetProtocolVersion() {
45 return std::string(devtools::kProtocolVersion); 55 return std::string(devtools::kProtocolVersion);
46 } 56 }
47 57
48 // static 58 // static
49 bool DevToolsAgentHost::IsSupportedProtocolVersion(const std::string& version) { 59 bool DevToolsAgentHost::IsSupportedProtocolVersion(const std::string& version) {
50 return devtools::IsSupportedProtocolVersion(version); 60 return devtools::IsSupportedProtocolVersion(version);
51 } 61 }
52 62
53 // static 63 // static
64 void DevToolsAgentHost::AddDiscoveryProvider(
65 const DiscoveryCallback& callback) {
66 g_providers.Get().push_back(callback);
67 }
68
69 // static
54 DevToolsAgentHost::List DevToolsAgentHost::GetOrCreateAll() { 70 DevToolsAgentHost::List DevToolsAgentHost::GetOrCreateAll() {
55 List result; 71 List result;
56 SharedWorkerDevToolsAgentHost::List shared_list; 72 SharedWorkerDevToolsAgentHost::List shared_list;
57 SharedWorkerDevToolsManager::GetInstance()->AddAllAgentHosts(&shared_list); 73 SharedWorkerDevToolsManager::GetInstance()->AddAllAgentHosts(&shared_list);
58 for (const auto& host : shared_list) 74 for (const auto& host : shared_list)
59 result.push_back(host); 75 result.push_back(host);
60 76
61 ServiceWorkerDevToolsAgentHost::List service_list; 77 ServiceWorkerDevToolsAgentHost::List service_list;
62 ServiceWorkerDevToolsManager::GetInstance()->AddAllAgentHosts(&service_list); 78 ServiceWorkerDevToolsManager::GetInstance()->AddAllAgentHosts(&service_list);
63 for (const auto& host : service_list) 79 for (const auto& host : service_list)
64 result.push_back(host); 80 result.push_back(host);
65 81
66 RenderFrameDevToolsAgentHost::AddAllAgentHosts(&result); 82 RenderFrameDevToolsAgentHost::AddAllAgentHosts(&result);
67 return result; 83 return result;
68 } 84 }
69 85
86 // static
87 DevToolsAgentHost::List DevToolsAgentHost::DiscoverAllHosts() {
88 content::DevToolsAgentHost::List result;
89 for (auto& provider : g_providers.Get()) {
90 content::DevToolsAgentHost::List partial = provider.Run();
91 result.insert(result.begin(), partial.begin(), partial.end());
92 }
93 return result;
94 }
95
70 // Called on the UI thread. 96 // Called on the UI thread.
71 // static 97 // static
72 scoped_refptr<DevToolsAgentHost> DevToolsAgentHost::GetForWorker( 98 scoped_refptr<DevToolsAgentHost> DevToolsAgentHost::GetForWorker(
73 int worker_process_id, 99 int worker_process_id,
74 int worker_route_id) { 100 int worker_route_id) {
75 if (scoped_refptr<DevToolsAgentHost> host = 101 if (scoped_refptr<DevToolsAgentHost> host =
76 SharedWorkerDevToolsManager::GetInstance() 102 SharedWorkerDevToolsManager::GetInstance()
77 ->GetDevToolsAgentHostForWorker(worker_process_id, 103 ->GetDevToolsAgentHostForWorker(worker_process_id,
78 worker_route_id)) { 104 worker_route_id)) {
79 return host; 105 return host;
(...skipping 267 matching lines...) Expand 10 before | Expand all | Expand 10 after
347 if (message_buffer_.size() != message_buffer_size_) 373 if (message_buffer_.size() != message_buffer_size_)
348 return false; 374 return false;
349 callback_.Run(chunk.session_id, message_buffer_); 375 callback_.Run(chunk.session_id, message_buffer_);
350 message_buffer_ = std::string(); 376 message_buffer_ = std::string();
351 message_buffer_size_ = 0; 377 message_buffer_size_ = 0;
352 } 378 }
353 return true; 379 return true;
354 } 380 }
355 381
356 } // namespace content 382 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698