| 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 // This file defines specific implementation of BrowserDistribution class for | 5 // This file defines specific implementation of BrowserDistribution class for |
| 6 // Google Chrome. | 6 // Google Chrome. |
| 7 | 7 |
| 8 #include "chrome/installer/util/google_chrome_distribution.h" | 8 #include "chrome/installer/util/google_chrome_distribution.h" |
| 9 | 9 |
| 10 #include <windows.h> | 10 #include <windows.h> |
| (...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 90 // process runs inside a Job object controlled by the shell. As long as there | 90 // process runs inside a Job object controlled by the shell. As long as there |
| 91 // are processes running, the shell will not close the uninstall applet. WMI | 91 // are processes running, the shell will not close the uninstall applet. WMI |
| 92 // allows us to escape from the Job object so the applet will close. | 92 // allows us to escape from the Job object so the applet will close. |
| 93 installer::WMIProcess::Launch(command, &pid); | 93 installer::WMIProcess::Launch(command, &pid); |
| 94 } | 94 } |
| 95 | 95 |
| 96 } // namespace | 96 } // namespace |
| 97 | 97 |
| 98 GoogleChromeDistribution::GoogleChromeDistribution() | 98 GoogleChromeDistribution::GoogleChromeDistribution() |
| 99 : BrowserDistribution(CHROME_BROWSER, | 99 : BrowserDistribution(CHROME_BROWSER, |
| 100 scoped_ptr<AppRegistrationData>( | 100 std::unique_ptr<AppRegistrationData>( |
| 101 new UpdatingAppRegistrationData(kChromeGuid))) { | 101 new UpdatingAppRegistrationData(kChromeGuid))) {} |
| 102 } | |
| 103 | 102 |
| 104 GoogleChromeDistribution::GoogleChromeDistribution( | 103 GoogleChromeDistribution::GoogleChromeDistribution( |
| 105 scoped_ptr<AppRegistrationData> app_reg_data) | 104 std::unique_ptr<AppRegistrationData> app_reg_data) |
| 106 : BrowserDistribution(CHROME_BROWSER, std::move(app_reg_data)) {} | 105 : BrowserDistribution(CHROME_BROWSER, std::move(app_reg_data)) {} |
| 107 | 106 |
| 108 void GoogleChromeDistribution::DoPostUninstallOperations( | 107 void GoogleChromeDistribution::DoPostUninstallOperations( |
| 109 const Version& version, | 108 const Version& version, |
| 110 const base::FilePath& local_data_path, | 109 const base::FilePath& local_data_path, |
| 111 const base::string16& distribution_data) { | 110 const base::string16& distribution_data) { |
| 112 // Send the Chrome version and OS version as params to the form. | 111 // Send the Chrome version and OS version as params to the form. |
| 113 // It would be nice to send the locale, too, but I don't see an | 112 // It would be nice to send the locale, too, but I don't see an |
| 114 // easy way to get that in the existing code. It's something we | 113 // easy way to get that in the existing code. It's something we |
| 115 // can add later, if needed. | 114 // can add later, if needed. |
| (...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 246 // that this was probably a stable channel release. | 245 // that this was probably a stable channel release. |
| 247 client_state_key.ReadValue(google_update::kRegApField, &ap_value); | 246 client_state_key.ReadValue(google_update::kRegApField, &ap_value); |
| 248 result.append(google_update::kRegApField); | 247 result.append(google_update::kRegApField); |
| 249 result.append(L"="); | 248 result.append(L"="); |
| 250 result.append(ap_value); | 249 result.append(ap_value); |
| 251 | 250 |
| 252 // Crash client id. | 251 // Crash client id. |
| 253 base::FilePath crash_dir; | 252 base::FilePath crash_dir; |
| 254 if (chrome::GetDefaultCrashDumpLocation(&crash_dir)) { | 253 if (chrome::GetDefaultCrashDumpLocation(&crash_dir)) { |
| 255 crashpad::UUID client_id; | 254 crashpad::UUID client_id; |
| 256 scoped_ptr<crashpad::CrashReportDatabase> database( | 255 std::unique_ptr<crashpad::CrashReportDatabase> database( |
| 257 crashpad::CrashReportDatabase::InitializeWithoutCreating(crash_dir)); | 256 crashpad::CrashReportDatabase::InitializeWithoutCreating(crash_dir)); |
| 258 if (database && database->GetSettings()->GetClientID(&client_id)) | 257 if (database && database->GetSettings()->GetClientID(&client_id)) |
| 259 result.append(L"&crash_client_id=").append(client_id.ToString16()); | 258 result.append(L"&crash_client_id=").append(client_id.ToString16()); |
| 260 } | 259 } |
| 261 | 260 |
| 262 return result; | 261 return result; |
| 263 } | 262 } |
| 264 | 263 |
| 265 base::string16 GoogleChromeDistribution::GetUninstallRegPath() { | 264 base::string16 GoogleChromeDistribution::GetUninstallRegPath() { |
| 266 return L"Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\" | 265 return L"Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\" |
| (...skipping 24 matching lines...) Expand all Loading... |
| 291 GetAppGuid()); | 290 GetAppGuid()); |
| 292 } | 291 } |
| 293 | 292 |
| 294 bool GoogleChromeDistribution::ShouldSetExperimentLabels() { | 293 bool GoogleChromeDistribution::ShouldSetExperimentLabels() { |
| 295 return true; | 294 return true; |
| 296 } | 295 } |
| 297 | 296 |
| 298 bool GoogleChromeDistribution::HasUserExperiments() { | 297 bool GoogleChromeDistribution::HasUserExperiments() { |
| 299 return true; | 298 return true; |
| 300 } | 299 } |
| OLD | NEW |