summaryrefslogtreecommitdiffstats
path: root/chrome/installer/setup/uninstall.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/installer/setup/uninstall.cc')
-rw-r--r--chrome/installer/setup/uninstall.cc24
1 files changed, 9 insertions, 15 deletions
diff --git a/chrome/installer/setup/uninstall.cc b/chrome/installer/setup/uninstall.cc
index d742e62..9403a8a 100644
--- a/chrome/installer/setup/uninstall.cc
+++ b/chrome/installer/setup/uninstall.cc
@@ -119,12 +119,8 @@ installer_util::InstallStatus IsChromeActiveOrUserCancelled(
int32 exit_code = ResultCodes::NORMAL_EXIT;
bool is_timeout = false;
- // We want to continue with the uninstallation only when chrome.exe either
- // returns NORMAL_EXIT (means Chrome is not running, user has confirmed
- // uninstallation and sentinel file/desktop/ql shortcuts have been
- // cleaned up) or UNINSTALL_DELETE_FILE_ERROR (means Chrome is not running,
- // user has confirmed uninstallation but there was a problem with deleting
- // sentinel file, desktop or ql shortcuts).
+ // We ignore all other errors such as whether launching chrome fails,
+ // whether chrome returns UNINSTALL_ERROR, etc.
LOG(INFO) << "Launching Chrome to do uninstall tasks.";
if (installer::LaunchChromeAndWaitForResult(system_uninstall,
kCmdLineOptions,
@@ -132,21 +128,18 @@ installer_util::InstallStatus IsChromeActiveOrUserCancelled(
&exit_code,
&is_timeout)) {
if (is_timeout || exit_code == ResultCodes::UNINSTALL_CHROME_ALIVE) {
- LOG(INFO) << "Can't uninstall when chrome is still running";
+ LOG(ERROR) << "Can't uninstall when chrome is still running";
return installer_util::CHROME_RUNNING;
} else if (exit_code == ResultCodes::UNINSTALL_USER_CANCEL) {
LOG(INFO) << "User cancelled uninstall operation";
return installer_util::UNINSTALL_CANCELLED;
- } else if (exit_code == ResultCodes::NORMAL_EXIT) {
- LOG(INFO) << "chrome.exe confirmed uninstallation from user.";
- return installer_util::UNINSTALL_CONFIRMED;
- } else if (exit_code == ResultCodes::UNINSTALL_DELETE_FILE_ERROR) {
- LOG(ERROR) << "chrome.exe returned delete file error.";
- return installer_util::UNINSTALL_CONFIRMED;
+ } else if (exit_code == ResultCodes::UNINSTALL_ERROR) {
+ LOG(ERROR) << "chrome.exe reported error while uninstalling.";
+ return installer_util::UNINSTALL_FAILED;
}
}
- return installer_util::UNINSTALL_FAILED;
+ return installer_util::UNINSTALL_CONFIRMED;
}
// Read the URL from the resource file and substitute the locale parameter
@@ -229,7 +222,8 @@ installer_util::InstallStatus installer_setup::UninstallChrome(
const installer::Version& installed_version, bool remove_all) {
installer_util::InstallStatus status =
IsChromeActiveOrUserCancelled(system_uninstall);
- if (status != installer_util::UNINSTALL_CONFIRMED)
+ if (status == installer_util::CHROME_RUNNING ||
+ status == installer_util::UNINSTALL_CANCELLED)
return status;
// Uninstall Gears first.