| OLD | NEW | 
|---|
| 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/libaddressinput_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/chromium/cpp/include/libaddressinput/addre
    ss_data.h" | 11 #include "third_party/libaddressinput/src/cpp/include/libaddressinput/address_da
    ta.h" | 
| 12 #include "third_party/libaddressinput/chromium/cpp/include/libaddressinput/addre
    ss_metadata.h" | 12 #include "third_party/libaddressinput/src/cpp/include/libaddressinput/address_me
    tadata.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 // Returns true if the |problem| should not be reported for the |field| because | 24 using ::i18n::addressinput::MISSING_REQUIRED_FIELD; | 
| 25 // the |filter| excludes it. | 25 | 
| 26 bool FilterExcludes( | 26 // Based on ::i18n::addressinput::ValidationTask::ShouldReport(). | 
| 27     const std::multimap<AddressField, AddressProblem::Type>* filter, | 27 bool ShouldReport(const std::multimap<AddressField, AddressProblem>* filter, | 
| 28     AddressField field, | 28                   AddressField field, | 
| 29     AddressProblem::Type problem) { | 29                   AddressProblem problem) { | 
| 30   return filter != NULL && !filter->empty() && | 30   return filter == NULL || filter->empty() || | 
| 31          std::find( | 31          std::find(filter->begin(), | 
| 32              filter->begin(), | 32                    filter->end(), | 
| 33              filter->end(), | 33                    std::multimap<AddressField, AddressProblem>::value_type( | 
| 34              std::multimap<AddressField, AddressProblem::Type>::value_type( | 34                        field, problem)) != filter->end(); | 
| 35                  field, problem)) == filter->end(); |  | 
| 36 } | 35 } | 
| 37 | 36 | 
| 38 }  // namespace | 37 }  // namespace | 
| 39 | 38 | 
| 40 bool HasAllRequiredFields(const AddressData& address_to_check) { | 39 bool HasAllRequiredFields(const AddressData& address_to_check) { | 
| 41   std::multimap<AddressField, AddressProblem::Type> problems; | 40   std::multimap<AddressField, AddressProblem> problems; | 
| 42   ValidateRequiredFields(address_to_check, NULL, &problems); | 41   ValidateRequiredFields(address_to_check, NULL, &problems); | 
| 43   return problems.empty(); | 42   return problems.empty(); | 
| 44 } | 43 } | 
| 45 | 44 | 
| 46 void ValidateRequiredFields( | 45 void ValidateRequiredFields( | 
| 47     const AddressData& address_to_check, | 46     const AddressData& address_to_check, | 
| 48     const std::multimap<AddressField, AddressProblem::Type>* filter, | 47     const std::multimap<AddressField, AddressProblem>* filter, | 
| 49     std::multimap<AddressField, AddressProblem::Type>* problems) { | 48     std::multimap<AddressField, AddressProblem>* problems) { | 
| 50   DCHECK(problems); | 49   DCHECK(problems); | 
| 51 | 50 | 
| 52   static const AddressField kFields[] = { | 51   static const AddressField kFields[] = { | 
| 53       ::i18n::addressinput::COUNTRY, | 52       ::i18n::addressinput::COUNTRY, | 
| 54       ::i18n::addressinput::ADMIN_AREA, | 53       ::i18n::addressinput::ADMIN_AREA, | 
| 55       ::i18n::addressinput::LOCALITY, | 54       ::i18n::addressinput::LOCALITY, | 
| 56       ::i18n::addressinput::DEPENDENT_LOCALITY, | 55       ::i18n::addressinput::DEPENDENT_LOCALITY, | 
| 57       ::i18n::addressinput::SORTING_CODE, | 56       ::i18n::addressinput::SORTING_CODE, | 
| 58       ::i18n::addressinput::POSTAL_CODE, | 57       ::i18n::addressinput::POSTAL_CODE, | 
| 59       ::i18n::addressinput::STREET_ADDRESS, | 58       ::i18n::addressinput::STREET_ADDRESS, | 
| 60       ::i18n::addressinput::RECIPIENT}; | 59       ::i18n::addressinput::RECIPIENT}; | 
| 61 | 60 | 
| 62   for (size_t i = 0; i < arraysize(kFields); ++i) { | 61   for (size_t i = 0; i < arraysize(kFields); ++i) { | 
| 63     AddressField field = kFields[i]; | 62     AddressField field = kFields[i]; | 
| 64     if (address_to_check.IsFieldEmpty(field) && | 63     if (address_to_check.IsFieldEmpty(field) && | 
| 65         IsFieldRequired(field, address_to_check.region_code) && | 64         IsFieldRequired(field, address_to_check.region_code) && | 
| 66         !FilterExcludes( | 65         ShouldReport(filter, field, MISSING_REQUIRED_FIELD)) { | 
| 67             filter, field, AddressProblem::MISSING_REQUIRED_FIELD)) { | 66       problems->insert(std::make_pair(field, MISSING_REQUIRED_FIELD)); | 
| 68       problems->insert( |  | 
| 69           std::make_pair(field, AddressProblem::MISSING_REQUIRED_FIELD)); |  | 
| 70     } | 67     } | 
| 71   } | 68   } | 
| 72 } | 69 } | 
| 73 | 70 | 
| 74 }  // namespace addressinput | 71 }  // namespace addressinput | 
| 75 }  // namespace autofill | 72 }  // namespace autofill | 
| OLD | NEW | 
|---|