OLD | NEW |
1 // Copyright (C) 2013 Google Inc. | 1 // Copyright (C) 2013 Google Inc. |
2 // | 2 // |
3 // Licensed under the Apache License, Version 2.0 (the "License"); | 3 // Licensed under the Apache License, Version 2.0 (the "License"); |
4 // you may not use this file except in compliance with the License. | 4 // you may not use this file except in compliance with the License. |
5 // You may obtain a copy of the License at | 5 // You may obtain a copy of the License at |
6 // | 6 // |
7 // http://www.apache.org/licenses/LICENSE-2.0 | 7 // http://www.apache.org/licenses/LICENSE-2.0 |
8 // | 8 // |
9 // Unless required by applicable law or agreed to in writing, software | 9 // Unless required by applicable law or agreed to in writing, software |
10 // distributed under the License is distributed on an "AS IS" BASIS, | 10 // distributed under the License is distributed on an "AS IS" BASIS, |
(...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
132 const std::vector<std::string>& GetInputLanguages() const { | 132 const std::vector<std::string>& GetInputLanguages() const { |
133 return input_languages_; | 133 return input_languages_; |
134 } | 134 } |
135 | 135 |
136 // Returns the language code of this rule, for example "de". | 136 // Returns the language code of this rule, for example "de". |
137 const std::string& GetLanguage() const { return language_; } | 137 const std::string& GetLanguage() const { return language_; } |
138 | 138 |
139 // Returns the postal code format, for example "\\d{5}([ \\-]\\d{4})?". | 139 // Returns the postal code format, for example "\\d{5}([ \\-]\\d{4})?". |
140 const std::string& GetPostalCodeFormat() const { return postal_code_format_; } | 140 const std::string& GetPostalCodeFormat() const { return postal_code_format_; } |
141 | 141 |
142 // The message string identifier for admin area name. If not set, then | 142 // A string identifying the type of admin area name for this country, e.g. |
143 // INVALID_MESSAGE_ID. | 143 // "state", "province", or "district". |
144 int GetAdminAreaNameMessageId() const { return admin_area_name_message_id_; } | 144 const std::string& GetAdminAreaNameType() const { |
145 | 145 return admin_area_name_type_; |
146 // The error message string identifier for an invalid admin area. If not set, | |
147 // then INVALID_MESSAGE_ID. | |
148 int GetInvalidAdminAreaMessageId() const { | |
149 return invalid_admin_area_message_id_; | |
150 } | 146 } |
151 | 147 |
152 // The message string identifier for postal code name. If not set, then | 148 // A string identifying the type of postal code name for this country, either |
153 // INVALID_MESSAGE_ID. | 149 // "postal" or "zip". |
154 int GetPostalCodeNameMessageId() const { | 150 const std::string& GetPostalCodeNameType() const { |
155 return postal_code_name_message_id_; | 151 return postal_code_name_type_; |
156 } | 152 } |
157 | 153 |
158 // The error message string identifier for an invalid postal code. If not set, | |
159 // then INVALID_MESSAGE_ID. | |
160 int GetInvalidPostalCodeMessageId() const { | |
161 return invalid_postal_code_message_id_; | |
162 } | |
163 | |
164 // Returns the error message string identifier for an invalid |field|. | |
165 int GetInvalidFieldMessageId(AddressField field) const; | |
166 | |
167 // Outputs the sub key for a given user input. For example, Texas will map to | 154 // Outputs the sub key for a given user input. For example, Texas will map to |
168 // TX. | 155 // TX. |
169 // | 156 // |
170 // If |keep_input_latin| is true, then does not convert a latinized region | 157 // If |keep_input_latin| is true, then does not convert a latinized region |
171 // name into a sub key. For example, tOKYo will change to TOKYO. If | 158 // name into a sub key. For example, tOKYo will change to TOKYO. If |
172 // |keep_input_latin| is false, then converts a latinized region name into a | 159 // |keep_input_latin| is false, then converts a latinized region name into a |
173 // sub key. For example, tOKYo becomes 東京都. | 160 // sub key. For example, tOKYo becomes 東京都. |
174 // | 161 // |
175 // |sub_key| should not be NULL. | 162 // |sub_key| should not be NULL. |
176 bool CanonicalizeSubKey(const std::string& user_input, | 163 bool CanonicalizeSubKey(const std::string& user_input, |
177 bool keep_input_latin, | 164 bool keep_input_latin, |
178 std::string* sub_key) const; | 165 std::string* sub_key) const; |
179 | 166 |
180 private: | 167 private: |
181 std::string key_; | 168 std::string key_; |
182 std::string name_; | 169 std::string name_; |
183 std::string latin_name_; | 170 std::string latin_name_; |
184 std::vector<std::vector<FormatElement> > format_; | 171 std::vector<std::vector<FormatElement> > format_; |
185 std::vector<std::vector<FormatElement> > latin_format_; | 172 std::vector<std::vector<FormatElement> > latin_format_; |
186 std::vector<AddressField> required_; | 173 std::vector<AddressField> required_; |
187 std::vector<std::string> sub_keys_; | 174 std::vector<std::string> sub_keys_; |
188 std::vector<std::string> sub_names_; | 175 std::vector<std::string> sub_names_; |
189 // The Latin names (when |sub_names_| is not in Latin characters). | 176 // The Latin names (when |sub_names_| is not in Latin characters). |
190 std::vector<std::string> sub_lnames_; | 177 std::vector<std::string> sub_lnames_; |
191 std::vector<std::string> languages_; | 178 std::vector<std::string> languages_; |
192 std::vector<std::string> input_languages_; | 179 std::vector<std::string> input_languages_; |
193 std::string language_; | 180 std::string language_; |
194 std::string postal_code_format_; | 181 std::string postal_code_format_; |
195 int admin_area_name_message_id_; | 182 std::string admin_area_name_type_; |
196 int invalid_admin_area_message_id_; | 183 std::string postal_code_name_type_; |
197 int postal_code_name_message_id_; | |
198 int invalid_postal_code_message_id_; | |
199 | 184 |
200 DISALLOW_COPY_AND_ASSIGN(Rule); | 185 DISALLOW_COPY_AND_ASSIGN(Rule); |
201 }; | 186 }; |
202 | 187 |
203 } // namespace addressinput | 188 } // namespace addressinput |
204 } // namespace i18n | 189 } // namespace i18n |
205 | 190 |
206 #endif // I18N_ADDRESSINPUT_RULE_H_ | 191 #endif // I18N_ADDRESSINPUT_RULE_H_ |
OLD | NEW |