| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "components/autofill/core/common/form_field_data.h" | 5 #include "components/autofill/core/common/form_field_data.h" |
| 6 | 6 |
| 7 #include <tuple> | |
| 8 | |
| 9 #include "base/pickle.h" | 7 #include "base/pickle.h" |
| 10 #include "base/strings/string_util.h" | 8 #include "base/strings/string_util.h" |
| 11 #include "base/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
| 12 | 10 |
| 13 namespace autofill { | 11 namespace autofill { |
| 14 | 12 |
| 15 namespace { | 13 namespace { |
| 16 | 14 |
| 17 // Increment this anytime pickle format is modified as well as provide | 15 // Increment this anytime pickle format is modified as well as provide |
| 18 // deserialization routine from previous kPickleVersion format. | 16 // deserialization routine from previous kPickleVersion format. |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 111 // The option values/contents which are the list of items in the list | 109 // The option values/contents which are the list of items in the list |
| 112 // of a drop-down are currently not considered part of the identity of | 110 // of a drop-down are currently not considered part of the identity of |
| 113 // a form element. This is debatable, since one might base heuristics | 111 // a form element. This is debatable, since one might base heuristics |
| 114 // on the types of elements that are available. Alternatively, one | 112 // on the types of elements that are available. Alternatively, one |
| 115 // could imagine some forms that dynamically change the element | 113 // could imagine some forms that dynamically change the element |
| 116 // contents (say, insert years starting from the current year) that | 114 // contents (say, insert years starting from the current year) that |
| 117 // should not be considered changes in the structure of the form. | 115 // should not be considered changes in the structure of the form. |
| 118 } | 116 } |
| 119 | 117 |
| 120 bool FormFieldData::operator<(const FormFieldData& field) const { | 118 bool FormFieldData::operator<(const FormFieldData& field) const { |
| 119 // This does not use std::tie() as that generates more implicit variables |
| 120 // than the max-vartrack-size for var-tracking-assignments when compiling |
| 121 // for Android, producing build warnings. (See https://crbug.com/555171 for |
| 122 // context.) |
| 123 |
| 121 // Like operator==, this ignores the value. | 124 // Like operator==, this ignores the value. |
| 125 if (label < field.label) return true; |
| 126 if (label > field.label) return false; |
| 127 if (name < field.name) return true; |
| 128 if (name > field.name) return false; |
| 129 if (form_control_type < field.form_control_type) return true; |
| 130 if (form_control_type > field.form_control_type) return false; |
| 131 if (autocomplete_attribute < field.autocomplete_attribute) return true; |
| 132 if (autocomplete_attribute > field.autocomplete_attribute) return false; |
| 133 if (max_length < field.max_length) return true; |
| 134 if (max_length > field.max_length) return false; |
| 122 // Skip |is_checked| and |is_autofilled| as in SameFieldAs. | 135 // Skip |is_checked| and |is_autofilled| as in SameFieldAs. |
| 136 if (is_checkable < field.is_checkable) return true; |
| 137 if (is_checkable > field.is_checkable) return false; |
| 138 if (is_focusable < field.is_focusable) return true; |
| 139 if (is_focusable > field.is_focusable) return false; |
| 140 if (should_autocomplete < field.should_autocomplete) return true; |
| 141 if (should_autocomplete > field.should_autocomplete) return false; |
| 142 if (role < field.role) return true; |
| 143 if (role > field.role) return false; |
| 144 if (text_direction < field.text_direction) return true; |
| 145 if (text_direction > field.text_direction) return false; |
| 123 // See operator== above for why we don't check option_values/contents. | 146 // See operator== above for why we don't check option_values/contents. |
| 124 return std::tie(label, name, form_control_type, autocomplete_attribute, | 147 return false; |
| 125 max_length, is_checkable, is_focusable, should_autocomplete, | |
| 126 role, text_direction) < | |
| 127 std::tie(field.label, field.name, field.form_control_type, | |
| 128 field.autocomplete_attribute, field.max_length, | |
| 129 field.is_checkable, field.is_focusable, | |
| 130 field.should_autocomplete, field.role, field.text_direction); | |
| 131 } | 148 } |
| 132 | 149 |
| 133 void SerializeFormFieldData(const FormFieldData& field_data, | 150 void SerializeFormFieldData(const FormFieldData& field_data, |
| 134 base::Pickle* pickle) { | 151 base::Pickle* pickle) { |
| 135 pickle->WriteInt(kPickleVersion); | 152 pickle->WriteInt(kPickleVersion); |
| 136 pickle->WriteString16(field_data.label); | 153 pickle->WriteString16(field_data.label); |
| 137 pickle->WriteString16(field_data.name); | 154 pickle->WriteString16(field_data.name); |
| 138 pickle->WriteString16(field_data.value); | 155 pickle->WriteString16(field_data.value); |
| 139 pickle->WriteString(field_data.form_control_type); | 156 pickle->WriteString(field_data.form_control_type); |
| 140 pickle->WriteString(field_data.autocomplete_attribute); | 157 pickle->WriteString(field_data.autocomplete_attribute); |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 193 << " " << field.autocomplete_attribute << " " << field.max_length | 210 << " " << field.autocomplete_attribute << " " << field.max_length |
| 194 << " " << (field.is_autofilled ? "true" : "false") << " " | 211 << " " << (field.is_autofilled ? "true" : "false") << " " |
| 195 << (field.is_checked ? "true" : "false") << " " | 212 << (field.is_checked ? "true" : "false") << " " |
| 196 << (field.is_checkable ? "true" : "false") << " " | 213 << (field.is_checkable ? "true" : "false") << " " |
| 197 << (field.is_focusable ? "true" : "false") << " " | 214 << (field.is_focusable ? "true" : "false") << " " |
| 198 << (field.should_autocomplete ? "true" : "false") << " " | 215 << (field.should_autocomplete ? "true" : "false") << " " |
| 199 << field.role << " " << field.text_direction; | 216 << field.role << " " << field.text_direction; |
| 200 } | 217 } |
| 201 | 218 |
| 202 } // namespace autofill | 219 } // namespace autofill |
| OLD | NEW |