| Index: chrome/installer/util/shell_util.h
|
| diff --git a/chrome/installer/util/shell_util.h b/chrome/installer/util/shell_util.h
|
| index 538a42e2373cd2de891c3dc74b05f17c2a8073c1..a67a7243fb62c2564f76b264a5f2edc65a6a1431 100644
|
| --- a/chrome/installer/util/shell_util.h
|
| +++ b/chrome/installer/util/shell_util.h
|
| @@ -15,15 +15,12 @@
|
| #include <vector>
|
|
|
| #include "base/basictypes.h"
|
| +#include "base/file_path.h"
|
| +#include "base/logging.h"
|
| #include "base/string16.h"
|
| #include "chrome/installer/util/work_item_list.h"
|
|
|
| class BrowserDistribution;
|
| -class FilePath;
|
| -
|
| -namespace base {
|
| -class DictionaryValue;
|
| -}
|
|
|
| // This is a utility class that provides common shell integration methods
|
| // that can be used by installer as well as Chrome.
|
| @@ -35,12 +32,159 @@ class ShellUtil {
|
| SYSTEM_LEVEL = 0x2 // Make any shell changes only at the system level
|
| };
|
|
|
| - enum VerifyShortcutStatus {
|
| - VERIFY_SHORTCUT_SUCCESS = 0,
|
| - VERIFY_SHORTCUT_FAILURE_UNEXPECTED,
|
| - VERIFY_SHORTCUT_FAILURE_PATH,
|
| - VERIFY_SHORTCUT_FAILURE_DESCRIPTION,
|
| - VERIFY_SHORTCUT_FAILURE_ICON_INDEX,
|
| + // Typical shortcut directories. Resolved in GetShortcutPath().
|
| + enum ChromeShortcutLocation {
|
| + SHORTCUT_DESKTOP,
|
| + SHORTCUT_QUICK_LAUNCH,
|
| + SHORTCUT_START_MENU,
|
| + };
|
| +
|
| + enum ChromeShortcutOperation {
|
| + // Create a new shortcut (overwriting if necessary).
|
| + SHORTCUT_CREATE_ALWAYS,
|
| + // Create the per-user shortcut only if its system-level equivalent is not
|
| + // present.
|
| + SHORTCUT_CREATE_IF_NO_SYSTEM_LEVEL,
|
| + // Overwrite an existing shortcut (fail if the shortcut doesn't exist).
|
| + SHORTCUT_REPLACE_EXISTING,
|
| + // Update specified properties only on an existing shortcut.
|
| + SHORTCUT_UPDATE_EXISTING,
|
| + };
|
| +
|
| + // Properties for shortcuts to chrome.exe. Properties set will be applied to
|
| + // the shortcut on creation/update. On update, unset properties are ignored;
|
| + // on create (and replaced) unset properties might have a default value (see
|
| + // individual property setters below for details).
|
| + // Callers are encouraged to use the setters provided which take care of
|
| + // setting |options| as desired.
|
| + struct ChromeShortcutProperties {
|
| + enum ChromeIndividualProperties {
|
| + PROPERTIES_CHROME_EXE = 1 << 0,
|
| + PROPERTIES_ARGUMENTS = 1 << 1,
|
| + PROPERTIES_DESCRIPTION = 1 << 2,
|
| + PROPERTIES_ICON = 1 << 3,
|
| + PROPERTIES_APP_ID = 1 << 4,
|
| + PROPERTIES_SHORTCUT_NAME = 1 << 5,
|
| + PROPERTIES_DUAL_MODE = 1 << 6,
|
| + };
|
| +
|
| + explicit ChromeShortcutProperties(ShellChange level_in)
|
| + : level(level_in), dual_mode(false), pin_to_taskbar(false),
|
| + options(0U) {}
|
| +
|
| + // Sets the chrome.exe to launch from this shortcut. This is mandatory when
|
| + // creating a shortcut.
|
| + void set_chrome_exe(const FilePath& chrome_exe_in) {
|
| + chrome_exe = chrome_exe_in;
|
| + options |= PROPERTIES_CHROME_EXE;
|
| + }
|
| +
|
| + // Sets the arguments to be passed to |chrome_exe| when launching from this
|
| + // shortcut.
|
| + // The length of this string must be less than MAX_PATH.
|
| + void set_arguments(const string16& arguments_in) {
|
| + // Size restriction as per MSDN at
|
| + // http://msdn.microsoft.com/library/windows/desktop/bb774954.aspx.
|
| + DCHECK(arguments_in.length() < MAX_PATH);
|
| + arguments = arguments_in;
|
| + options |= PROPERTIES_ARGUMENTS;
|
| + }
|
| +
|
| + // Sets the localized description of the shortcut.
|
| + // Default: the current distribution's description.
|
| + // The length of this string must be less than MAX_PATH.
|
| + void set_description(const string16& description_in) {
|
| + // Size restriction as per MSDN at
|
| + // http://msdn.microsoft.com/library/windows/desktop/bb774955.aspx.
|
| + DCHECK(description_in.length() < MAX_PATH);
|
| + description = description_in;
|
| + options |= PROPERTIES_DESCRIPTION;
|
| + }
|
| +
|
| + // Sets the path to the icon (icon_index set to 0).
|
| + // Default: chrome.exe (icon_index defaults to the current distribution's
|
| + // icon index unless otherwise specified in master_preferences).
|
| + void set_icon(const FilePath& icon_in) {
|
| + icon = icon_in;
|
| + options |= PROPERTIES_ICON;
|
| + }
|
| +
|
| + // Sets the app model id for the shortcut (Win7+).
|
| + // Default: the browser model id for the current install.
|
| + void set_app_id(const string16& app_id_in) {
|
| + app_id = app_id_in;
|
| + options |= PROPERTIES_APP_ID;
|
| + }
|
| +
|
| + // Forces the shortcut's name to |shortcut_name_in|.
|
| + // Default: the current distribution's GetAppShortcutName().
|
| + // The ".lnk" extension will automatically be added to this name.
|
| + void set_shortcut_name(const string16& shortcut_name_in) {
|
| + shortcut_name = shortcut_name_in;
|
| + options |= PROPERTIES_SHORTCUT_NAME;
|
| + }
|
| +
|
| + // Sets whether this is a dual mode shortcut (Win8+).
|
| + // NOTE: Only the default (no arguments and default browser appid) browser
|
| + // shortcut in the Start menu (Start screen on Win8+) should be made dual
|
| + // mode.
|
| + void set_dual_mode(bool dual_mode_in) {
|
| + dual_mode = dual_mode_in;
|
| + options |= PROPERTIES_DUAL_MODE;
|
| + }
|
| +
|
| + // Sets whether to pin this shortcut to the taskbar after creating it
|
| + // (ignored if the shortcut is only being updated).
|
| + // Note: This property doesn't have a mask in |options|.
|
| + void set_pin_to_taskbar(bool pin_to_taskbar_in) {
|
| + pin_to_taskbar = pin_to_taskbar_in;
|
| + }
|
| +
|
| + bool has_chrome_exe() const {
|
| + return (options & PROPERTIES_CHROME_EXE) != 0;
|
| + }
|
| +
|
| + bool has_arguments() const {
|
| + return (options & PROPERTIES_ARGUMENTS) != 0;
|
| + }
|
| +
|
| + bool has_description() const {
|
| + return (options & PROPERTIES_DESCRIPTION) != 0;
|
| + }
|
| +
|
| + bool has_icon() const {
|
| + return (options & PROPERTIES_ICON) != 0;
|
| + }
|
| +
|
| + bool has_app_id() const {
|
| + return (options & PROPERTIES_APP_ID) != 0;
|
| + }
|
| +
|
| + bool has_shortcut_name() const {
|
| + return (options & PROPERTIES_SHORTCUT_NAME) != 0;
|
| + }
|
| +
|
| + bool has_dual_mode() const {
|
| + return (options & PROPERTIES_CHROME_EXE) != 0;
|
| + }
|
| +
|
| + // The level to install this shortcut at (CURRENT_USER for a per-user
|
| + // shortcut and SYSTEM_LEVEL for an all-users shortcut).
|
| + ShellChange level;
|
| +
|
| + FilePath chrome_exe;
|
| + string16 arguments;
|
| + string16 description;
|
| + FilePath icon;
|
| + string16 app_id;
|
| + string16 shortcut_name;
|
| + bool dual_mode;
|
| + bool pin_to_taskbar;
|
| + // Bitfield made of IndividualProperties. Properties set in |options| will
|
| + // be used to create/update the shortcut, others will be ignored on update
|
| + // and possibly replaced by default values on create (see individual
|
| + // property setters above for details on default values).
|
| + uint32 options;
|
| };
|
|
|
| // Relative path of the URL Protocol registry entry (prefixed with '\').
|
| @@ -142,43 +286,25 @@ class ShellUtil {
|
| const string16& chrome_exe,
|
| const string16& suffix);
|
|
|
| - // Creates Chrome shortcut on the Desktop.
|
| + // Sets |path| to the path for a shortcut at the |location| desired for the
|
| + // given |level| (CURRENT_USER for per-user path and SYSTEM_LEVEL for
|
| + // all-users path).
|
| + // Returns false on failure.
|
| + static bool GetShortcutPath(ChromeShortcutLocation location,
|
| + BrowserDistribution* dist,
|
| + ShellChange level,
|
| + FilePath* path);
|
| +
|
| + // Updates Chrome shortcut in |location| (or creates it if |options| specify
|
| + // SHORTCUT_CREATE_ALWAYS).
|
| // |dist| gives the type of browser distribution currently in use.
|
| - // |chrome_exe| provides the target path information.
|
| - // |description| provides the shortcut's "comment" property.
|
| - // |appended_name| provides a string to be appended to the distribution name,
|
| - // and can be the empty string.
|
| - // |arguments| gives a set of arguments to be passed to the executable.
|
| - // |icon_path| provides the path to the icon file to use.
|
| - // |icon_index| provides the index of the icon within the provided icon file.
|
| - // If |shell_change| is CURRENT_USER, the shortcut is created in the
|
| - // Desktop folder of current user's profile.
|
| - // If |shell_change| is SYSTEM_LEVEL, the shortcut is created in the
|
| - // Desktop folder of the "All Users" profile.
|
| - // |options|: bitfield for which the options come from ChromeShortcutOptions.
|
| - // Returns true iff the method causes a shortcut to be created / updated.
|
| - static bool CreateChromeDesktopShortcut(BrowserDistribution* dist,
|
| - const string16& chrome_exe,
|
| - const string16& description,
|
| - const string16& appended_name,
|
| - const string16& arguments,
|
| - const string16& icon_path,
|
| - int icon_index,
|
| - ShellChange shell_change,
|
| - uint32 options);
|
| -
|
| - // Create Chrome shortcut on Quick Launch Bar.
|
| - // If shell_change is CURRENT_USER, the shortcut is created in the
|
| - // Quick Launch folder of current user's profile.
|
| - // If shell_change is SYSTEM_LEVEL, the shortcut is created in the
|
| - // Quick Launch folder of "Default User" profile. This will make sure
|
| - // that this shortcut will be seen by all the new users logging into the
|
| - // system.
|
| - // |options|: bitfield for which the options come from ChromeShortcutOptions.
|
| - static bool CreateChromeQuickLaunchShortcut(BrowserDistribution* dist,
|
| - const string16& chrome_exe,
|
| - int shell_change,
|
| - uint32 options);
|
| + // |properties| and |operation| affect this method as described on their
|
| + // invidividual definitions above.
|
| + static bool CreateOrUpdateChromeShortcut(
|
| + ChromeShortcutLocation location,
|
| + BrowserDistribution* dist,
|
| + const ChromeShortcutProperties& properties,
|
| + ChromeShortcutOperation operation);
|
|
|
| // This method appends the Chrome icon index inside chrome.exe to the
|
| // chrome.exe path passed in as input, to generate the full path for
|
| @@ -198,27 +324,6 @@ class ShellUtil {
|
| // |chrome_exe|: the full path to chrome.exe
|
| static string16 GetChromeDelegateCommand(const string16& chrome_exe);
|
|
|
| - // Returns the localized name of Chrome shortcut in |shortcut|. If
|
| - // |appended_name| is not empty, it is included in the shortcut name. If
|
| - // |alternate| is true, a second localized text that is better suited for
|
| - // certain scenarios is used.
|
| - static bool GetChromeShortcutName(BrowserDistribution* dist,
|
| - bool alternate,
|
| - const string16& appended_name,
|
| - string16* shortcut);
|
| -
|
| - // Gets the desktop path for the current user or all users (if system_level
|
| - // is true) and returns it in 'path' argument. Return true if successful,
|
| - // otherwise returns false.
|
| - static bool GetDesktopPath(bool system_level, FilePath* path);
|
| -
|
| - // Gets the Quick Launch shortcuts path for the current user and
|
| - // returns it in 'path' argument. Return true if successful, otherwise
|
| - // returns false. If system_level is true this function returns the path
|
| - // to Default Users Quick Launch shortcuts path. Adding a shortcut to Default
|
| - // User's profile only affects any new user profiles (not existing ones).
|
| - static bool GetQuickLaunchPath(bool system_level, FilePath* path);
|
| -
|
| // Gets a mapping of all registered browser names (excluding browsers in the
|
| // |dist| distribution) and their reinstall command (which usually sets
|
| // browser as default).
|
| @@ -378,64 +483,24 @@ class ShellUtil {
|
| const string16& protocol,
|
| bool elevate_if_not_admin);
|
|
|
| - // Remove Chrome shortcut from Desktop.
|
| - // If |shell_change| is CURRENT_USER, the shortcut is removed from the
|
| - // Desktop folder of current user's profile.
|
| - // If |shell_change| is SYSTEM_LEVEL, the shortcut is removed from the
|
| - // Desktop folder of "All Users" profile.
|
| - // |options|: bitfield for which the options come from ChromeShortcutOptions.
|
| - // Only SHORTCUT_ALTERNATE is a valid option for this function.
|
| - static bool RemoveChromeDesktopShortcut(BrowserDistribution* dist,
|
| - int shell_change,
|
| - uint32 options);
|
| -
|
| - // Removes a set of existing Chrome desktop shortcuts. |appended_names| is a
|
| - // list of shortcut file names as obtained from
|
| - // ShellUtil::GetChromeShortcutName.
|
| - static bool RemoveChromeDesktopShortcutsWithAppendedNames(
|
| - const std::vector<string16>& appended_names);
|
| -
|
| - // Remove Chrome shortcut from Quick Launch Bar.
|
| - // If shell_change is CURRENT_USER, the shortcut is removed from
|
| - // the Quick Launch folder of current user's profile.
|
| - // If shell_change is SYSTEM_LEVEL, the shortcut is removed from
|
| - // the Quick Launch folder of "Default User" profile.
|
| - static bool RemoveChromeQuickLaunchShortcut(BrowserDistribution* dist,
|
| - int shell_change);
|
| + // Removes installed Chrome shortcut at |location|.
|
| + // |level|: CURRENT_USER to remove the per-user shortcut and SYSTEM_LEVEL to
|
| + // remove the all-users shortcut.
|
| + // |shortcut_name|: If non-null, remove the shortcut named |shortcut_name| at
|
| + // location; otherwise remove the default shortcut at |location|.
|
| + // If |location| is SHORTCUT_START_MENU the shortcut folder specific to |dist|
|
| + // is deleted.
|
| + // Also attempts to unpin the removed shortcut from the taskbar.
|
| + // Returns true on success or if no shortcut is found at |location|.
|
| + static bool RemoveChromeShortcut(ChromeShortcutLocation location,
|
| + BrowserDistribution* dist,
|
| + ShellChange level,
|
| + const string16* shortcut_name);
|
|
|
| // This will remove all secondary tiles from the start screen for |dist|.
|
| static void RemoveChromeStartScreenShortcuts(BrowserDistribution* dist,
|
| const string16& chrome_exe);
|
|
|
| - enum ChromeShortcutOptions {
|
| - SHORTCUT_NO_OPTIONS = 0,
|
| - // Set DualMode property for Windows 8 Metro-enabled shortcuts.
|
| - SHORTCUT_DUAL_MODE = 1 << 0,
|
| - // Create a new shortcut (overwriting if necessary).
|
| - SHORTCUT_CREATE_ALWAYS = 1 << 1,
|
| - // Use an alternate application name for the shortcut (e.g. "The Internet").
|
| - // This option is only applied to the Desktop shortcut.
|
| - SHORTCUT_ALTERNATE = 1 << 2,
|
| - };
|
| -
|
| - // Updates shortcut (or creates a new shortcut) at destination given by
|
| - // shortcut to a target given by chrome_exe. The arguments are given by
|
| - // |arguments| for the target and icon is set based on |icon_path| and
|
| - // |icon_index|. If create_new is set to true, the function will create a new
|
| - // shortcut if it doesn't exist.
|
| - // |options|: bitfield for which the options come from ChromeShortcutOptions.
|
| - // If SHORTCUT_CREATE_ALWAYS is not set in |options|, only specified (non-
|
| - // null) properties on an existing shortcut will be modified. If the shortcut
|
| - // does not exist, this method is a no-op and returns false.
|
| - static bool UpdateChromeShortcut(BrowserDistribution* dist,
|
| - const string16& chrome_exe,
|
| - const string16& shortcut,
|
| - const string16& arguments,
|
| - const string16& description,
|
| - const string16& icon_path,
|
| - int icon_index,
|
| - uint32 options);
|
| -
|
| // Sets |suffix| to the base 32 encoding of the md5 hash of this user's sid
|
| // preceded by a dot.
|
| // This is guaranteed to be unique on the machine and 27 characters long
|
|
|