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

Side by Side Diff: chromecast/shell/browser/devtools/cast_dev_tools_delegate.cc

Issue 505393002: Chromecast devtools API fixes. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: restoring patch set 1 Created 6 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
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "chromecast/shell/browser/devtools/cast_dev_tools_delegate.h" 5 #include "chromecast/shell/browser/devtools/cast_dev_tools_delegate.h"
6 6
7 #include "base/files/file_path.h" 7 #include "base/files/file_path.h"
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "base/strings/utf_string_conversions.h" 9 #include "base/strings/utf_string_conversions.h"
10 #include "content/public/browser/devtools_agent_host.h" 10 #include "content/public/browser/devtools_agent_host.h"
11 #include "content/public/browser/devtools_target.h" 11 #include "content/public/browser/devtools_target.h"
12 #include "content/public/browser/favicon_status.h" 12 #include "content/public/browser/favicon_status.h"
13 #include "content/public/browser/navigation_entry.h" 13 #include "content/public/browser/navigation_entry.h"
14 #include "content/public/browser/render_view_host.h" 14 #include "content/public/browser/render_view_host.h"
15 #include "content/public/browser/web_contents.h" 15 #include "content/public/browser/web_contents.h"
16 #include "content/public/browser/web_contents_delegate.h" 16 #include "content/public/browser/web_contents_delegate.h"
17 #include "grit/shell_resources.h" 17 #include "grit/shell_resources.h"
18 #include "ui/base/resource/resource_bundle.h" 18 #include "ui/base/resource/resource_bundle.h"
19 19
20 namespace chromecast { 20 namespace chromecast {
21 namespace shell { 21 namespace shell {
22 22
23 namespace { 23 namespace {
24 24
25 const char kTargetTypePage[] = "page"; 25 const char kTargetTypePage[] = "page";
26 const char kTargetTypeServiceWorker[] = "service_worker";
27 const char kTargetTypeOther[] = "other";
26 28
27 class Target : public content::DevToolsTarget { 29 class Target : public content::DevToolsTarget {
28 public: 30 public:
29 explicit Target(content::WebContents* web_contents); 31 explicit Target(scoped_refptr<content::DevToolsAgentHost> agent_host);
30 32
31 virtual std::string GetId() const OVERRIDE { return id_; } 33 virtual std::string GetId() const OVERRIDE { return agent_host_->GetId(); }
32 virtual std::string GetParentId() const OVERRIDE { return std::string(); } 34 virtual std::string GetParentId() const OVERRIDE { return std::string(); }
33 virtual std::string GetType() const OVERRIDE { return kTargetTypePage; } 35 virtual std::string GetType() const OVERRIDE {
34 virtual std::string GetTitle() const OVERRIDE { return title_; } 36 switch (agent_host_->GetType()) {
37 case content::DevToolsAgentHost::TYPE_WEB_CONTENTS:
38 return kTargetTypePage;
39 case content::DevToolsAgentHost::TYPE_SERVICE_WORKER:
40 return kTargetTypeServiceWorker;
41 default:
42 break;
43 }
44 return kTargetTypeOther;
45 }
46 virtual std::string GetTitle() const OVERRIDE {
47 return agent_host_->GetTitle();
48 }
35 virtual std::string GetDescription() const OVERRIDE { return std::string(); } 49 virtual std::string GetDescription() const OVERRIDE { return std::string(); }
36 virtual GURL GetURL() const OVERRIDE { return url_; } 50 virtual GURL GetURL() const OVERRIDE { return url_; }
37 virtual GURL GetFaviconURL() const OVERRIDE { return favicon_url_; } 51 virtual GURL GetFaviconURL() const OVERRIDE { return favicon_url_; }
38 virtual base::TimeTicks GetLastActivityTime() const OVERRIDE { 52 virtual base::TimeTicks GetLastActivityTime() const OVERRIDE {
39 return last_activity_time_; 53 return last_activity_time_;
40 } 54 }
41 virtual bool IsAttached() const OVERRIDE { 55 virtual bool IsAttached() const OVERRIDE {
42 return agent_host_->IsAttached(); 56 return agent_host_->IsAttached();
43 } 57 }
44 virtual scoped_refptr<content::DevToolsAgentHost> GetAgentHost() 58 virtual scoped_refptr<content::DevToolsAgentHost> GetAgentHost()
45 const OVERRIDE { 59 const OVERRIDE {
46 return agent_host_; 60 return agent_host_;
47 } 61 }
48 virtual bool Activate() const OVERRIDE; 62 virtual bool Activate() const OVERRIDE;
49 virtual bool Close() const OVERRIDE; 63 virtual bool Close() const OVERRIDE;
50 64
51 private: 65 private:
52 scoped_refptr<content::DevToolsAgentHost> agent_host_; 66 scoped_refptr<content::DevToolsAgentHost> agent_host_;
53 std::string id_; 67 std::string id_;
54 std::string title_; 68 std::string title_;
55 GURL url_; 69 GURL url_;
56 GURL favicon_url_; 70 GURL favicon_url_;
57 base::TimeTicks last_activity_time_; 71 base::TimeTicks last_activity_time_;
58 72
59 DISALLOW_COPY_AND_ASSIGN(Target); 73 DISALLOW_COPY_AND_ASSIGN(Target);
60 }; 74 };
61 75
62 Target::Target(content::WebContents* web_contents) { 76 Target::Target(scoped_refptr<content::DevToolsAgentHost> agent_host)
63 agent_host_ = content::DevToolsAgentHost::GetOrCreateFor(web_contents); 77 : agent_host_(agent_host) {
64 id_ = agent_host_->GetId(); 78 if (content::WebContents* web_contents = agent_host_->GetWebContents()) {
65 title_ = base::UTF16ToUTF8(web_contents->GetTitle()); 79 content::NavigationController& controller = web_contents->GetController();
66 url_ = web_contents->GetURL(); 80 content::NavigationEntry* entry = controller.GetActiveEntry();
67 content::NavigationController& controller = web_contents->GetController(); 81 if (entry != NULL && entry->GetURL().is_valid())
68 content::NavigationEntry* entry = controller.GetActiveEntry(); 82 favicon_url_ = entry->GetFavicon().url;
69 if (entry != NULL && entry->GetURL().is_valid()) 83 last_activity_time_ = web_contents->GetLastActiveTime();
70 favicon_url_ = entry->GetFavicon().url; 84 }
71 last_activity_time_ = web_contents->GetLastActiveTime();
72 } 85 }
73 86
74 bool Target::Activate() const { 87 bool Target::Activate() const {
75 content::WebContents* web_contents = agent_host_->GetWebContents(); 88 content::WebContents* web_contents = agent_host_->GetWebContents();
76 if (!web_contents) 89 if (!web_contents)
77 return false; 90 return false;
78 web_contents->GetDelegate()->ActivateContents(web_contents); 91 web_contents->GetDelegate()->ActivateContents(web_contents);
79 return true; 92 return true;
80 } 93 }
81 94
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after
122 return ""; 135 return "";
123 } 136 }
124 137
125 scoped_ptr<content::DevToolsTarget> CastDevToolsDelegate::CreateNewTarget( 138 scoped_ptr<content::DevToolsTarget> CastDevToolsDelegate::CreateNewTarget(
126 const GURL& url) { 139 const GURL& url) {
127 return scoped_ptr<content::DevToolsTarget>(); 140 return scoped_ptr<content::DevToolsTarget>();
128 } 141 }
129 142
130 void CastDevToolsDelegate::EnumerateTargets(TargetCallback callback) { 143 void CastDevToolsDelegate::EnumerateTargets(TargetCallback callback) {
131 TargetList targets; 144 TargetList targets;
132 std::vector<content::WebContents*> wc_list = 145 content::DevToolsAgentHost::List agents =
133 content::DevToolsAgentHost::GetInspectableWebContents(); 146 content::DevToolsAgentHost::GetOrCreateAll();
134 for (std::vector<content::WebContents*>::iterator it = wc_list.begin(); 147 for (content::DevToolsAgentHost::List::iterator it = agents.begin();
135 it != wc_list.end(); 148 it != agents.end(); ++it) {
136 ++it) {
137 targets.push_back(new Target(*it)); 149 targets.push_back(new Target(*it));
138 } 150 }
139 callback.Run(targets); 151 callback.Run(targets);
140 } 152 }
141 153
142 scoped_ptr<net::StreamListenSocket> 154 scoped_ptr<net::StreamListenSocket>
143 CastDevToolsDelegate::CreateSocketForTethering( 155 CastDevToolsDelegate::CreateSocketForTethering(
144 net::StreamListenSocket::Delegate* delegate, 156 net::StreamListenSocket::Delegate* delegate,
145 std::string* name) { 157 std::string* name) {
146 return scoped_ptr<net::StreamListenSocket>(); 158 return scoped_ptr<net::StreamListenSocket>();
147 } 159 }
148 160
149 } // namespace shell 161 } // namespace shell
150 } // namespace chromecast 162 } // namespace chromecast
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698