OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "android_webview/native/aw_dev_tools_server.h" | 5 #include "android_webview/native/aw_dev_tools_server.h" |
6 | 6 |
7 #include "android_webview/native/aw_contents.h" | 7 #include "android_webview/native/aw_contents.h" |
8 #include "base/bind.h" | 8 #include "base/bind.h" |
9 #include "base/files/file_path.h" | 9 #include "base/files/file_path.h" |
10 #include "base/json/json_writer.h" | 10 #include "base/json/json_writer.h" |
(...skipping 13 matching lines...) Expand all Loading... |
24 using content::DevToolsAgentHost; | 24 using content::DevToolsAgentHost; |
25 using content::RenderViewHost; | 25 using content::RenderViewHost; |
26 using content::WebContents; | 26 using content::WebContents; |
27 | 27 |
28 namespace { | 28 namespace { |
29 | 29 |
30 const char kFrontEndURL[] = | 30 const char kFrontEndURL[] = |
31 "http://chrome-devtools-frontend.appspot.com/serve_rev/%s/devtools.html"; | 31 "http://chrome-devtools-frontend.appspot.com/serve_rev/%s/devtools.html"; |
32 const char kSocketNameFormat[] = "webview_devtools_remote_%d"; | 32 const char kSocketNameFormat[] = "webview_devtools_remote_%d"; |
33 | 33 |
34 const char kTargetTypePage[] = "page"; | |
35 | |
36 std::string GetViewDescription(WebContents* web_contents); | 34 std::string GetViewDescription(WebContents* web_contents); |
37 | 35 |
38 class Target : public content::DevToolsTarget { | 36 class Target : public content::DevToolsTarget { |
39 public: | 37 public: |
40 explicit Target(WebContents* web_contents); | 38 explicit Target(scoped_refptr<DevToolsAgentHost> agent_host); |
41 | 39 |
42 virtual std::string GetId() const OVERRIDE { return id_; } | 40 virtual std::string GetId() const OVERRIDE { return agent_host_->GetId(); } |
43 virtual std::string GetParentId() const OVERRIDE { return std::string(); } | 41 virtual std::string GetParentId() const OVERRIDE { return std::string(); } |
44 virtual std::string GetType() const OVERRIDE { return kTargetTypePage; } | 42 virtual std::string GetType() const OVERRIDE { |
45 virtual std::string GetTitle() const OVERRIDE { return title_; } | 43 return agent_host_->GetType(); |
| 44 } |
| 45 virtual std::string GetTitle() const OVERRIDE { |
| 46 return agent_host_->GetTitle(); |
| 47 } |
46 virtual std::string GetDescription() const OVERRIDE { return description_; } | 48 virtual std::string GetDescription() const OVERRIDE { return description_; } |
47 virtual GURL GetURL() const OVERRIDE { return url_; } | 49 virtual GURL GetURL() const OVERRIDE { return agent_host_->GetURL(); } |
48 virtual GURL GetFaviconURL() const OVERRIDE { return GURL(); } | 50 virtual GURL GetFaviconURL() const OVERRIDE { return GURL(); } |
49 virtual base::TimeTicks GetLastActivityTime() const OVERRIDE { | 51 virtual base::TimeTicks GetLastActivityTime() const OVERRIDE { |
50 return last_activity_time_; | 52 return last_activity_time_; |
51 } | 53 } |
52 virtual bool IsAttached() const OVERRIDE { | 54 virtual bool IsAttached() const OVERRIDE { |
53 return agent_host_->IsAttached(); | 55 return agent_host_->IsAttached(); |
54 } | 56 } |
55 virtual scoped_refptr<DevToolsAgentHost> GetAgentHost() const OVERRIDE { | 57 virtual scoped_refptr<DevToolsAgentHost> GetAgentHost() const OVERRIDE { |
56 return agent_host_; | 58 return agent_host_; |
57 } | 59 } |
58 virtual bool Activate() const OVERRIDE { return false; } | 60 virtual bool Activate() const OVERRIDE { return agent_host_->Activate(); } |
59 virtual bool Close() const OVERRIDE { return false; } | 61 virtual bool Close() const OVERRIDE { return agent_host_->Close(); } |
60 | 62 |
61 private: | 63 private: |
62 scoped_refptr<DevToolsAgentHost> agent_host_; | 64 scoped_refptr<DevToolsAgentHost> agent_host_; |
63 std::string id_; | |
64 std::string title_; | |
65 std::string description_; | 65 std::string description_; |
66 GURL url_; | |
67 base::TimeTicks last_activity_time_; | 66 base::TimeTicks last_activity_time_; |
68 }; | 67 }; |
69 | 68 |
70 Target::Target(WebContents* web_contents) { | 69 Target::Target(scoped_refptr<DevToolsAgentHost> agent_host) |
71 agent_host_ = | 70 : agent_host_(agent_host) { |
72 DevToolsAgentHost::GetOrCreateFor(web_contents); | 71 if (WebContents* web_contents = agent_host->GetWebContents()) { |
73 id_ = agent_host_->GetId(); | 72 description_ = GetViewDescription(web_contents); |
74 description_ = GetViewDescription(web_contents); | 73 last_activity_time_ = web_contents->GetLastActiveTime(); |
75 title_ = base::UTF16ToUTF8(web_contents->GetTitle()); | 74 } |
76 url_ = web_contents->GetURL(); | |
77 last_activity_time_ = web_contents->GetLastActiveTime(); | |
78 } | 75 } |
79 | 76 |
80 // Delegate implementation for the devtools http handler for WebView. A new | 77 // Delegate implementation for the devtools http handler for WebView. A new |
81 // instance of this gets created each time web debugging is enabled. | 78 // instance of this gets created each time web debugging is enabled. |
82 class AwDevToolsServerDelegate : public content::DevToolsHttpHandlerDelegate { | 79 class AwDevToolsServerDelegate : public content::DevToolsHttpHandlerDelegate { |
83 public: | 80 public: |
84 AwDevToolsServerDelegate() {} | 81 AwDevToolsServerDelegate() {} |
85 virtual ~AwDevToolsServerDelegate() {} | 82 virtual ~AwDevToolsServerDelegate() {} |
86 | 83 |
87 // DevToolsHttpProtocolHandler::Delegate overrides. | 84 // DevToolsHttpProtocolHandler::Delegate overrides. |
(...skipping 11 matching lines...) Expand all Loading... |
99 return ""; | 96 return ""; |
100 } | 97 } |
101 | 98 |
102 virtual scoped_ptr<content::DevToolsTarget> CreateNewTarget( | 99 virtual scoped_ptr<content::DevToolsTarget> CreateNewTarget( |
103 const GURL&) OVERRIDE { | 100 const GURL&) OVERRIDE { |
104 return scoped_ptr<content::DevToolsTarget>(); | 101 return scoped_ptr<content::DevToolsTarget>(); |
105 } | 102 } |
106 | 103 |
107 virtual void EnumerateTargets(TargetCallback callback) OVERRIDE { | 104 virtual void EnumerateTargets(TargetCallback callback) OVERRIDE { |
108 TargetList targets; | 105 TargetList targets; |
109 std::vector<WebContents*> wc_list = | 106 DevToolsAgentHost::List agents = DevToolsAgentHost::GetOrCreateAll(); |
110 DevToolsAgentHost::GetInspectableWebContents(); | 107 for (DevToolsAgentHost::List::iterator it = agents.begin(); |
111 for (std::vector<WebContents*>::iterator it = wc_list.begin(); | 108 it != agents.end(); ++it) { |
112 it != wc_list.end(); ++it) { | |
113 targets.push_back(new Target(*it)); | 109 targets.push_back(new Target(*it)); |
114 } | 110 } |
115 callback.Run(targets); | 111 callback.Run(targets); |
116 } | 112 } |
117 | 113 |
118 virtual scoped_ptr<net::StreamListenSocket> CreateSocketForTethering( | 114 virtual scoped_ptr<net::StreamListenSocket> CreateSocketForTethering( |
119 net::StreamListenSocket::Delegate* delegate, | 115 net::StreamListenSocket::Delegate* delegate, |
120 std::string* name) OVERRIDE { | 116 std::string* name) OVERRIDE { |
121 return scoped_ptr<net::StreamListenSocket>(); | 117 return scoped_ptr<net::StreamListenSocket>(); |
122 } | 118 } |
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
217 AwDevToolsServer* devtools_server = | 213 AwDevToolsServer* devtools_server = |
218 reinterpret_cast<AwDevToolsServer*>(server); | 214 reinterpret_cast<AwDevToolsServer*>(server); |
219 if (enabled) { | 215 if (enabled) { |
220 devtools_server->Start(); | 216 devtools_server->Start(); |
221 } else { | 217 } else { |
222 devtools_server->Stop(); | 218 devtools_server->Stop(); |
223 } | 219 } |
224 } | 220 } |
225 | 221 |
226 } // namespace android_webview | 222 } // namespace android_webview |
OLD | NEW |