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

Side by Side Diff: chrome/common/platform_util_win.cc

Issue 523151: Fix crash due to parsing of raw branch code from Google Update (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 10 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 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/common/platform_util.h" 5 #include "chrome/common/platform_util.h"
6 6
7 #include <commdlg.h> 7 #include <commdlg.h>
8 #include <dwmapi.h> 8 #include <dwmapi.h>
9 #include <shellapi.h> 9 #include <shellapi.h>
10 #include <shlobj.h> 10 #include <shlobj.h>
11 11
12 #include "app/gfx/native_widget_types.h" 12 #include "app/gfx/native_widget_types.h"
13 #include "app/win_util.h" 13 #include "app/win_util.h"
14 #include "base/file_path.h" 14 #include "base/file_path.h"
15 #include "base/file_util.h" 15 #include "base/file_util.h"
16 #include "base/logging.h" 16 #include "base/logging.h"
17 #include "base/registry.h" 17 #include "base/registry.h"
18 #include "base/scoped_comptr_win.h" 18 #include "base/scoped_comptr_win.h"
19 #include "base/string_util.h" 19 #include "base/string_util.h"
20 #include "chrome/installer/util/google_update_constants.h"
20 #include "googleurl/src/gurl.h" 21 #include "googleurl/src/gurl.h"
21 22
22 namespace platform_util { 23 namespace platform_util {
23 24
24 void ShowItemInFolder(const FilePath& full_path) { 25 void ShowItemInFolder(const FilePath& full_path) {
25 FilePath dir = full_path.DirName(); 26 FilePath dir = full_path.DirName();
26 // ParseDisplayName will fail if the directory is "C:", it must be "C:\\". 27 // ParseDisplayName will fail if the directory is "C:", it must be "C:\\".
27 if (dir.value() == L"" || !file_util::EnsureEndsWithSeparator(&dir)) 28 if (dir.value() == L"" || !file_util::EnsureEndsWithSeparator(&dir))
28 return; 29 return;
29 30
(...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after
152 } 153 }
153 154
154 void SimpleErrorBox(gfx::NativeWindow parent, 155 void SimpleErrorBox(gfx::NativeWindow parent,
155 const string16& title, 156 const string16& title,
156 const string16& message) { 157 const string16& message) {
157 win_util::MessageBox(parent, message, title, MB_OK | MB_SETFOREGROUND); 158 win_util::MessageBox(parent, message, title, MB_OK | MB_SETFOREGROUND);
158 } 159 }
159 160
160 161
161 namespace { 162 namespace {
162 // Constants copied from src/tools/channel_changer/channel_changer.cc.
163 163
164 // The Google Update key to read to find out which branch you are on.
165 const wchar_t* const kChromeClientStateKey =
166 L"Software\\Google\\Update\\ClientState\\"
167 L"{8A69D345-D564-463C-AFF1-A69D9E530F96}";
168
169 // The Google Client key to read to find out which branch you are on.
170 const wchar_t* const kChromeClientsKey =
171 L"Software\\Google\\Update\\Clients\\"
172 L"{8A69D345-D564-463C-AFF1-A69D9E530F96}";
173
174 // The Google Update value that defines which branch you are on.
175 const wchar_t* const kBranchKey = L"ap";
176
177 // The suffix Google Update sometimes adds to the channel name (channel names
178 // are defined in kBranchStrings), indicating that a full install is needed. We
179 // strip this out (if present) for the purpose of determining which channel you
180 // are on.
181 const wchar_t* const kChannelSuffix = L"-full";
182
183 // See DetectBranch() in src/tools/channel_changer/channel_changer.cc.
184 std::wstring CurrentChromeChannel() { 164 std::wstring CurrentChromeChannel() {
185 std::wstring update_branch = L"stable"; // default if we get confused. 165 std::wstring update_branch = L"stable"; // The default if we get confused.
Erik does not do reviews 2010/01/07 23:50:51 per mark's comment, this shouldn't be the default
186 166
187 // See if we can find the Clients key on the HKLM branch. 167 // See if we can find the Clients key on the HKLM branch.
188 HKEY registry_hive = HKEY_LOCAL_MACHINE; 168 HKEY registry_hive = HKEY_LOCAL_MACHINE;
189 RegKey google_update_hklm(registry_hive, kChromeClientsKey, KEY_READ); 169 std::wstring key = google_update::kRegPathClients + std::wstring(L"\\") +
170 google_update::kChromeUpgradeCode;
171 RegKey google_update_hklm(registry_hive, key.c_str(), KEY_READ);
190 if (!google_update_hklm.Valid()) { 172 if (!google_update_hklm.Valid()) {
191 // HKLM failed us, try the same for the HKCU branch. 173 // HKLM failed us, try the same for the HKCU branch.
192 registry_hive = HKEY_CURRENT_USER; 174 registry_hive = HKEY_CURRENT_USER;
193 RegKey google_update_hkcu(registry_hive, kChromeClientsKey, KEY_READ); 175 RegKey google_update_hkcu(registry_hive, key.c_str(), KEY_READ);
194 if (!google_update_hkcu.Valid()) { 176 if (!google_update_hkcu.Valid()) {
195 // Unknown. 177 // Unknown.
196 registry_hive = 0; 178 registry_hive = 0;
197 } 179 }
198 } 180 }
199 181
200 if (registry_hive != 0) { 182 if (registry_hive != 0) {
201 // Now that we know which hive to use, read the 'ap' key from it. 183 // Now that we know which hive to use, read the 'ap' key from it.
202 RegKey client_state(registry_hive, kChromeClientStateKey, KEY_READ); 184 std::wstring key = google_update::kRegPathClientState +
203 client_state.ReadValue(kBranchKey, &update_branch); 185 std::wstring(L"\\") + google_update::kChromeUpgradeCode;
204 186 RegKey client_state(registry_hive, key.c_str(), KEY_READ);
205 // We look for '1.1-beta' or '1.1-dev', but Google Update might have added 187 client_state.ReadValue(google_update::kRegApField, &update_branch);
206 // '-full' to the channel name, which we need to strip out to determine what
207 // channel you are on.
208 std::wstring suffix = kChannelSuffix;
209 if (update_branch.length() > suffix.length()) {
210 size_t index = update_branch.rfind(suffix);
211 if (index != std::wstring::npos &&
212 index == update_branch.length() - suffix.length()) {
213 update_branch = update_branch.substr(0, index);
214 }
215 }
216 } 188 }
217 189
218 // Map to something pithy for human consumption. 190 // Map to something pithy for human consumption. There are no rules as to
219 if ((update_branch == L"2.0-dev") ||(update_branch == L"1.1-dev")) 191 // what the ap string can contain, but generally it will contain a number
192 // followed by a dash followed by the branch name (and then some random
193 // suffix).
194 if (update_branch.find(L"-beta") != std::wstring::npos)
195 update_branch = L"beta";
196 else if (update_branch.find(L"-dev") != std::wstring::npos)
220 update_branch = L"dev"; 197 update_branch = L"dev";
221 else if (update_branch == L"1.1-beta") 198 else
222 update_branch = L"beta"; 199 update_branch = L"";
Erik does not do reviews 2010/01/07 23:50:51 Add a comment here about why we don't return "stab
223 200
224 return update_branch; 201 return update_branch;
225 } 202 }
226 203
227 } // namespace 204 } // namespace
228 205
229 string16 GetVersionStringModifier() { 206 string16 GetVersionStringModifier() {
230 #if defined(GOOGLE_CHROME_BUILD) 207 #if defined(GOOGLE_CHROME_BUILD)
231 return CurrentChromeChannel(); 208 return CurrentChromeChannel();
232 #else 209 #else
233 return EmptyString16(); 210 return EmptyString16();
234 #endif 211 #endif
235 } 212 }
236 213
237 } // namespace platform_util 214 } // namespace platform_util
OLDNEW
« no previous file with comments | « chrome/browser/views/about_chrome_view.cc ('k') | chrome/installer/util/google_update_constants.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698