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

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

Issue 2344753002: DevTools: return discovered targets asynchronously. (Closed)
Patch Set: for bots 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/json/json_writer.h" 10 #include "base/json/json_writer.h"
(...skipping 13 matching lines...) Expand all
24 namespace { 24 namespace {
25 typedef std::map<std::string, DevToolsAgentHostImpl*> Instances; 25 typedef std::map<std::string, DevToolsAgentHostImpl*> Instances;
26 base::LazyInstance<Instances>::Leaky g_instances = LAZY_INSTANCE_INITIALIZER; 26 base::LazyInstance<Instances>::Leaky g_instances = LAZY_INSTANCE_INITIALIZER;
27 27
28 using AgentStateCallbacks = 28 using AgentStateCallbacks =
29 std::vector<const DevToolsAgentHost::AgentStateCallback*>; 29 std::vector<const DevToolsAgentHost::AgentStateCallback*>;
30 base::LazyInstance<AgentStateCallbacks>::Leaky g_callbacks = 30 base::LazyInstance<AgentStateCallbacks>::Leaky g_callbacks =
31 LAZY_INSTANCE_INITIALIZER; 31 LAZY_INSTANCE_INITIALIZER;
32 using DiscoveryCallbacks = 32 using DiscoveryCallbacks =
33 std::vector<DevToolsAgentHost::DiscoveryCallback>; 33 std::vector<DevToolsAgentHost::DiscoveryCallback>;
34 base::LazyInstance<DiscoveryCallbacks>::Leaky g_providers =
35 LAZY_INSTANCE_INITIALIZER;
36 } // namespace 34 } // namespace
37 35
38 char DevToolsAgentHost::kTypePage[] = "page"; 36 char DevToolsAgentHost::kTypePage[] = "page";
39 char DevToolsAgentHost::kTypeFrame[] = "iframe"; 37 char DevToolsAgentHost::kTypeFrame[] = "iframe";
40 char DevToolsAgentHost::kTypeSharedWorker[] = "shared_worker"; 38 char DevToolsAgentHost::kTypeSharedWorker[] = "shared_worker";
41 char DevToolsAgentHost::kTypeServiceWorker[] = "service_worker"; 39 char DevToolsAgentHost::kTypeServiceWorker[] = "service_worker";
42 char DevToolsAgentHost::kTypeExternal[] = "external"; 40 char DevToolsAgentHost::kTypeExternal[] = "external";
43 char DevToolsAgentHost::kTypeBrowser[] = "browser"; 41 char DevToolsAgentHost::kTypeBrowser[] = "browser";
44 char DevToolsAgentHost::kTypeOther[] = "other"; 42 char DevToolsAgentHost::kTypeOther[] = "other";
45 43
46 // static 44 // static
47 std::string DevToolsAgentHost::GetProtocolVersion() { 45 std::string DevToolsAgentHost::GetProtocolVersion() {
48 return std::string(devtools::kProtocolVersion); 46 return std::string(devtools::kProtocolVersion);
49 } 47 }
50 48
51 // static 49 // static
52 bool DevToolsAgentHost::IsSupportedProtocolVersion(const std::string& version) { 50 bool DevToolsAgentHost::IsSupportedProtocolVersion(const std::string& version) {
53 return devtools::IsSupportedProtocolVersion(version); 51 return devtools::IsSupportedProtocolVersion(version);
54 } 52 }
55 53
56 // static 54 // static
57 void DevToolsAgentHost::AddDiscoveryProvider(
58 const DiscoveryCallback& callback) {
59 g_providers.Get().push_back(callback);
60 }
61
62 // static
63 DevToolsAgentHost::List DevToolsAgentHost::GetOrCreateAll() { 55 DevToolsAgentHost::List DevToolsAgentHost::GetOrCreateAll() {
64 List result; 56 List result;
65 SharedWorkerDevToolsAgentHost::List shared_list; 57 SharedWorkerDevToolsAgentHost::List shared_list;
66 SharedWorkerDevToolsManager::GetInstance()->AddAllAgentHosts(&shared_list); 58 SharedWorkerDevToolsManager::GetInstance()->AddAllAgentHosts(&shared_list);
67 for (const auto& host : shared_list) 59 for (const auto& host : shared_list)
68 result.push_back(host); 60 result.push_back(host);
69 61
70 ServiceWorkerDevToolsAgentHost::List service_list; 62 ServiceWorkerDevToolsAgentHost::List service_list;
71 ServiceWorkerDevToolsManager::GetInstance()->AddAllAgentHosts(&service_list); 63 ServiceWorkerDevToolsManager::GetInstance()->AddAllAgentHosts(&service_list);
72 for (const auto& host : service_list) 64 for (const auto& host : service_list)
73 result.push_back(host); 65 result.push_back(host);
74 66
75 RenderFrameDevToolsAgentHost::AddAllAgentHosts(&result); 67 RenderFrameDevToolsAgentHost::AddAllAgentHosts(&result);
76 return result; 68 return result;
77 } 69 }
78 70
79 // static 71 // static
80 DevToolsAgentHost::List DevToolsAgentHost::DiscoverAllHosts() { 72 void DevToolsAgentHost::DiscoverAllHosts(const DiscoveryCallback& callback) {
81 content::DevToolsAgentHost::List result; 73 DevToolsManager* manager = DevToolsManager::GetInstance();
82 // Force create all the delegates. 74 if (!manager->delegate() || !manager->delegate()->DiscoverTargets(callback))
83 DevToolsManager::GetInstance(); 75 callback.Run(DevToolsAgentHost::GetOrCreateAll());
84 if (!g_providers.Get().size())
85 return DevToolsAgentHost::GetOrCreateAll();
86 for (auto& provider : g_providers.Get()) {
87 content::DevToolsAgentHost::List partial = provider.Run();
88 result.insert(result.begin(), partial.begin(), partial.end());
89 }
90 return result;
91 } 76 }
92 77
93 // Called on the UI thread. 78 // Called on the UI thread.
94 // static 79 // static
95 scoped_refptr<DevToolsAgentHost> DevToolsAgentHost::GetForWorker( 80 scoped_refptr<DevToolsAgentHost> DevToolsAgentHost::GetForWorker(
96 int worker_process_id, 81 int worker_process_id,
97 int worker_route_id) { 82 int worker_route_id) {
98 if (scoped_refptr<DevToolsAgentHost> host = 83 if (scoped_refptr<DevToolsAgentHost> host =
99 SharedWorkerDevToolsManager::GetInstance() 84 SharedWorkerDevToolsManager::GetInstance()
100 ->GetDevToolsAgentHostForWorker(worker_process_id, 85 ->GetDevToolsAgentHostForWorker(worker_process_id,
(...skipping 268 matching lines...) Expand 10 before | Expand all | Expand 10 after
369 if (message_buffer_.size() != message_buffer_size_) 354 if (message_buffer_.size() != message_buffer_size_)
370 return false; 355 return false;
371 callback_.Run(chunk.session_id, message_buffer_); 356 callback_.Run(chunk.session_id, message_buffer_);
372 message_buffer_ = std::string(); 357 message_buffer_ = std::string();
373 message_buffer_size_ = 0; 358 message_buffer_size_ = 0;
374 } 359 }
375 return true; 360 return true;
376 } 361 }
377 362
378 } // namespace content 363 } // namespace content
OLDNEW
« no previous file with comments | « chrome/browser/devtools/chrome_devtools_manager_delegate.cc ('k') | content/browser/devtools/devtools_http_handler.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698