Index: chrome/browser/devtools/chrome_devtools_manager_delegate.cc |
diff --git a/chrome/browser/devtools/chrome_devtools_manager_delegate.cc b/chrome/browser/devtools/chrome_devtools_manager_delegate.cc |
index ca25d95a7575ef5eb795cfd9f54c407ab63c03c2..085e940515be36396d26beb4b1988b12cedfbfe0 100644 |
--- a/chrome/browser/devtools/chrome_devtools_manager_delegate.cc |
+++ b/chrome/browser/devtools/chrome_devtools_manager_delegate.cc |
@@ -7,32 +7,28 @@ |
#include "base/strings/utf_string_conversions.h" |
#include "build/build_config.h" |
#include "chrome/browser/devtools/devtools_network_protocol_handler.h" |
-#include "components/devtools_discovery/devtools_discovery_manager.h" |
-#include "content/public/browser/devtools_agent_host.h" |
-#include "content/public/browser/web_contents.h" |
- |
-#if !defined(OS_ANDROID) |
#include "chrome/browser/devtools/devtools_window.h" |
#include "chrome/browser/extensions/extension_tab_util.h" |
#include "chrome/browser/profiles/profile.h" |
+#include "chrome/browser/profiles/profile_manager.h" |
+#include "chrome/browser/ui/browser_navigator.h" |
+#include "chrome/browser/ui/browser_navigator_params.h" |
#include "chrome/browser/ui/tab_contents/tab_contents_iterator.h" |
+#include "content/public/browser/devtools_agent_host.h" |
#include "content/public/browser/render_frame_host.h" |
+#include "content/public/browser/web_contents.h" |
#include "extensions/browser/extension_host.h" |
#include "extensions/browser/extension_registry.h" |
#include "extensions/browser/process_manager.h" |
-#else // !defined(OS_ANDROID) |
-#include "chrome/browser/android/tab_android.h" |
-#include "chrome/browser/ui/android/tab_model/tab_model.h" |
-#include "chrome/browser/ui/android/tab_model/tab_model_list.h" |
-#endif // !defined(OS_ANDROID) |
- |
-using devtools_discovery::DevToolsDiscoveryManager; |
char ChromeDevToolsManagerDelegate::kTypeApp[] = "app"; |
char ChromeDevToolsManagerDelegate::kTypeBackgroundPage[] = "background_page"; |
+ |
ChromeDevToolsManagerDelegate::ChromeDevToolsManagerDelegate() |
: network_protocol_handler_(new DevToolsNetworkProtocolHandler()) { |
+ content::DevToolsAgentHost::AddDiscoveryProvider( |
dgozman
2016/08/27 00:49:13
Let's have a default provider if nothing was added
|
+ base::Bind(&content::DevToolsAgentHost::GetOrCreateAll)); |
} |
ChromeDevToolsManagerDelegate::~ChromeDevToolsManagerDelegate() { |
@@ -40,7 +36,6 @@ ChromeDevToolsManagerDelegate::~ChromeDevToolsManagerDelegate() { |
void ChromeDevToolsManagerDelegate::Inspect( |
content::DevToolsAgentHost* agent_host) { |
-#if !defined(OS_ANDROID) |
Profile* profile = |
Profile::FromBrowserContext(agent_host->GetBrowserContext()); |
if (!profile) |
@@ -54,17 +49,11 @@ void ChromeDevToolsManagerDelegate::Inspect( |
content::WebContents* web_contents = agent_host->GetWebContents(); |
if (web_contents) |
DevToolsWindow::OpenDevToolsWindow(web_contents); |
-#endif // !defined(OS_ANDROID) |
} |
base::DictionaryValue* ChromeDevToolsManagerDelegate::HandleCommand( |
content::DevToolsAgentHost* agent_host, |
base::DictionaryValue* command_dict) { |
- std::unique_ptr<base::DictionaryValue> result = |
- DevToolsDiscoveryManager::GetInstance()->HandleCreateTargetCommand( |
- command_dict); |
- if (result) |
- return result.release(); // Caller takes ownership. |
return network_protocol_handler_->HandleCommand(agent_host, command_dict); |
} |
@@ -72,7 +61,6 @@ std::string ChromeDevToolsManagerDelegate::GetTargetType( |
content::RenderFrameHost* host) { |
content::WebContents* web_contents = |
content::WebContents::FromRenderFrameHost(host); |
-#if !defined(OS_ANDROID) |
for (TabContentsIterator it; !it.done(); it.Next()) { |
if (*it == web_contents) |
return content::DevToolsAgentHost::kTypePage; |
@@ -103,23 +91,11 @@ std::string ChromeDevToolsManagerDelegate::GetTargetType( |
|| extension->is_platform_app()) { |
return kTypeApp; |
} |
-#else // !defined(OS_ANDROID) |
- for (TabModelList::const_iterator iter = TabModelList::begin(); |
- iter != TabModelList::end(); ++iter) { |
- TabModel* model = *iter; |
- for (int i = 0; i < model->GetTabCount(); ++i) { |
- TabAndroid* tab = model->GetTabAt(i); |
- if (tab && web_contents == tab->web_contents()) |
- return content::DevToolsAgentHost::kTypePage; |
- } |
- } |
-#endif // !defined(OS_ANDROID) |
return content::DevToolsAgentHost::kTypeOther; |
} |
std::string ChromeDevToolsManagerDelegate::GetTargetTitle( |
content::RenderFrameHost* host) { |
-#if !defined(OS_ANDROID) |
content::WebContents* web_contents = |
content::WebContents::FromRenderFrameHost(host); |
if (host->GetParent()) |
@@ -133,10 +109,20 @@ std::string ChromeDevToolsManagerDelegate::GetTargetTitle( |
host->GetLastCommittedURL().host()); |
if (extension) |
return extension->name(); |
-#endif // !defined(OS_ANDROID) |
return ""; |
} |
+scoped_refptr<content::DevToolsAgentHost> |
+ChromeDevToolsManagerDelegate::CreateNewTarget(const GURL& url) { |
+ chrome::NavigateParams params(ProfileManager::GetLastUsedProfile(), |
+ url, ui::PAGE_TRANSITION_AUTO_TOPLEVEL); |
+ params.disposition = NEW_FOREGROUND_TAB; |
+ chrome::Navigate(¶ms); |
+ if (!params.target_contents) |
+ return nullptr; |
+ return content::DevToolsAgentHost::GetOrCreateFor(params.target_contents); |
+} |
+ |
void ChromeDevToolsManagerDelegate::DevToolsAgentStateChanged( |
content::DevToolsAgentHost* agent_host, |
bool attached) { |