Chromium Code Reviews| 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 a class that contains various method related to branding. | 5 // This file defines a class that contains various method related to branding. |
| 6 // It provides only default implementations of these methods. Usually to add | 6 // It provides only default implementations of these methods. Usually to add |
| 7 // specific branding, we will need to extend this class with a custom | 7 // specific branding, we will need to extend this class with a custom |
| 8 // implementation. | 8 // implementation. |
| 9 | 9 |
| 10 #include "chrome/installer/util/browser_distribution.h" | 10 #include "chrome/installer/util/browser_distribution.h" |
| 11 | 11 |
| 12 #include <utility> | 12 #include <utility> |
| 13 | 13 |
| 14 #include "base/atomicops.h" | 14 #include "base/atomicops.h" |
| 15 #include "base/command_line.h" | 15 #include "base/command_line.h" |
| 16 #include "base/files/file_path.h" | 16 #include "base/files/file_path.h" |
| 17 #include "base/logging.h" | 17 #include "base/logging.h" |
| 18 #include "base/memory/ptr_util.h" | 18 #include "base/memory/ptr_util.h" |
| 19 #include "base/win/registry.h" | 19 #include "base/win/registry.h" |
| 20 #include "base/win/windows_version.h" | 20 #include "base/win/windows_version.h" |
| 21 #include "chrome/common/chrome_icon_resources_win.h" | 21 #include "chrome/common/chrome_icon_resources_win.h" |
| 22 #include "chrome/common/env_vars.h" | 22 #include "chrome/common/env_vars.h" |
| 23 #include "chrome/installer/util/app_registration_data.h" | 23 #include "chrome/installer/util/app_registration_data.h" |
| 24 #include "chrome/installer/util/chromium_binaries_distribution.h" | |
| 25 #include "chrome/installer/util/google_chrome_binaries_distribution.h" | |
| 26 #include "chrome/installer/util/google_chrome_distribution.h" | 24 #include "chrome/installer/util/google_chrome_distribution.h" |
| 27 #include "chrome/installer/util/google_chrome_sxs_distribution.h" | 25 #include "chrome/installer/util/google_chrome_sxs_distribution.h" |
| 28 #include "chrome/installer/util/install_util.h" | 26 #include "chrome/installer/util/install_util.h" |
| 29 #include "chrome/installer/util/installer_util_strings.h" | 27 #include "chrome/installer/util/installer_util_strings.h" |
| 30 #include "chrome/installer/util/l10n_string_util.h" | 28 #include "chrome/installer/util/l10n_string_util.h" |
| 31 #include "chrome/installer/util/master_preferences.h" | 29 #include "chrome/installer/util/master_preferences.h" |
| 32 #include "chrome/installer/util/non_updating_app_registration_data.h" | 30 #include "chrome/installer/util/non_updating_app_registration_data.h" |
| 33 | 31 |
| 34 using installer::MasterPreferences; | 32 using installer::MasterPreferences; |
| 35 | 33 |
| 36 namespace { | 34 namespace { |
| 37 | 35 |
| 38 const wchar_t kChromiumActiveSetupGuid[] = | 36 const wchar_t kChromiumActiveSetupGuid[] = |
| 39 L"{7D2B3E1D-D096-4594-9D8F-A6667F12E0AC}"; | 37 L"{7D2B3E1D-D096-4594-9D8F-A6667F12E0AC}"; |
| 40 | 38 |
| 41 const wchar_t kCommandExecuteImplUuid[] = | 39 const wchar_t kCommandExecuteImplUuid[] = |
| 42 L"{A2DF06F9-A21A-44A8-8A99-8B9C84F29160}"; | 40 L"{A2DF06F9-A21A-44A8-8A99-8B9C84F29160}"; |
| 43 | 41 |
| 44 // The BrowserDistribution objects are never freed. | 42 // The BrowserDistribution objects are never freed. |
| 45 BrowserDistribution* g_browser_distribution = NULL; | 43 BrowserDistribution* g_browser_distribution = NULL; |
| 46 BrowserDistribution* g_binaries_distribution = NULL; | |
| 47 | |
| 48 BrowserDistribution::Type GetCurrentDistributionType() { | 44 BrowserDistribution::Type GetCurrentDistributionType() { |
| 49 return BrowserDistribution::CHROME_BROWSER; | 45 return BrowserDistribution::CHROME_BROWSER; |
| 50 } | 46 } |
| 51 | 47 |
| 52 } // namespace | 48 } // namespace |
| 53 | 49 |
| 54 BrowserDistribution::BrowserDistribution() | 50 BrowserDistribution::BrowserDistribution() |
| 55 : type_(CHROME_BROWSER), | 51 : type_(CHROME_BROWSER), |
| 56 app_reg_data_(base::MakeUnique<NonUpdatingAppRegistrationData>( | 52 app_reg_data_(base::MakeUnique<NonUpdatingAppRegistrationData>( |
| 57 L"Software\\Chromium")) {} | 53 L"Software\\Chromium")) {} |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 75 } | 71 } |
| 76 | 72 |
| 77 return *dist; | 73 return *dist; |
| 78 } | 74 } |
| 79 | 75 |
| 80 BrowserDistribution* BrowserDistribution::GetDistribution() { | 76 BrowserDistribution* BrowserDistribution::GetDistribution() { |
| 81 return GetSpecificDistribution(GetCurrentDistributionType()); | 77 return GetSpecificDistribution(GetCurrentDistributionType()); |
| 82 } | 78 } |
| 83 | 79 |
| 84 // static | 80 // static |
| 85 BrowserDistribution* BrowserDistribution::GetSpecificDistribution( | 81 BrowserDistribution* BrowserDistribution::GetSpecificDistribution( |
|
robertshield
2017/01/10 14:49:30
This method shrinking makes me so happy.
grt (UTC plus 2)
2017/01/10 19:54:41
How happy will you be if I remove BrowserDistribut
| |
| 86 BrowserDistribution::Type type) { | 82 BrowserDistribution::Type type) { |
| 83 DCHECK_EQ(type, CHROME_BROWSER); | |
| 87 BrowserDistribution* dist = NULL; | 84 BrowserDistribution* dist = NULL; |
| 88 | 85 |
| 89 switch (type) { | |
| 90 case CHROME_BROWSER: | |
| 91 #if defined(GOOGLE_CHROME_BUILD) | 86 #if defined(GOOGLE_CHROME_BUILD) |
| 92 if (InstallUtil::IsChromeSxSProcess()) { | 87 if (InstallUtil::IsChromeSxSProcess()) { |
| 93 dist = GetOrCreateBrowserDistribution<GoogleChromeSxSDistribution>( | 88 dist = GetOrCreateBrowserDistribution<GoogleChromeSxSDistribution>( |
| 94 &g_browser_distribution); | 89 &g_browser_distribution); |
| 95 } else { | 90 } else { |
| 96 dist = GetOrCreateBrowserDistribution<GoogleChromeDistribution>( | 91 dist = GetOrCreateBrowserDistribution<GoogleChromeDistribution>( |
| 97 &g_browser_distribution); | 92 &g_browser_distribution); |
| 98 } | 93 } |
| 99 #else | 94 #else |
| 100 dist = GetOrCreateBrowserDistribution<BrowserDistribution>( | 95 dist = GetOrCreateBrowserDistribution<BrowserDistribution>( |
| 101 &g_browser_distribution); | 96 &g_browser_distribution); |
| 102 #endif | 97 #endif |
| 103 break; | |
| 104 | |
| 105 default: | |
| 106 DCHECK_EQ(CHROME_BINARIES, type); | |
| 107 #if defined(GOOGLE_CHROME_BUILD) | |
| 108 dist = GetOrCreateBrowserDistribution<GoogleChromeBinariesDistribution>( | |
| 109 &g_binaries_distribution); | |
| 110 #else | |
| 111 dist = GetOrCreateBrowserDistribution<ChromiumBinariesDistribution>( | |
| 112 &g_binaries_distribution); | |
| 113 #endif | |
| 114 } | |
| 115 | 98 |
| 116 return dist; | 99 return dist; |
| 117 } | 100 } |
| 118 | 101 |
| 119 const AppRegistrationData& BrowserDistribution::GetAppRegistrationData() const { | 102 const AppRegistrationData& BrowserDistribution::GetAppRegistrationData() const { |
| 120 return *app_reg_data_; | 103 return *app_reg_data_; |
| 121 } | 104 } |
| 122 | 105 |
| 123 base::string16 BrowserDistribution::GetAppGuid() const { | 106 base::string16 BrowserDistribution::GetAppGuid() const { |
| 124 return app_reg_data_->GetAppGuid(); | 107 return app_reg_data_->GetAppGuid(); |
| (...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 248 installer::InstallStatus install_status) { | 231 installer::InstallStatus install_status) { |
| 249 } | 232 } |
| 250 | 233 |
| 251 bool BrowserDistribution::ShouldSetExperimentLabels() { | 234 bool BrowserDistribution::ShouldSetExperimentLabels() { |
| 252 return false; | 235 return false; |
| 253 } | 236 } |
| 254 | 237 |
| 255 bool BrowserDistribution::HasUserExperiments() { | 238 bool BrowserDistribution::HasUserExperiments() { |
| 256 return false; | 239 return false; |
| 257 } | 240 } |
| OLD | NEW |