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

Side by Side Diff: base/version.cc

Issue 1364002: Fixed bug where an empty version string is considered valid. (Closed)
Patch Set: addressed comments Created 10 years, 9 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
« no previous file with comments | « base/version.h ('k') | base/version_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 <vector> 5 #include "base/version.h"
6 6
7 #include "base/logging.h"
7 #include "base/string_util.h" 8 #include "base/string_util.h"
8 #include "base/version.h"
9 9
10 // static 10 // static
11 Version* Version::GetVersionFromString(const std::wstring& version_str) { 11 Version* Version::GetVersionFromString(const std::wstring& version_str) {
12 if (!IsStringASCII(version_str)) 12 if (!IsStringASCII(version_str))
13 return NULL; 13 return NULL;
14 return GetVersionFromString(WideToASCII(version_str)); 14 return GetVersionFromString(WideToASCII(version_str));
15 } 15 }
16 16
17 // static 17 // static
18 Version* Version::GetVersionFromString(const std::string& version_str) { 18 Version* Version::GetVersionFromString(const std::string& version_str) {
19 Version* vers = new Version(); 19 Version* vers = new Version();
20 if (vers->InitFromString(version_str)) 20 if (vers->InitFromString(version_str)) {
21 DCHECK(vers->is_valid_);
21 return vers; 22 return vers;
23 }
22 delete vers; 24 delete vers;
23 return NULL; 25 return NULL;
24 } 26 }
25 27
28 Version::Version() : is_valid_(false) {}
29
26 bool Version::Equals(const Version& that) const { 30 bool Version::Equals(const Version& that) const {
31 DCHECK(is_valid_);
32 DCHECK(that.is_valid_);
27 return CompareTo(that) == 0; 33 return CompareTo(that) == 0;
28 } 34 }
29 35
30 int Version::CompareTo(const Version& other) const { 36 int Version::CompareTo(const Version& other) const {
31 std::vector<uint16> other_components = other.components(); 37 DCHECK(is_valid_);
32 size_t count = std::min(components_.size(), other_components.size()); 38 DCHECK(other.is_valid_);
39 size_t count = std::min(components_.size(), other.components_.size());
33 for (size_t i = 0; i < count; ++i) { 40 for (size_t i = 0; i < count; ++i) {
34 if (components_[i] > other_components[i]) 41 if (components_[i] > other.components_[i])
35 return 1; 42 return 1;
36 if (components_[i] < other_components[i]) 43 if (components_[i] < other.components_[i])
37 return -1; 44 return -1;
38 } 45 }
39 if (components_.size() > other_components.size()) { 46 if (components_.size() > other.components_.size()) {
40 for (size_t i = count; i < components_.size(); ++i) 47 for (size_t i = count; i < components_.size(); ++i)
41 if (components_[i] > 0) 48 if (components_[i] > 0)
42 return 1; 49 return 1;
43 } else if (components_.size() < other_components.size()) { 50 } else if (components_.size() < other.components_.size()) {
44 for (size_t i = count; i < other_components.size(); ++i) 51 for (size_t i = count; i < other.components_.size(); ++i)
45 if (other_components[i] > 0) 52 if (other.components_[i] > 0)
46 return -1; 53 return -1;
47 } 54 }
48 return 0; 55 return 0;
49 } 56 }
50 57
51 const std::string Version::GetString() const { 58 const std::string Version::GetString() const {
59 DCHECK(is_valid_);
52 std::string version_str; 60 std::string version_str;
53 int count = components_.size(); 61 int count = components_.size();
54 for (int i = 0; i < count - 1; ++i) { 62 for (int i = 0; i < count - 1; ++i) {
55 version_str.append(IntToString(components_[i])); 63 version_str.append(IntToString(components_[i]));
56 version_str.append("."); 64 version_str.append(".");
57 } 65 }
58 version_str.append(IntToString(components_[count - 1])); 66 version_str.append(IntToString(components_[count - 1]));
59 return version_str; 67 return version_str;
60 } 68 }
61 69
62 bool Version::InitFromString(const std::string& version_str) { 70 bool Version::InitFromString(const std::string& version_str) {
71 DCHECK(!is_valid_);
63 std::vector<std::string> numbers; 72 std::vector<std::string> numbers;
64 SplitString(version_str, '.', &numbers); 73 SplitString(version_str, '.', &numbers);
74 if (numbers.empty())
75 return false;
65 for (std::vector<std::string>::iterator i = numbers.begin(); 76 for (std::vector<std::string>::iterator i = numbers.begin();
66 i != numbers.end(); ++i) { 77 i != numbers.end(); ++i) {
67 int num; 78 int num;
68 if (!StringToInt(*i, &num)) 79 if (!StringToInt(*i, &num))
69 return false; 80 return false;
70 if (num < 0) 81 if (num < 0)
71 return false; 82 return false;
72 const uint16 max = 0xFFFF; 83 const uint16 max = 0xFFFF;
73 if (num > max) 84 if (num > max)
74 return false; 85 return false;
75 // This throws out things like +3, or 032. 86 // This throws out things like +3, or 032.
76 if (IntToString(num) != *i) 87 if (IntToString(num) != *i)
77 return false; 88 return false;
78 uint16 component = static_cast<uint16>(num); 89 uint16 component = static_cast<uint16>(num);
79 components_.push_back(component); 90 components_.push_back(component);
80 } 91 }
92 is_valid_ = true;
81 return true; 93 return true;
82 } 94 }
OLDNEW
« no previous file with comments | « base/version.h ('k') | base/version_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698