| Index: chrome_frame/chrome_launcher_utils.cc
|
| ===================================================================
|
| --- chrome_frame/chrome_launcher_utils.cc (revision 0)
|
| +++ chrome_frame/chrome_launcher_utils.cc (revision 0)
|
| @@ -0,0 +1,68 @@
|
| +// Copyright (c) 2009 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "chrome_frame/chrome_launcher_utils.h"
|
| +
|
| +#include "base/base_switches.h"
|
| +#include "base/command_line.h"
|
| +#include "base/file_util.h"
|
| +#include "base/logging.h"
|
| +#include "base/path_service.h"
|
| +#include "base/win_util.h"
|
| +#include "chrome/common/chrome_constants.h"
|
| +#include "chrome/common/chrome_switches.h"
|
| +#include "chrome_frame/chrome_frame_automation.h"
|
| +
|
| +namespace chrome_launcher {
|
| +
|
| +const wchar_t kLauncherExeBaseName[] = L"chrome_launcher.exe";
|
| +
|
| +CommandLine* CreateLaunchCommandLine() {
|
| + // Shortcut for OS versions that don't need the integrity broker.
|
| + if (win_util::GetWinVersion() < win_util::WINVERSION_VISTA) {
|
| + return new CommandLine(GetChromeExecutablePath());
|
| + }
|
| +
|
| + // 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
|
| + // existence of the file and try the path that includes the /servers/
|
| + // directory if needed.
|
| + 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);
|
| + if (file_util::PathExists(same_dir_path)) {
|
| + return new CommandLine(same_dir_path);
|
| + } else {
|
| + FilePath servers_path =
|
| + current_dir.Append(L"servers").Append(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);
|
| + }
|
| + } else {
|
| + NOTREACHED();
|
| + return NULL;
|
| + }
|
| +}
|
| +
|
| +FilePath GetChromeExecutablePath() {
|
| + FilePath cur_path;
|
| + PathService::Get(base::DIR_MODULE, &cur_path);
|
| + cur_path = cur_path.Append(chrome::kBrowserProcessExecutableName);
|
| +
|
| + // The installation model for Chrome places the DLLs in a versioned
|
| + // sub-folder one down from the Chrome executable. If we fail to find
|
| + // chrome.exe in the current path, try looking one up and launching that
|
| + // instead.
|
| + if (!file_util::PathExists(cur_path)) {
|
| + PathService::Get(base::DIR_MODULE, &cur_path);
|
| + cur_path = cur_path.DirName().Append(chrome::kBrowserProcessExecutableName);
|
| + }
|
| +
|
| + return cur_path;
|
| +}
|
| +
|
| +} // namespace chrome_launcher
|
|
|
| Property changes on: chrome_frame\chrome_launcher_utils.cc
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|