OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/installer/setup/setup_main.h" | 5 #include "chrome/installer/setup/setup_main.h" |
6 | 6 |
7 #include <windows.h> | 7 #include <windows.h> |
8 #include <msi.h> | 8 #include <msi.h> |
9 #include <shellapi.h> | 9 #include <shellapi.h> |
10 #include <shlobj.h> | 10 #include <shlobj.h> |
11 #include <stddef.h> | 11 #include <stddef.h> |
12 #include <stdint.h> | 12 #include <stdint.h> |
13 | 13 |
14 #include <string> | 14 #include <string> |
15 | 15 |
16 #include "base/at_exit.h" | 16 #include "base/at_exit.h" |
| 17 #include "base/bind.h" |
17 #include "base/command_line.h" | 18 #include "base/command_line.h" |
18 #include "base/file_version_info.h" | 19 #include "base/file_version_info.h" |
19 #include "base/files/file_path.h" | 20 #include "base/files/file_path.h" |
20 #include "base/files/file_util.h" | 21 #include "base/files/file_util.h" |
21 #include "base/files/scoped_temp_dir.h" | 22 #include "base/files/scoped_temp_dir.h" |
22 #include "base/macros.h" | 23 #include "base/macros.h" |
23 #include "base/memory/scoped_ptr.h" | 24 #include "base/memory/scoped_ptr.h" |
24 #include "base/path_service.h" | 25 #include "base/path_service.h" |
25 #include "base/process/launch.h" | 26 #include "base/process/launch.h" |
26 #include "base/process/memory.h" | 27 #include "base/process/memory.h" |
(...skipping 17 matching lines...) Expand all Loading... |
44 #include "chrome/installer/setup/archive_patch_helper.h" | 45 #include "chrome/installer/setup/archive_patch_helper.h" |
45 #include "chrome/installer/setup/install.h" | 46 #include "chrome/installer/setup/install.h" |
46 #include "chrome/installer/setup/install_worker.h" | 47 #include "chrome/installer/setup/install_worker.h" |
47 #include "chrome/installer/setup/installer_crash_reporting.h" | 48 #include "chrome/installer/setup/installer_crash_reporting.h" |
48 #include "chrome/installer/setup/installer_metrics.h" | 49 #include "chrome/installer/setup/installer_metrics.h" |
49 #include "chrome/installer/setup/setup_constants.h" | 50 #include "chrome/installer/setup/setup_constants.h" |
50 #include "chrome/installer/setup/setup_util.h" | 51 #include "chrome/installer/setup/setup_util.h" |
51 #include "chrome/installer/setup/uninstall.h" | 52 #include "chrome/installer/setup/uninstall.h" |
52 #include "chrome/installer/util/browser_distribution.h" | 53 #include "chrome/installer/util/browser_distribution.h" |
53 #include "chrome/installer/util/delete_after_reboot_helper.h" | 54 #include "chrome/installer/util/delete_after_reboot_helper.h" |
| 55 #include "chrome/installer/util/delete_old_versions.h" |
54 #include "chrome/installer/util/delete_tree_work_item.h" | 56 #include "chrome/installer/util/delete_tree_work_item.h" |
55 #include "chrome/installer/util/google_update_constants.h" | 57 #include "chrome/installer/util/google_update_constants.h" |
56 #include "chrome/installer/util/google_update_settings.h" | 58 #include "chrome/installer/util/google_update_settings.h" |
57 #include "chrome/installer/util/google_update_util.h" | 59 #include "chrome/installer/util/google_update_util.h" |
58 #include "chrome/installer/util/helper.h" | 60 #include "chrome/installer/util/helper.h" |
59 #include "chrome/installer/util/html_dialog.h" | 61 #include "chrome/installer/util/html_dialog.h" |
60 #include "chrome/installer/util/install_util.h" | 62 #include "chrome/installer/util/install_util.h" |
61 #include "chrome/installer/util/installation_state.h" | 63 #include "chrome/installer/util/installation_state.h" |
62 #include "chrome/installer/util/installation_validator.h" | 64 #include "chrome/installer/util/installation_validator.h" |
63 #include "chrome/installer/util/installer_state.h" | 65 #include "chrome/installer/util/installer_state.h" |
(...skipping 252 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
316 << BrowserDistribution::GetSpecificDistribution(type)-> | 318 << BrowserDistribution::GetSpecificDistribution(type)-> |
317 GetDisplayName(); | 319 GetDisplayName(); |
318 } | 320 } |
319 } | 321 } |
320 } | 322 } |
321 } | 323 } |
322 } | 324 } |
323 | 325 |
324 // This function is called when --rename-chrome-exe option is specified on | 326 // This function is called when --rename-chrome-exe option is specified on |
325 // setup.exe command line. This function assumes an in-use update has happened | 327 // setup.exe command line. This function assumes an in-use update has happened |
326 // for Chrome so there should be a file called new_chrome.exe on the file | 328 // for Chrome so there should be a file called new_chrome.exe on the file system |
327 // system and a key called 'opv' in the registry. This function will move | 329 // and a key called 'opv' in the registry. This function will move |
328 // new_chrome.exe to chrome.exe and delete 'opv' key in one atomic operation. | 330 // new_chrome.exe to chrome.exe and delete 'opv' key in one atomic operation. |
329 // This function also deletes elevation policies associated with the old version | 331 // This function also takes care of deleting files and elevation policies that |
330 // if they exist. | 332 // belong to old versions of Chrome. |
331 installer::InstallStatus RenameChromeExecutables( | 333 installer::InstallStatus RenameChromeExecutables( |
332 const InstallationState& original_state, | 334 const InstallationState& original_state, |
333 InstallerState* installer_state) { | 335 InstallerState* installer_state) { |
334 // See what products are already installed in multi mode. When we do the | 336 // See what products are already installed in multi mode. When we do the |
335 // rename for multi installs, we must update all installations since they | 337 // rename for multi installs, we must update all installations since they |
336 // share the binaries. | 338 // share the binaries. |
337 AddExistingMultiInstalls(original_state, installer_state); | 339 AddExistingMultiInstalls(original_state, installer_state); |
338 const base::FilePath &target_path = installer_state->target_path(); | 340 const base::FilePath &target_path = installer_state->target_path(); |
339 base::FilePath chrome_exe(target_path.Append(installer::kChromeExe)); | 341 base::FilePath chrome_exe(target_path.Append(installer::kChromeExe)); |
340 base::FilePath chrome_new_exe(target_path.Append(installer::kChromeNewExe)); | 342 base::FilePath chrome_new_exe(target_path.Append(installer::kChromeNewExe)); |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
380 install_list->AddDeleteRegValueWorkItem( | 382 install_list->AddDeleteRegValueWorkItem( |
381 reg_root, | 383 reg_root, |
382 version_key, | 384 version_key, |
383 KEY_WOW64_32KEY, | 385 KEY_WOW64_32KEY, |
384 google_update::kRegCriticalVersionField); | 386 google_update::kRegCriticalVersionField); |
385 install_list->AddDeleteRegValueWorkItem(reg_root, | 387 install_list->AddDeleteRegValueWorkItem(reg_root, |
386 version_key, | 388 version_key, |
387 KEY_WOW64_32KEY, | 389 KEY_WOW64_32KEY, |
388 google_update::kRegRenameCmdField); | 390 google_update::kRegRenameCmdField); |
389 } | 391 } |
| 392 |
| 393 // Delete old versions. |
| 394 // TODO(fdoray): Launch a cleanup process when this fails. crbug.com/451546 |
| 395 AddDeleteOldVersionsWorkItem(*installer_state, install_list.get()) |
| 396 ->set_ignore_failure(true); |
| 397 |
390 installer::InstallStatus ret = installer::RENAME_SUCCESSFUL; | 398 installer::InstallStatus ret = installer::RENAME_SUCCESSFUL; |
391 if (!install_list->Do()) { | 399 if (!install_list->Do()) { |
392 LOG(ERROR) << "Renaming of executables failed. Rolling back any changes."; | 400 LOG(ERROR) << "Renaming of executables failed. Rolling back any changes."; |
393 install_list->Rollback(); | 401 install_list->Rollback(); |
394 ret = installer::RENAME_FAILED; | 402 ret = installer::RENAME_FAILED; |
395 } | 403 } |
396 // temp_path's dtor will take care of deleting or scheduling itself for | 404 // temp_path's dtor will take care of deleting or scheduling itself for |
397 // deletion at reboot when this scope closes. | 405 // deletion at reboot when this scope closes. |
398 VLOG(1) << "Deleting temporary directory " << temp_path.path().value(); | 406 VLOG(1) << "Deleting temporary directory " << temp_path.path().value(); |
399 | 407 |
(...skipping 1385 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1785 // to pass through, since this is only returned on uninstall which is | 1793 // to pass through, since this is only returned on uninstall which is |
1786 // never invoked directly by Google Update. | 1794 // never invoked directly by Google Update. |
1787 return_code = InstallUtil::GetInstallReturnCode(install_status); | 1795 return_code = InstallUtil::GetInstallReturnCode(install_status); |
1788 } | 1796 } |
1789 | 1797 |
1790 installer::EndPersistentHistogramStorage(installer_state.target_path()); | 1798 installer::EndPersistentHistogramStorage(installer_state.target_path()); |
1791 VLOG(1) << "Installation complete, returning: " << return_code; | 1799 VLOG(1) << "Installation complete, returning: " << return_code; |
1792 | 1800 |
1793 return return_code; | 1801 return return_code; |
1794 } | 1802 } |
OLD | NEW |