Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "cloud_print/service/win/chrome_launcher.h" | 5 #include "cloud_print/service/win/chrome_launcher.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include "base/base_switches.h" | 9 #include "base/base_switches.h" |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| 11 #include "base/files/file_util.h" | 11 #include "base/files/file_util.h" |
| 12 #include "base/files/scoped_temp_dir.h" | 12 #include "base/files/scoped_temp_dir.h" |
| 13 #include "base/json/json_reader.h" | 13 #include "base/json/json_reader.h" |
| 14 #include "base/json/json_writer.h" | 14 #include "base/json/json_writer.h" |
| 15 #include "base/process/process.h" | 15 #include "base/process/process.h" |
| 16 #include "base/process/process.h" | |
| 17 #include "base/values.h" | 16 #include "base/values.h" |
| 18 #include "base/win/registry.h" | 17 #include "base/win/registry.h" |
| 19 #include "base/win/scoped_handle.h" | 18 #include "base/win/scoped_handle.h" |
| 20 #include "base/win/scoped_process_information.h" | 19 #include "base/win/scoped_process_information.h" |
| 21 #include "chrome/common/chrome_constants.h" | 20 #include "chrome/common/chrome_constants.h" |
| 22 #include "chrome/common/chrome_switches.h" | 21 #include "chrome/common/chrome_switches.h" |
| 23 #include "chrome/common/pref_names.h" | 22 #include "chrome/common/pref_names.h" |
| 24 #include "chrome/installer/launcher_support/chrome_launcher_support.h" | 23 #include "chrome/installer/launcher_support/chrome_launcher_support.h" |
| 25 #include "cloud_print/common/win/cloud_print_utils.h" | 24 #include "cloud_print/common/win/cloud_print_utils.h" |
| 26 #include "cloud_print/service/service_constants.h" | 25 #include "cloud_print/service/service_constants.h" |
| (...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 194 void ChromeLauncher::Stop() { | 193 void ChromeLauncher::Stop() { |
| 195 stop_event_.Signal(); | 194 stop_event_.Signal(); |
| 196 thread_->Join(); | 195 thread_->Join(); |
| 197 thread_.reset(); | 196 thread_.reset(); |
| 198 } | 197 } |
| 199 | 198 |
| 200 void ChromeLauncher::Run() { | 199 void ChromeLauncher::Run() { |
| 201 const base::TimeDelta default_time_out = base::TimeDelta::FromSeconds(1); | 200 const base::TimeDelta default_time_out = base::TimeDelta::FromSeconds(1); |
| 202 const base::TimeDelta max_time_out = base::TimeDelta::FromHours(1); | 201 const base::TimeDelta max_time_out = base::TimeDelta::FromHours(1); |
| 203 | 202 |
| 204 for (base::TimeDelta time_out = default_time_out;; | 203 base::TimeDelta time_out = default_time_out; |
|
tfarina
2015/12/30 20:32:59
really? Maybe just add a space after the first ';'
Lei Zhang
2015/12/30 20:59:59
Meh. For-loops without a condition are harder to r
| |
| 205 time_out = std::min(time_out * 2, max_time_out)) { | 204 while (1) { |
| 206 base::FilePath chrome_path = | 205 base::FilePath chrome_path = |
| 207 chrome_launcher_support::GetAnyChromePath(false /* is_sxs */); | 206 chrome_launcher_support::GetAnyChromePath(false /* is_sxs */); |
| 208 | 207 |
| 209 if (!chrome_path.empty()) { | 208 if (!chrome_path.empty()) { |
| 210 base::CommandLine cmd(chrome_path); | 209 base::CommandLine cmd(chrome_path); |
| 211 CopyChromeSwitchesFromCurrentProcess(&cmd); | 210 CopyChromeSwitchesFromCurrentProcess(&cmd); |
| 212 | 211 |
| 213 // Required switches. | 212 // Required switches. |
| 214 cmd.AppendSwitchASCII(switches::kProcessType, switches::kServiceProcess); | 213 cmd.AppendSwitchASCII(switches::kProcessType, switches::kServiceProcess); |
| 215 cmd.AppendSwitchPath(switches::kUserDataDir, user_data_); | 214 cmd.AppendSwitchPath(switches::kUserDataDir, user_data_); |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 247 } else { | 246 } else { |
| 248 LOG(ERROR) << "Error waiting Chrome (" << ::GetLastError() << ")."; | 247 LOG(ERROR) << "Error waiting Chrome (" << ::GetLastError() << ")."; |
| 249 } | 248 } |
| 250 if (base::Time::Now() - started > base::TimeDelta::FromHours(1)) { | 249 if (base::Time::Now() - started > base::TimeDelta::FromHours(1)) { |
| 251 // Reset timeout because process worked long enough. | 250 // Reset timeout because process worked long enough. |
| 252 time_out = default_time_out; | 251 time_out = default_time_out; |
| 253 } | 252 } |
| 254 } | 253 } |
| 255 if (stop_event_.TimedWait(time_out)) | 254 if (stop_event_.TimedWait(time_out)) |
| 256 break; | 255 break; |
| 256 | |
| 257 time_out = std::min(time_out * 2, max_time_out); | |
| 257 } | 258 } |
| 258 } | 259 } |
| 259 | 260 |
| 260 std::string ChromeLauncher::CreateServiceStateFile( | 261 std::string ChromeLauncher::CreateServiceStateFile( |
| 261 const std::string& proxy_id, | 262 const std::string& proxy_id, |
| 262 const std::vector<std::string>& printers) { | 263 const std::vector<std::string>& printers) { |
| 263 base::ScopedTempDir temp_user_data; | 264 base::ScopedTempDir temp_user_data; |
| 264 if (!temp_user_data.CreateUniqueTempDir()) { | 265 if (!temp_user_data.CreateUniqueTempDir()) { |
| 265 LOG(ERROR) << "Can't create temp dir."; | 266 LOG(ERROR) << "Can't create temp dir."; |
| 266 return std::string(); | 267 return std::string(); |
| (...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 323 LOG(ERROR) << "Chrome launch failed."; | 324 LOG(ERROR) << "Chrome launch failed."; |
| 324 return std::string(); | 325 return std::string(); |
| 325 } | 326 } |
| 326 if (!json.empty()) { | 327 if (!json.empty()) { |
| 327 // Close chrome because Service State is ready. | 328 // Close chrome because Service State is ready. |
| 328 CloseChrome(chrome_process.Pass(), thread_id); | 329 CloseChrome(chrome_process.Pass(), thread_id); |
| 329 return json; | 330 return json; |
| 330 } | 331 } |
| 331 } | 332 } |
| 332 } | 333 } |
| OLD | NEW |