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

Side by Side Diff: components/autofill/core/browser/credit_card.cc

Issue 1080883002: Remove some more bad ASCII-centric autofill code. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: tests Created 5 years, 8 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
OLDNEW
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/browser/credit_card.h" 5 #include "components/autofill/core/browser/credit_card.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include <algorithm> 9 #include <algorithm>
10 #include <ostream> 10 #include <ostream>
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
45 } 45 }
46 46
47 // Try parsing the |year| as a number. 47 // Try parsing the |year| as a number.
48 if (base::StringToInt(year, num)) 48 if (base::StringToInt(year, num))
49 return true; 49 return true;
50 50
51 *num = 0; 51 *num = 0;
52 return false; 52 return false;
53 } 53 }
54 54
55 bool ConvertMonth(const base::string16& month,
56 const std::string& app_locale,
57 int* num) {
58 // If the |month| is empty, clear the stored value.
59 if (month.empty()) {
60 *num = 0;
61 return true;
62 }
63
64 // Try parsing the |month| as a number.
65 if (base::StringToInt(month, num))
66 return true;
67
68 // If the locale is unknown, give up.
69 if (app_locale.empty())
70 return false;
71
72 // Otherwise, try parsing the |month| as a named month, e.g. "January" or
73 // "Jan".
74 l10n::CaseInsensitiveCompare compare;
75 UErrorCode status = U_ZERO_ERROR;
76 icu::Locale locale(app_locale.c_str());
77 icu::DateFormatSymbols date_format_symbols(locale, status);
78 DCHECK(status == U_ZERO_ERROR || status == U_USING_FALLBACK_WARNING ||
79 status == U_USING_DEFAULT_WARNING);
80
81 int32_t num_months;
82 const icu::UnicodeString* months = date_format_symbols.getMonths(num_months);
83 for (int32_t i = 0; i < num_months; ++i) {
84 const base::string16 icu_month(months[i].getBuffer(), months[i].length());
85 if (compare.StringsEqual(icu_month, month)) {
86 *num = i + 1; // Adjust from 0-indexed to 1-indexed.
87 return true;
88 }
89 }
90
91 months = date_format_symbols.getShortMonths(num_months);
92 for (int32_t i = 0; i < num_months; ++i) {
93 const base::string16 icu_month(months[i].getBuffer(), months[i].length());
94 if (compare.StringsEqual(icu_month, month)) {
95 *num = i + 1; // Adjust from 0-indexed to 1-indexed.
96 return true;
97 }
98 }
99
100 *num = 0;
101 return false;
102 }
103
104 base::string16 TypeForFill(const std::string& type) { 55 base::string16 TypeForFill(const std::string& type) {
105 if (type == kAmericanExpressCard) 56 if (type == kAmericanExpressCard)
106 return l10n_util::GetStringUTF16(IDS_AUTOFILL_CC_AMEX); 57 return l10n_util::GetStringUTF16(IDS_AUTOFILL_CC_AMEX);
107 if (type == kDinersCard) 58 if (type == kDinersCard)
108 return l10n_util::GetStringUTF16(IDS_AUTOFILL_CC_DINERS); 59 return l10n_util::GetStringUTF16(IDS_AUTOFILL_CC_DINERS);
109 if (type == kDiscoverCard) 60 if (type == kDiscoverCard)
110 return l10n_util::GetStringUTF16(IDS_AUTOFILL_CC_DISCOVER); 61 return l10n_util::GetStringUTF16(IDS_AUTOFILL_CC_DISCOVER);
111 if (type == kJCBCard) 62 if (type == kJCBCard)
112 return l10n_util::GetStringUTF16(IDS_AUTOFILL_CC_JCB); 63 return l10n_util::GetStringUTF16(IDS_AUTOFILL_CC_JCB);
113 if (type == kMasterCard) 64 if (type == kMasterCard)
(...skipping 634 matching lines...) Expand 10 before | Expand all | Expand 10 after
748 699
749 void CreditCard::SetNumber(const base::string16& number) { 700 void CreditCard::SetNumber(const base::string16& number) {
750 number_ = number; 701 number_ = number;
751 702
752 // Set the type based on the card number, but only for full numbers, not 703 // Set the type based on the card number, but only for full numbers, not
753 // when we have masked cards from the server (last 4 digits). 704 // when we have masked cards from the server (last 4 digits).
754 if (record_type_ != MASKED_SERVER_CARD) 705 if (record_type_ != MASKED_SERVER_CARD)
755 type_ = GetCreditCardType(StripSeparators(number_)); 706 type_ = GetCreditCardType(StripSeparators(number_));
756 } 707 }
757 708
709 // static
710 bool CreditCard::ConvertMonth(const base::string16& month,
711 const std::string& app_locale,
712 int* num) {
713 // If the |month| is empty, clear the stored value.
714 if (month.empty()) {
715 *num = 0;
716 return true;
717 }
718
719 // Try parsing the |month| as a number.
720 if (base::StringToInt(month, num))
721 return true;
722
723 // If the locale is unknown, give up.
724 if (app_locale.empty())
725 return false;
726
727 // Otherwise, try parsing the |month| as a named month, e.g. "January" or
728 // "Jan".
729 l10n::CaseInsensitiveCompare compare;
730 UErrorCode status = U_ZERO_ERROR;
731 icu::Locale locale(app_locale.c_str());
732 icu::DateFormatSymbols date_format_symbols(locale, status);
733 DCHECK(status == U_ZERO_ERROR || status == U_USING_FALLBACK_WARNING ||
734 status == U_USING_DEFAULT_WARNING);
735
736 int32_t num_months;
737 const icu::UnicodeString* months = date_format_symbols.getMonths(num_months);
738 for (int32_t i = 0; i < num_months; ++i) {
739 const base::string16 icu_month(months[i].getBuffer(), months[i].length());
740 if (compare.StringsEqual(icu_month, month)) {
741 *num = i + 1; // Adjust from 0-indexed to 1-indexed.
742 return true;
743 }
744 }
745
746 months = date_format_symbols.getShortMonths(num_months);
747 // Some abbreviations have . at the end (e.g., "janv." in French). We don't
748 // care about matching that.
749 base::string16 trimmed_month;
750 base::TrimString(month, base::ASCIIToUTF16("."), &trimmed_month);
751 for (int32_t i = 0; i < num_months; ++i) {
752 base::string16 icu_month(months[i].getBuffer(), months[i].length());
753 base::TrimString(icu_month, base::ASCIIToUTF16("."), &icu_month);
754 if (compare.StringsEqual(icu_month, trimmed_month)) {
755 *num = i + 1; // Adjust from 0-indexed to 1-indexed.
756 return true;
757 }
758 }
759
760 *num = 0;
761 return false;
762 }
763
758 // So we can compare CreditCards with EXPECT_EQ(). 764 // So we can compare CreditCards with EXPECT_EQ().
759 std::ostream& operator<<(std::ostream& os, const CreditCard& credit_card) { 765 std::ostream& operator<<(std::ostream& os, const CreditCard& credit_card) {
760 return os 766 return os
761 << base::UTF16ToUTF8(credit_card.Label()) 767 << base::UTF16ToUTF8(credit_card.Label())
762 << " " 768 << " "
763 << credit_card.guid() 769 << credit_card.guid()
764 << " " 770 << " "
765 << credit_card.origin() 771 << credit_card.origin()
766 << " " 772 << " "
767 << base::UTF16ToUTF8(credit_card.GetRawInfo(CREDIT_CARD_NAME)) 773 << base::UTF16ToUTF8(credit_card.GetRawInfo(CREDIT_CARD_NAME))
(...skipping 14 matching lines...) Expand all
782 const char* const kAmericanExpressCard = "americanExpressCC"; 788 const char* const kAmericanExpressCard = "americanExpressCC";
783 const char* const kDinersCard = "dinersCC"; 789 const char* const kDinersCard = "dinersCC";
784 const char* const kDiscoverCard = "discoverCC"; 790 const char* const kDiscoverCard = "discoverCC";
785 const char* const kGenericCard = "genericCC"; 791 const char* const kGenericCard = "genericCC";
786 const char* const kJCBCard = "jcbCC"; 792 const char* const kJCBCard = "jcbCC";
787 const char* const kMasterCard = "masterCardCC"; 793 const char* const kMasterCard = "masterCardCC";
788 const char* const kUnionPay = "unionPayCC"; 794 const char* const kUnionPay = "unionPayCC";
789 const char* const kVisaCard = "visaCC"; 795 const char* const kVisaCard = "visaCC";
790 796
791 } // namespace autofill 797 } // namespace autofill
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698