// Copyright (c) 2012 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/installer/util/chrome_frame_operations.h" #include "base/command_line.h" #include "base/files/file_path.h" #include "base/logging.h" #include "chrome/installer/util/channel_info.h" #include "chrome/installer/util/helper.h" #include "chrome/installer/util/master_preferences.h" #include "chrome/installer/util/master_preferences_constants.h" #include "chrome/installer/util/util_constants.h" namespace installer { void ChromeFrameOperations::ReadOptions(const MasterPreferences& prefs, std::set* options) const { DCHECK(options); static const struct PrefToOption { const char* pref_name; const wchar_t* option_name; } map[] = { { master_preferences::kMultiInstall, kOptionMultiInstall } }; bool pref_value; for (const PrefToOption* scan = &map[0], *end = &map[arraysize(map)]; scan != end; ++scan) { if (prefs.GetBool(scan->pref_name, &pref_value) && pref_value) options->insert(scan->option_name); } } void ChromeFrameOperations::ReadOptions( const base::CommandLine& uninstall_command, std::set* options) const { DCHECK(options); static const struct FlagToOption { const char* flag_name; const wchar_t* option_name; } map[] = { { switches::kMultiInstall, kOptionMultiInstall } }; for (const FlagToOption* scan = &map[0], *end = &map[arraysize(map)]; scan != end; ++scan) { if (uninstall_command.HasSwitch(scan->flag_name)) options->insert(scan->option_name); } } void ChromeFrameOperations::AddKeyFiles( const std::set& options, std::vector* key_files) const { DCHECK(key_files); key_files->push_back(base::FilePath(installer::kChromeFrameDll)); key_files->push_back(base::FilePath(installer::kChromeFrameHelperExe)); } void ChromeFrameOperations::AddComDllList( const std::set& options, std::vector* com_dll_list) const { DCHECK(com_dll_list); com_dll_list->push_back(base::FilePath(installer::kChromeFrameDll)); } void ChromeFrameOperations::AppendProductFlags( const std::set& options, base::CommandLine* cmd_line) const { DCHECK(cmd_line); bool is_multi_install = options.find(kOptionMultiInstall) != options.end(); // Add --multi-install if it isn't already there. if (is_multi_install && !cmd_line->HasSwitch(switches::kMultiInstall)) cmd_line->AppendSwitch(switches::kMultiInstall); // --chrome-frame is always needed. cmd_line->AppendSwitch(switches::kChromeFrame); } void ChromeFrameOperations::AppendRenameFlags( const std::set& options, base::CommandLine* cmd_line) const { DCHECK(cmd_line); bool is_multi_install = options.find(kOptionMultiInstall) != options.end(); // Add --multi-install if it isn't already there. if (is_multi_install && !cmd_line->HasSwitch(switches::kMultiInstall)) cmd_line->AppendSwitch(switches::kMultiInstall); // --chrome-frame is needed for single installs. if (!is_multi_install) cmd_line->AppendSwitch(switches::kChromeFrame); } bool ChromeFrameOperations::SetChannelFlags( const std::set& options, bool set, ChannelInfo* channel_info) const { #if defined(GOOGLE_CHROME_BUILD) DCHECK(channel_info); bool modified = channel_info->SetChromeFrame(set); // Unconditionally remove the legacy -readymode flag. modified |= channel_info->SetReadyMode(false); return modified; #else return false; #endif } bool ChromeFrameOperations::ShouldCreateUninstallEntry( const std::set& options) const { return true; } void ChromeFrameOperations::AddDefaultShortcutProperties( BrowserDistribution* dist, const base::FilePath& target_exe, ShellUtil::ShortcutProperties* properties) const { NOTREACHED() << "Chrome Frame does not create shortcuts."; } void ChromeFrameOperations::LaunchUserExperiment( const base::FilePath& setup_path, const std::set& options, InstallStatus status, bool system_level) const { // No experiments yet. If adding some in the future, need to have // ChromeFrameDistribution::HasUserExperiments() return true. NOTREACHED(); } } // namespace installer