Index: chromecast/browser/devtools/remote_debugging_server.cc |
diff --git a/chromecast/browser/devtools/remote_debugging_server.cc b/chromecast/browser/devtools/remote_debugging_server.cc |
index 6391b6d63035597090abd92bee27b300f89b25d5..7b830c59fa9eec94dcdff5c12cc21e303c9795fa 100644 |
--- a/chromecast/browser/devtools/remote_debugging_server.cc |
+++ b/chromecast/browser/devtools/remote_debugging_server.cc |
@@ -8,6 +8,7 @@ |
#include "base/bind_helpers.h" |
#include "base/command_line.h" |
#include "base/files/file_path.h" |
+#include "base/strings/string_number_conversions.h" |
#include "base/strings/stringprintf.h" |
#include "chromecast/browser/cast_browser_process.h" |
#include "chromecast/browser/devtools/cast_dev_tools_delegate.h" |
@@ -112,42 +113,40 @@ std::string GetFrontendUrl() { |
} // namespace |
-RemoteDebuggingServer::RemoteDebuggingServer() : port_(0) { |
+RemoteDebuggingServer::RemoteDebuggingServer() |
+ : port_(kDefaultRemoteDebuggingPort) { |
DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
- pref_port_.Init(prefs::kRemoteDebuggingPort, |
- CastBrowserProcess::GetInstance()->pref_service(), |
- base::Bind(&RemoteDebuggingServer::OnPortChanged, |
- base::Unretained(this))); |
+ pref_enabled_.Init(prefs::kEnableRemoteDebugging, |
+ CastBrowserProcess::GetInstance()->pref_service(), |
+ base::Bind(&RemoteDebuggingServer::OnEnabledChanged, |
+ base::Unretained(this))); |
+ |
+ std::string port_str = |
+ base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( |
+ switches::kRemoteDebuggingPort); |
+ if (!port_str.empty()) { |
+ int port = kDefaultRemoteDebuggingPort; |
+ if (base::StringToInt(port_str, &port)) { |
+ port_ = static_cast<uint16>(port); |
+ } else { |
+ port_ = kDefaultRemoteDebuggingPort; |
+ } |
+ } |
// Starts new dev tools, clearing port number saved in config. |
// Remote debugging in production must be triggered only by config server. |
- pref_port_.SetValue(ShouldStartImmediately() ? |
- kDefaultRemoteDebuggingPort : 0); |
- OnPortChanged(); |
+ pref_enabled_.SetValue(ShouldStartImmediately() && port_ != 0); |
+ OnEnabledChanged(); |
} |
RemoteDebuggingServer::~RemoteDebuggingServer() { |
- pref_port_.SetValue(0); |
- OnPortChanged(); |
+ pref_enabled_.SetValue(false); |
+ OnEnabledChanged(); |
} |
-void RemoteDebuggingServer::OnPortChanged() { |
- uint16 new_port = static_cast<uint16>(std::max(*pref_port_, 0)); |
- VLOG(1) << "OnPortChanged called: old_port=" << port_ |
- << ", new_port=" << new_port; |
- |
- if (new_port == port_) { |
- VLOG(1) << "Port has not been changed. Ignore silently."; |
- return; |
- } |
- |
- if (devtools_http_handler_) { |
- LOG(INFO) << "Stop old devtools: port=" << port_; |
- devtools_http_handler_.reset(); |
- } |
- |
- port_ = new_port; |
- if (port_ > 0) { |
+void RemoteDebuggingServer::OnEnabledChanged() { |
+ bool enabled = *pref_enabled_ && port_ != 0; |
+ if (enabled && !devtools_http_handler_) { |
devtools_http_handler_.reset(new DevToolsHttpHandler( |
CreateSocketFactory(port_), |
GetFrontendUrl(), |
@@ -157,6 +156,9 @@ void RemoteDebuggingServer::OnPortChanged() { |
std::string(), |
GetUserAgent())); |
LOG(INFO) << "Devtools started: port=" << port_; |
+ } else if (devtools_http_handler_) { |
byungchul
2015/06/16 16:57:24
it includes the condition "enabled && evtools_http
derekjchow1
2015/06/16 17:02:48
Done.
|
+ LOG(INFO) << "Stop devtools: port=" << port_; |
+ devtools_http_handler_.reset(); |
} |
} |