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

Unified Diff: components/payments/core/payment_request_data_util.cc

Issue 2843513004: [Payments] Return basic-card as the method name when possible. (Closed)
Patch Set: Created 3 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « components/payments/content/payment_request_spec_unittest.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/payments/core/payment_request_data_util.cc
diff --git a/components/payments/core/payment_request_data_util.cc b/components/payments/core/payment_request_data_util.cc
index 9a5f5f4f9636f30dc2b60ac6423a53d4a92ff5c3..596a20e8ba5950a615ee05c4a79ef5926fe724b5 100644
--- a/components/payments/core/payment_request_data_util.cc
+++ b/components/payments/core/payment_request_data_util.cc
@@ -102,9 +102,10 @@ void ParseBasicCardSupportedNetworks(
DCHECK(out_supported_networks->empty());
DCHECK(out_basic_card_specified_networks->empty());
- std::set<std::string> card_networks{"amex", "diners", "discover",
- "jcb", "mastercard", "mir",
- "unionpay", "visa"};
+ const std::set<std::string> kBasicCardNetworks{
+ "amex", "diners", "discover", "jcb",
+ "mastercard", "mir", "unionpay", "visa"};
+ std::set<std::string> remaining_card_networks(kBasicCardNetworks);
for (const PaymentMethodData& method_data_entry : method_data) {
if (method_data_entry.supported_methods.empty())
return;
@@ -113,40 +114,42 @@ void ParseBasicCardSupportedNetworks(
if (method.empty())
continue;
- // If a card network is specified right in "supportedMethods", add it.
const char kBasicCardMethodName[] = "basic-card";
- auto card_it = card_networks.find(method);
- if (card_it != card_networks.end()) {
+ // If a card network is specified right in "supportedMethods", add it.
+ auto card_it = remaining_card_networks.find(method);
+ if (card_it != remaining_card_networks.end()) {
out_supported_networks->push_back(method);
- // |method| removed from |card_networks| so that it is not doubly added
- // to |supported_card_networks_| if "basic-card" is specified with no
- // supported networks.
- card_networks.erase(card_it);
+ // |method| removed from |remaining_card_networks| so that it is not
+ // doubly added to |out_supported_networks|.
+ remaining_card_networks.erase(card_it);
} else if (method == kBasicCardMethodName) {
// For the "basic-card" method, check "supportedNetworks".
if (method_data_entry.supported_networks.empty()) {
// Empty |supported_networks| means all networks are supported.
out_supported_networks->insert(out_supported_networks->end(),
- card_networks.begin(),
- card_networks.end());
- out_basic_card_specified_networks->insert(card_networks.begin(),
- card_networks.end());
+ remaining_card_networks.begin(),
+ remaining_card_networks.end());
+ out_basic_card_specified_networks->insert(kBasicCardNetworks.begin(),
+ kBasicCardNetworks.end());
// Clear the set so that no further networks are added to
// |out_supported_networks|.
- card_networks.clear();
+ remaining_card_networks.clear();
} else {
// The merchant has specified a few basic card supported networks. Use
// the mapping to transform to known basic-card types.
for (const std::string& supported_network :
method_data_entry.supported_networks) {
// Make sure that the network was not already added to
- // |out_supported_networks|. If it's still in |card_networks| it's
- // fair game.
- auto it = card_networks.find(supported_network);
- if (it != card_networks.end()) {
+ // |out_supported_networks|. If it's still in
+ // |remaining_card_networks| it's fair game.
+ auto it = remaining_card_networks.find(supported_network);
+ if (it != remaining_card_networks.end()) {
out_supported_networks->push_back(supported_network);
+ remaining_card_networks.erase(it);
+ }
+ if (kBasicCardNetworks.find(supported_network) !=
+ kBasicCardNetworks.end()) {
out_basic_card_specified_networks->insert(supported_network);
- card_networks.erase(it);
}
}
}
« no previous file with comments | « components/payments/content/payment_request_spec_unittest.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698