diff options
author | jhawkins@chromium.org <jhawkins@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-12-19 00:28:55 +0000 |
---|---|---|
committer | jhawkins@chromium.org <jhawkins@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-12-19 00:28:55 +0000 |
commit | 2dd8e7fdab91dfbd1ed6478808f2aae5c2d9c064 (patch) | |
tree | e20154116affea06f0ca8ea16282b339c5d4daed | |
parent | 0a85d7be7b67b07e2e20cd7bd16e0732aae831b9 (diff) | |
download | chromium_src-2dd8e7fdab91dfbd1ed6478808f2aae5c2d9c064.zip chromium_src-2dd8e7fdab91dfbd1ed6478808f2aae5c2d9c064.tar.gz chromium_src-2dd8e7fdab91dfbd1ed6478808f2aae5c2d9c064.tar.bz2 |
Set the address field type based on how many address fields we encountered.
BUG=none
TEST=none
Review URL: http://codereview.chromium.org/501092
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@35011 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/autofill/form_field.cc | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/chrome/browser/autofill/form_field.cc b/chrome/browser/autofill/form_field.cc index e6e375b..4d4c76f 100644 --- a/chrome/browser/autofill/form_field.cc +++ b/chrome/browser/autofill/form_field.cc @@ -135,6 +135,10 @@ string16 FormField::GetEcmlPattern(const string16& ecml_name1, } FormFieldSet::FormFieldSet(FormStructure* fields) { + std::vector<AddressField*> addresses; + + // First, find if there is one form field with an ECML name. If there is, + // then we will match an element only if it is in the standard. bool is_ecml = CheckECML(fields); // Parse fields. @@ -147,6 +151,29 @@ FormFieldSet::FormFieldSet(FormStructure* fields) { } push_back(form_field); + + if (form_field->GetFormFieldType() == kAddressType) { + AddressField* address = static_cast<AddressField*>(form_field); + if (address->IsFullAddress()) + addresses.push_back(address); + } + } + + // Now determine an address type for each address. Note, if this is an ECML + // form, then we already got this info from the field names. + if (!is_ecml && !addresses.empty()) { + if (addresses.size() == 1) { + addresses[0]->SetType(addresses[0]->FindType()); + } else { + AddressType type0 = addresses[0]->FindType(); + AddressType type1 = addresses[1]->FindType(); + + // When there are two addresses on a page, they almost always appear in + // the order (billing, shipping). + bool reversed = (type0 == kShippingAddress && type1 == kBillingAddress); + addresses[0]->SetType(reversed ? kShippingAddress : kBillingAddress); + addresses[1]->SetType(reversed ? kBillingAddress : kShippingAddress); + } } } |