Chromium Code Reviews| Index: chrome_frame/chrome_launcher_utils.cc |
| =================================================================== |
| --- chrome_frame/chrome_launcher_utils.cc (revision 72310) |
| +++ 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"; |
|
robertshield
2011/01/24 15:08:42
This is only used in the anonymous namespace above
erikwright (departed)
2011/01/24 17:17:14
Done.
|
| + |
| +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); |