Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(366)

Side by Side Diff: chrome/installer/util/browser_distribution.cc

Issue 2621713004: Remove *BinariesDistribution and ChromeBinariesOperations from installer_util. (Closed)
Patch Set: sync to position 442533 Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698