Index: chrome/browser/devtools/device/self_device_provider.cc |
diff --git a/chrome/browser/devtools/device/self_device_provider.cc b/chrome/browser/devtools/device/self_device_provider.cc |
index d4b6bf40379bb04c1e01c5dc8e96d42d06a8bca5..326bbcfdb78bba88c2777755fdb5fdb33c7894de 100644 |
--- a/chrome/browser/devtools/device/self_device_provider.cc |
+++ b/chrome/browser/devtools/device/self_device_provider.cc |
@@ -4,6 +4,8 @@ |
#include "chrome/browser/devtools/device/self_device_provider.h" |
+#include <algorithm> |
+ |
#include "base/location.h" |
#include "base/single_thread_task_runner.h" |
#include "base/strings/string_number_conversions.h" |
@@ -15,8 +17,6 @@ namespace { |
const char kDeviceModel[] = "Local Chrome"; |
dgozman
2015/07/06 10:08:34
It's not Chrome anymore, let's update.
yurys
2015/07/06 12:49:00
Done.
|
const char kBrowserName[] = "Chrome"; |
dgozman
2015/07/06 10:08:34
ditto
yurys
2015/07/06 12:49:00
Done.
|
-const char kLocalhost[] = "127.0.0.1"; |
-const char kSerial[] = "local"; |
static void RunSocketCallback( |
const AndroidDeviceManager::SocketCallback& callback, |
@@ -27,12 +27,19 @@ static void RunSocketCallback( |
} // namespace |
-SelfAsDeviceProvider::SelfAsDeviceProvider(int port) : port_(port) { |
+SelfAsDeviceProvider::SelfAsDeviceProvider(const RemoteTargets& targets) |
+ : targets_(targets) { |
} |
void SelfAsDeviceProvider::QueryDevices(const SerialsCallback& callback) { |
std::vector<std::string> result; |
- result.push_back(kSerial); |
+ for (const net::HostPortPair& target : targets_) { |
+ const std::string& host = target.host(); |
+ if (std::find(result.begin(), result.end(), host) != result.end()) { |
dgozman
2015/07/06 10:08:34
nit: we don't usually wrap one-liners with {}
yurys
2015/07/06 12:49:00
Done.
|
+ continue; |
+ } |
+ result.push_back(host); |
+ } |
callback.Run(result); |
} |
@@ -42,12 +49,17 @@ void SelfAsDeviceProvider::QueryDeviceInfo(const std::string& serial, |
device_info.model = kDeviceModel; |
device_info.connected = true; |
- AndroidDeviceManager::BrowserInfo browser_info; |
- browser_info.socket_name = base::IntToString(port_); |
- browser_info.display_name = kBrowserName; |
- browser_info.type = AndroidDeviceManager::BrowserInfo::kTypeChrome; |
+ for (const net::HostPortPair& target : targets_) { |
+ if (serial != target.host()) { |
pfeldman
2015/07/06 10:10:04
ditto
yurys
2015/07/06 12:49:00
Done.
|
+ continue; |
+ } |
+ AndroidDeviceManager::BrowserInfo browser_info; |
+ browser_info.socket_name = base::IntToString(target.port()); |
+ browser_info.display_name = kBrowserName; |
+ browser_info.type = AndroidDeviceManager::BrowserInfo::kTypeChrome; |
- device_info.browser_info.push_back(browser_info); |
+ device_info.browser_info.push_back(browser_info); |
+ } |
base::ThreadTaskRunnerHandle::Get()->PostTask( |
FROM_HERE, base::Bind(callback, device_info)); |
@@ -59,7 +71,9 @@ void SelfAsDeviceProvider::OpenSocket(const std::string& serial, |
// Use plain socket for remote debugging and port forwarding on Desktop |
// (debugging purposes). |
net::IPAddressNumber ip_number; |
- net::ParseIPLiteralToNumber(kLocalhost, &ip_number); |
+ if (!net::ParseIPLiteralToNumber(serial, &ip_number)) { |
pfeldman
2015/07/06 10:10:04
ditto
yurys
2015/07/06 12:49:00
Done.
|
+ LOG(ERROR) << "Failed to parse IP address: " << serial; |
dgozman
2015/07/06 10:08:34
We should |callback(nullptr)| probably.
yurys
2015/07/06 12:49:00
Done.
|
+ } |
int port; |
base::StringToInt(socket_name, &port); |
net::AddressList address_list = |
@@ -71,7 +85,6 @@ void SelfAsDeviceProvider::OpenSocket(const std::string& serial, |
} |
void SelfAsDeviceProvider::ReleaseDevice(const std::string& serial) { |
- DCHECK(serial == kSerial); |
if (!release_callback_.is_null()) |
release_callback_.Run(); |
} |