| 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); | 
| +} | 
|  |