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

Unified Diff: chrome/browser/devtools/browser_list_tabcontents_provider.cc

Issue 24995003: DevTools: Extract target discovery and manipulation from DevToolsHttpHandlerImpl (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Added Android implementations Created 7 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/devtools/browser_list_tabcontents_provider.cc
diff --git a/chrome/browser/devtools/browser_list_tabcontents_provider.cc b/chrome/browser/devtools/browser_list_tabcontents_provider.cc
index 1e43a493367bc87d7c4aa332ed9da65c1c5efa31..ad70a56d5a331cdf3a09c35ae2dd31aa6a1fc303 100644
--- a/chrome/browser/devtools/browser_list_tabcontents_provider.cc
+++ b/chrome/browser/devtools/browser_list_tabcontents_provider.cc
@@ -20,7 +20,12 @@
#include "chrome/browser/ui/tab_contents/tab_contents_iterator.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/common/chrome_paths.h"
+#include "content/public/browser/browser_thread.h"
+#include "content/public/browser/devtools_agent_host.h"
+#include "content/public/browser/devtools_target_descriptor.h"
+#include "content/public/browser/render_view_host.h"
#include "content/public/browser/web_contents.h"
+#include "content/public/browser/worker_service.h"
#include "content/public/common/url_constants.h"
#include "grit/devtools_discovery_page_resources.h"
#include "net/socket/tcp_listen_socket.h"
@@ -28,7 +33,41 @@
#include "ui/base/resource/resource_bundle.h"
using content::DevToolsHttpHandlerDelegate;
+using content::DevToolsAgentHost;
using content::RenderViewHost;
+using content::WebContents;
+
+namespace {
+
+const char kTargetTypeOther[] = "other";
+
+std::string GetDescription(WebContents* web_contents) {
+ Profile* profile =
+ Profile::FromBrowserContext(web_contents->GetBrowserContext());
+ if (!profile)
+ return std::string();
+
+ extensions::ExtensionHost* extension_host =
+ extensions::ExtensionSystem::Get(profile)->process_manager()->
+ GetBackgroundHostForExtension(web_contents->GetURL().host());
+
+ if (!extension_host || extension_host->host_contents() != web_contents)
+ return std::string();
+
+ return extension_host->extension()->name();
+}
+
+RenderViewHost* GetRenderViewHost(const std::string& id) {
+ DevToolsAgentHost* agent_host = DevToolsAgentHost::GetForId(id);
+ return agent_host ? agent_host->GetRenderViewHost() : NULL;
+}
+
+WebContents* GetWebContents(const std::string& id) {
+ RenderViewHost* rvh = GetRenderViewHost(id);
+ return rvh ? WebContents::FromRenderViewHost(rvh) : NULL;
+}
+
+} // namespace
BrowserListTabContentsProvider::BrowserListTabContentsProvider(
chrome::HostDesktopType host_desktop_type)
@@ -70,8 +109,17 @@ base::FilePath BrowserListTabContentsProvider::GetDebugFrontendDir() {
#endif
}
+bool BrowserListTabContentsProvider::SupportsPageThumbnails() {
+ return true;
+}
+
std::string BrowserListTabContentsProvider::GetPageThumbnailData(
- const GURL& url) {
+ const std::string& id) {
+ WebContents* web_contents = GetWebContents(id);
+ if (!web_contents)
+ return std::string();
+
+ GURL url = web_contents->GetURL();
for (chrome::BrowserIterator it; !it.done(); it.Next()) {
Profile* profile = (*it)->profile();
history::TopSites* top_sites = profile->GetTopSites();
@@ -86,54 +134,56 @@ std::string BrowserListTabContentsProvider::GetPageThumbnailData(
return std::string();
}
-RenderViewHost* BrowserListTabContentsProvider::CreateNewTarget() {
+DevToolsHttpHandlerDelegate::Target*
+BrowserListTabContentsProvider::CreateNewTarget() {
+ WebContents* web_contents;
const BrowserList* browser_list =
BrowserList::GetInstance(host_desktop_type_);
-
if (browser_list->empty()) {
chrome::NewEmptyWindow(ProfileManager::GetLastUsedProfile(),
host_desktop_type_);
- return browser_list->empty() ? NULL :
- browser_list->get(0)->tab_strip_model()->GetActiveWebContents()->
- GetRenderViewHost();
+ if (browser_list->empty())
+ return NULL;
+ web_contents =
+ browser_list->get(0)->tab_strip_model()->GetActiveWebContents();
+ } else {
+ web_contents = chrome::AddSelectedTabWithURL(
+ browser_list->get(0),
+ GURL(content::kAboutBlankURL),
+ content::PAGE_TRANSITION_LINK);
}
-
- content::WebContents* web_contents = chrome::AddSelectedTabWithURL(
- browser_list->get(0),
- GURL(content::kAboutBlankURL),
- content::PAGE_TRANSITION_LINK);
- return web_contents->GetRenderViewHost();
+ return Target::FromWebContents(web_contents);
}
-content::DevToolsHttpHandlerDelegate::TargetType
-BrowserListTabContentsProvider::GetTargetType(content::RenderViewHost* rvh) {
- for (TabContentsIterator it; !it.done(); it.Next())
- if (rvh == it->GetRenderViewHost())
- return kTargetTypeTab;
-
- return kTargetTypeOther;
-}
-
-std::string BrowserListTabContentsProvider::GetViewDescription(
- content::RenderViewHost* rvh) {
- content::WebContents* web_contents =
- content::WebContents::FromRenderViewHost(rvh);
+bool BrowserListTabContentsProvider::ActivateTarget(const std::string& id) {
+ WebContents* web_contents = GetWebContents(id);
if (!web_contents)
- return std::string();
-
- Profile* profile =
- Profile::FromBrowserContext(web_contents->GetBrowserContext());
- if (!profile)
- return std::string();
+ return false;
+ web_contents->GetDelegate()->ActivateContents(web_contents);
+ return true;
+}
- extensions::ExtensionHost* extension_host =
- extensions::ExtensionSystem::Get(profile)->process_manager()->
- GetBackgroundHostForExtension(web_contents->GetURL().host());
+bool BrowserListTabContentsProvider::CloseTarget(const std::string& id) {
+ RenderViewHost* rvh = GetRenderViewHost(id);
+ if (!rvh)
+ return false;
+ rvh->ClosePage();
+ return true;
+}
- if (!extension_host || extension_host->host_contents() != web_contents)
- return std::string();
+scoped_refptr<DevToolsAgentHost> BrowserListTabContentsProvider::GetAgentHost(
+ const std::string& id) {
+ return DevToolsAgentHost::GetForId(id);
+}
- return extension_host->extension()->name();
+void BrowserListTabContentsProvider::RequestTargets(TargetCallback callback) {
+ content::BrowserThread::PostTaskAndReplyWithResult(
+ content::BrowserThread::IO,
+ FROM_HERE,
+ base::Bind(&BrowserListTabContentsProvider::CollectWorkerTargets, this),
+ base::Bind(&BrowserListTabContentsProvider::RespondWithTargetList,
+ this,
+ callback));
}
#if defined(DEBUG_DEVTOOLS)
@@ -158,3 +208,42 @@ BrowserListTabContentsProvider::CreateSocketForTethering(
return scoped_ptr<net::StreamListenSocket>();
}
#endif // defined(DEBUG_DEVTOOLS)
+
+DevToolsHttpHandlerDelegate::TargetList
+BrowserListTabContentsProvider::CollectWorkerTargets() {
+ TargetList targets;
+ std::vector<content::WorkerService::WorkerInfo> worker_info =
+ content::WorkerService::GetInstance()->GetWorkers();
+ for (size_t i = 0; i < worker_info.size(); ++i)
+ targets.push_back(Target::FromWorkerInfo(worker_info[i]));
+ return targets;
+}
+
+void BrowserListTabContentsProvider::RespondWithTargetList(
+ TargetCallback callback, const TargetList& worker_targets) {
+ std::set<RenderViewHost*> tab_rvhs;
+ for (TabContentsIterator it; !it.done(); it.Next())
+ tab_rvhs.insert(it->GetRenderViewHost());
+
+ TargetList targets;
+
+ std::vector<RenderViewHost*> rvh_list =
+ content::DevToolsAgentHost::GetValidRenderViewHosts();
+ for (std::vector<RenderViewHost*>::iterator it = rvh_list.begin();
+ it != rvh_list.end(); ++it) {
+ bool is_tab = tab_rvhs.find(*it) != tab_rvhs.end();
+ WebContents* web_contents = WebContents::FromRenderViewHost(*it);
+ if (!web_contents)
+ continue;
+ Target* target = Target::FromWebContents(web_contents);
+ if (!is_tab) {
+ target->OverrideType(kTargetTypeOther);
+ target->OverrideDescription(GetDescription(web_contents));
+ }
+ targets.push_back(target);
+ }
+
+ targets.insert(targets.end(), worker_targets.begin(), worker_targets.end());
+
+ callback.Run(targets);
+}

Powered by Google App Engine
This is Rietveld 408576698