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

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

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

Powered by Google App Engine
This is Rietveld 408576698