Index: chrome_frame/chrome_launcher_utils.cc |
=================================================================== |
--- chrome_frame/chrome_launcher_utils.cc (revision 71126) |
+++ chrome_frame/chrome_launcher_utils.cc (working copy) |
@@ -14,16 +14,9 @@ |
#include "chrome/common/chrome_switches.h" |
#include "chrome_frame/chrome_frame_automation.h" |
-namespace chrome_launcher { |
+namespace { |
-const wchar_t kLauncherExeBaseName[] = L"chrome_launcher.exe"; |
- |
-CommandLine* CreateLaunchCommandLine() { |
- // Shortcut for OS versions that don't need the integrity broker. |
- if (base::win::GetVersion() < base::win::VERSION_VISTA) { |
- return new CommandLine(GetChromeExecutablePath()); |
- } |
- |
+CommandLine* CreateChromeLauncherCommandLine() { |
// The launcher EXE will be in the same directory as the Chrome Frame DLL, |
// so create a full path to it based on this assumption. Since our unit |
// tests also use this function, and live in the directory above, we test |
@@ -32,12 +25,13 @@ |
FilePath module_path; |
if (PathService::Get(base::FILE_MODULE, &module_path)) { |
FilePath current_dir = module_path.DirName(); |
- FilePath same_dir_path = current_dir.Append(kLauncherExeBaseName); |
+ FilePath same_dir_path = current_dir.Append( |
+ chrome_launcher::kLauncherExeBaseName); |
if (file_util::PathExists(same_dir_path)) { |
return new CommandLine(same_dir_path); |
} else { |
- FilePath servers_path = |
- current_dir.Append(L"servers").Append(kLauncherExeBaseName); |
+ FilePath servers_path = current_dir.Append(L"servers").Append( |
+ chrome_launcher::kLauncherExeBaseName); |
DCHECK(file_util::PathExists(servers_path)) << |
"What module is this? It's not in 'servers' or main output dir."; |
return new CommandLine(servers_path); |
@@ -48,6 +42,34 @@ |
} |
} |
+} // namespace |
+ |
+namespace chrome_launcher { |
+ |
+const wchar_t kLauncherExeBaseName[] = L"chrome_launcher.exe"; |
+ |
+const char kUpdateCommandFlag[] = "--update-cmd"; |
+ |
+CommandLine* CreateUpdateCommandLine(const std::wstring& update_command) { |
+ CommandLine* command_line = CreateChromeLauncherCommandLine(); |
+ |
+ if (command_line) { |
+ command_line->AppendArg(kUpdateCommandFlag); |
+ command_line->AppendArg(WideToASCII(update_command)); |
+ } |
+ |
+ return command_line; |
+} |
+ |
+CommandLine* CreateLaunchCommandLine() { |
+ // Shortcut for OS versions that don't need the integrity broker. |
+ if (base::win::GetVersion() < base::win::VERSION_VISTA) { |
+ return new CommandLine(GetChromeExecutablePath()); |
+ } |
+ |
+ return CreateChromeLauncherCommandLine(); |
+} |
+ |
FilePath GetChromeExecutablePath() { |
FilePath cur_path; |
PathService::Get(base::DIR_MODULE, &cur_path); |