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 "chrome/browser/ui/android/autofill/autofill_dialog_result.h" | 5 #include "chrome/browser/ui/android/autofill/autofill_dialog_result.h" |
6 | 6 |
7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
8 #include "base/android/jni_array.h" | 8 #include "base/android/jni_array.h" |
9 #include "base/android/jni_string.h" | 9 #include "base/android/jni_string.h" |
10 #include "base/android/scoped_java_ref.h" | 10 #include "base/android/scoped_java_ref.h" |
(...skipping 20 matching lines...) Expand all Loading... |
31 : base::string16(); | 31 : base::string16(); |
32 } | 32 } |
33 | 33 |
34 #define FETCH_JFIELD(env, jobj, cls, getter) \ | 34 #define FETCH_JFIELD(env, jobj, cls, getter) \ |
35 (Java_##cls##_get##getter((env), (jobj))) | 35 (Java_##cls##_get##getter((env), (jobj))) |
36 | 36 |
37 #define FETCH_JSTRING(utf, env, jobj, cls, getter) \ | 37 #define FETCH_JSTRING(utf, env, jobj, cls, getter) \ |
38 (ConvertNullOrJavaStringTo##utf( \ | 38 (ConvertNullOrJavaStringTo##utf( \ |
39 (env), FETCH_JFIELD((env), (jobj), cls, getter).obj())) | 39 (env), FETCH_JFIELD((env), (jobj), cls, getter).obj())) |
40 | 40 |
41 scoped_ptr<wallet::Address> ParseJavaWalletAddress( | 41 std::unique_ptr<wallet::Address> ParseJavaWalletAddress(JNIEnv* env, |
42 JNIEnv* env, jobject address) { | 42 jobject address) { |
43 if (!address) | 43 if (!address) |
44 return scoped_ptr<wallet::Address>(); | 44 return std::unique_ptr<wallet::Address>(); |
45 | 45 |
46 const base::string16 recipient_name = | 46 const base::string16 recipient_name = |
47 FETCH_JSTRING(UTF16, env, address, ResultAddress, Name); | 47 FETCH_JSTRING(UTF16, env, address, ResultAddress, Name); |
48 | 48 |
49 const base::string16 street_address = | 49 const base::string16 street_address = |
50 FETCH_JSTRING(UTF16, env, address, ResultAddress, StreetAddress); | 50 FETCH_JSTRING(UTF16, env, address, ResultAddress, StreetAddress); |
51 std::vector<base::string16> address_lines = base::SplitString( | 51 std::vector<base::string16> address_lines = base::SplitString( |
52 street_address, base::string16(1, '\n'), | 52 street_address, base::string16(1, '\n'), |
53 base::TRIM_WHITESPACE, base::SPLIT_WANT_ALL); | 53 base::TRIM_WHITESPACE, base::SPLIT_WANT_ALL); |
54 | 54 |
55 const base::string16 locality_name = | 55 const base::string16 locality_name = |
56 FETCH_JSTRING(UTF16, env, address, ResultAddress, Locality); | 56 FETCH_JSTRING(UTF16, env, address, ResultAddress, Locality); |
57 const base::string16 dependent_locality_name = | 57 const base::string16 dependent_locality_name = |
58 FETCH_JSTRING(UTF16, env, address, ResultAddress, DependentLocality); | 58 FETCH_JSTRING(UTF16, env, address, ResultAddress, DependentLocality); |
59 const base::string16 administrative_area_name = | 59 const base::string16 administrative_area_name = |
60 FETCH_JSTRING(UTF16, env, address, ResultAddress, AdministrativeArea); | 60 FETCH_JSTRING(UTF16, env, address, ResultAddress, AdministrativeArea); |
61 const base::string16 postal_code_number = | 61 const base::string16 postal_code_number = |
62 FETCH_JSTRING(UTF16, env, address, ResultAddress, PostalCode); | 62 FETCH_JSTRING(UTF16, env, address, ResultAddress, PostalCode); |
63 const base::string16 sorting_code = | 63 const base::string16 sorting_code = |
64 FETCH_JSTRING(UTF16, env, address, ResultAddress, SortingCode); | 64 FETCH_JSTRING(UTF16, env, address, ResultAddress, SortingCode); |
65 const base::string16 phone_number = | 65 const base::string16 phone_number = |
66 FETCH_JSTRING(UTF16, env, address, ResultAddress, PhoneNumber); | 66 FETCH_JSTRING(UTF16, env, address, ResultAddress, PhoneNumber); |
67 const std::string country_name_code = | 67 const std::string country_name_code = |
68 FETCH_JSTRING(UTF8, env, address, ResultAddress, CountryCode); | 68 FETCH_JSTRING(UTF8, env, address, ResultAddress, CountryCode); |
69 DCHECK(!country_name_code.empty()); | 69 DCHECK(!country_name_code.empty()); |
70 const std::string language_code = | 70 const std::string language_code = |
71 FETCH_JSTRING(UTF8, env, address, ResultAddress, LanguageCode); | 71 FETCH_JSTRING(UTF8, env, address, ResultAddress, LanguageCode); |
72 | 72 |
73 return scoped_ptr<wallet::Address>(new wallet::Address( | 73 return std::unique_ptr<wallet::Address>(new wallet::Address( |
74 country_name_code, | 74 country_name_code, recipient_name, address_lines, locality_name, |
75 recipient_name, | 75 dependent_locality_name, administrative_area_name, postal_code_number, |
76 address_lines, | 76 sorting_code, phone_number, std::string(), language_code)); |
77 locality_name, | |
78 dependent_locality_name, | |
79 administrative_area_name, | |
80 postal_code_number, | |
81 sorting_code, | |
82 phone_number, | |
83 std::string(), | |
84 language_code)); | |
85 } | 77 } |
86 | 78 |
87 scoped_ptr<wallet::FullWallet> ParseJavaWallet(JNIEnv* env, jobject wallet) { | 79 std::unique_ptr<wallet::FullWallet> ParseJavaWallet(JNIEnv* env, |
| 80 jobject wallet) { |
88 const ScopedJavaLocalRef<jobject> billing_address( | 81 const ScopedJavaLocalRef<jobject> billing_address( |
89 FETCH_JFIELD(env, wallet, ResultWallet, BillingAddress)); | 82 FETCH_JFIELD(env, wallet, ResultWallet, BillingAddress)); |
90 const ScopedJavaLocalRef<jobject> shipping_address( | 83 const ScopedJavaLocalRef<jobject> shipping_address( |
91 FETCH_JFIELD(env, wallet, ResultWallet, ShippingAddress)); | 84 FETCH_JFIELD(env, wallet, ResultWallet, ShippingAddress)); |
92 const ScopedJavaLocalRef<jobject> card( | 85 const ScopedJavaLocalRef<jobject> card( |
93 FETCH_JFIELD(env, wallet, ResultWallet, Card)); | 86 FETCH_JFIELD(env, wallet, ResultWallet, Card)); |
94 | 87 |
95 const int expiration_month = | 88 const int expiration_month = |
96 FETCH_JFIELD(env, card.obj(), ResultCard, ExpirationMonth); | 89 FETCH_JFIELD(env, card.obj(), ResultCard, ExpirationMonth); |
97 const int expiration_year = | 90 const int expiration_year = |
(...skipping 19 matching lines...) Expand all Loading... |
117 std::string ParseGoogleTransactionId(JNIEnv* env, jobject wallet) { | 110 std::string ParseGoogleTransactionId(JNIEnv* env, jobject wallet) { |
118 return FETCH_JSTRING(UTF8, env, wallet, ResultWallet, GoogleTransactionId); | 111 return FETCH_JSTRING(UTF8, env, wallet, ResultWallet, GoogleTransactionId); |
119 } | 112 } |
120 | 113 |
121 #undef FETCH_JSTRING | 114 #undef FETCH_JSTRING |
122 #undef FETCH_FIELD | 115 #undef FETCH_FIELD |
123 | 116 |
124 } // namespace | 117 } // namespace |
125 | 118 |
126 // static | 119 // static |
127 scoped_ptr<wallet::FullWallet> AutofillDialogResult::ConvertFromJava( | 120 std::unique_ptr<wallet::FullWallet> AutofillDialogResult::ConvertFromJava( |
128 JNIEnv* env, jobject wallet) { | 121 JNIEnv* env, |
| 122 jobject wallet) { |
129 return ParseJavaWallet(env, wallet); | 123 return ParseJavaWallet(env, wallet); |
130 } | 124 } |
131 | 125 |
132 // static | 126 // static |
133 base::string16 AutofillDialogResult::GetWalletEmail( | 127 base::string16 AutofillDialogResult::GetWalletEmail( |
134 JNIEnv* env, jobject wallet) { | 128 JNIEnv* env, jobject wallet) { |
135 return ParseWalletEmail(env, wallet); | 129 return ParseWalletEmail(env, wallet); |
136 } | 130 } |
137 | 131 |
138 // static | 132 // static |
139 std::string AutofillDialogResult::GetWalletGoogleTransactionId( | 133 std::string AutofillDialogResult::GetWalletGoogleTransactionId( |
140 JNIEnv* env, jobject wallet) { | 134 JNIEnv* env, jobject wallet) { |
141 return ParseGoogleTransactionId(env, wallet); | 135 return ParseGoogleTransactionId(env, wallet); |
142 } | 136 } |
143 | 137 |
144 // static | 138 // static |
145 bool AutofillDialogResult::RegisterAutofillDialogResult(JNIEnv* env) { | 139 bool AutofillDialogResult::RegisterAutofillDialogResult(JNIEnv* env) { |
146 return RegisterNativesImpl(env); | 140 return RegisterNativesImpl(env); |
147 } | 141 } |
148 | 142 |
149 } // namespace autofill | 143 } // namespace autofill |
OLD | NEW |