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

Side by Side Diff: trunk/src/third_party/libaddressinput/chromium/addressinput_util.cc

Issue 387123004: Revert 282726 "Reland "Use upstream libaddressinput in Chrome."" (Closed) Base URL: svn://svn.chromium.org/chrome/
Patch Set: Created 6 years, 5 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "third_party/libaddressinput/chromium/addressinput_util.h" 5 #include "third_party/libaddressinput/chromium/addressinput_util.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/macros.h" 10 #include "base/macros.h"
11 #include "third_party/libaddressinput/src/cpp/include/libaddressinput/address_da ta.h" 11 #include "third_party/libaddressinput/chromium/cpp/include/libaddressinput/addre ss_data.h"
12 #include "third_party/libaddressinput/src/cpp/include/libaddressinput/address_me tadata.h" 12 #include "third_party/libaddressinput/chromium/cpp/include/libaddressinput/addre ss_metadata.h"
13 13
14 namespace autofill { 14 namespace autofill {
15 namespace addressinput { 15 namespace addressinput {
16 16
17 namespace { 17 namespace {
18 18
19 using ::i18n::addressinput::AddressData; 19 using ::i18n::addressinput::AddressData;
20 using ::i18n::addressinput::AddressField; 20 using ::i18n::addressinput::AddressField;
21 using ::i18n::addressinput::AddressProblem; 21 using ::i18n::addressinput::AddressProblem;
22 using ::i18n::addressinput::IsFieldRequired; 22 using ::i18n::addressinput::IsFieldRequired;
23 23
24 using ::i18n::addressinput::MISSING_REQUIRED_FIELD;
25
26 // Returns true if the |problem| should not be reported for the |field| because 24 // Returns true if the |problem| should not be reported for the |field| because
27 // the |filter| excludes it. 25 // the |filter| excludes it.
28 bool FilterExcludes(const std::multimap<AddressField, AddressProblem>* filter, 26 bool FilterExcludes(
29 AddressField field, 27 const std::multimap<AddressField, AddressProblem::Type>* filter,
30 AddressProblem problem) { 28 AddressField field,
29 AddressProblem::Type problem) {
31 return filter != NULL && !filter->empty() && 30 return filter != NULL && !filter->empty() &&
32 std::find(filter->begin(), 31 std::find(
33 filter->end(), 32 filter->begin(),
34 std::multimap<AddressField, AddressProblem>::value_type( 33 filter->end(),
35 field, problem)) == filter->end(); 34 std::multimap<AddressField, AddressProblem::Type>::value_type(
35 field, problem)) == filter->end();
36 } 36 }
37 37
38 } // namespace 38 } // namespace
39 39
40 bool HasAllRequiredFields(const AddressData& address_to_check) { 40 bool HasAllRequiredFields(const AddressData& address_to_check) {
41 std::multimap<AddressField, AddressProblem> problems; 41 std::multimap<AddressField, AddressProblem::Type> problems;
42 ValidateRequiredFields(address_to_check, NULL, &problems); 42 ValidateRequiredFields(address_to_check, NULL, &problems);
43 return problems.empty(); 43 return problems.empty();
44 } 44 }
45 45
46 void ValidateRequiredFields( 46 void ValidateRequiredFields(
47 const AddressData& address_to_check, 47 const AddressData& address_to_check,
48 const std::multimap<AddressField, AddressProblem>* filter, 48 const std::multimap<AddressField, AddressProblem::Type>* filter,
49 std::multimap<AddressField, AddressProblem>* problems) { 49 std::multimap<AddressField, AddressProblem::Type>* problems) {
50 DCHECK(problems); 50 DCHECK(problems);
51 51
52 static const AddressField kFields[] = { 52 static const AddressField kFields[] = {
53 ::i18n::addressinput::COUNTRY, 53 ::i18n::addressinput::COUNTRY,
54 ::i18n::addressinput::ADMIN_AREA, 54 ::i18n::addressinput::ADMIN_AREA,
55 ::i18n::addressinput::LOCALITY, 55 ::i18n::addressinput::LOCALITY,
56 ::i18n::addressinput::DEPENDENT_LOCALITY, 56 ::i18n::addressinput::DEPENDENT_LOCALITY,
57 ::i18n::addressinput::SORTING_CODE, 57 ::i18n::addressinput::SORTING_CODE,
58 ::i18n::addressinput::POSTAL_CODE, 58 ::i18n::addressinput::POSTAL_CODE,
59 ::i18n::addressinput::STREET_ADDRESS, 59 ::i18n::addressinput::STREET_ADDRESS,
60 ::i18n::addressinput::RECIPIENT}; 60 ::i18n::addressinput::RECIPIENT};
61 61
62 for (size_t i = 0; i < arraysize(kFields); ++i) { 62 for (size_t i = 0; i < arraysize(kFields); ++i) {
63 AddressField field = kFields[i]; 63 AddressField field = kFields[i];
64 if (address_to_check.IsFieldEmpty(field) && 64 if (address_to_check.IsFieldEmpty(field) &&
65 IsFieldRequired(field, address_to_check.region_code) && 65 IsFieldRequired(field, address_to_check.region_code) &&
66 !FilterExcludes(filter, field, MISSING_REQUIRED_FIELD)) { 66 !FilterExcludes(
67 problems->insert(std::make_pair(field, MISSING_REQUIRED_FIELD)); 67 filter, field, AddressProblem::MISSING_REQUIRED_FIELD)) {
68 problems->insert(
69 std::make_pair(field, AddressProblem::MISSING_REQUIRED_FIELD));
68 } 70 }
69 } 71 }
70 } 72 }
71 73
72 } // namespace addressinput 74 } // namespace addressinput
73 } // namespace autofill 75 } // namespace autofill
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698