Chromium Code Reviews| Index: extensions/common/permissions/permission_message_util.cc |
| diff --git a/extensions/common/permissions/permission_message_util.cc b/extensions/common/permissions/permission_message_util.cc |
| index 0b2e1a9c038d6fba4e62590ecf20711cab511b6a..c4f4371dda43e166c14d8f98179f346e6ee0333d 100644 |
| --- a/extensions/common/permissions/permission_message_util.cc |
| +++ b/extensions/common/permissions/permission_message_util.cc |
| @@ -38,54 +38,54 @@ bool RcdBetterThan(const std::string& a, const std::string& b) { |
| namespace permission_message_util { |
| PermissionMessage CreateFromHostList(const std::set<std::string>& hosts) { |
| - std::vector<std::string> host_list(hosts.begin(), hosts.end()); |
| - DCHECK(host_list.size()); |
| + std::vector<base::string16> host_list; |
| PermissionMessage::ID message_id; |
| base::string16 message; |
| base::string16 details; |
| + uint32_t kMaxBeforeListOfHosts = 3; |
|
jww
2014/07/22 21:31:56
This should be const, I think.
mhm
2014/07/22 23:37:28
Done.
|
| + std::vector<std::pair<PermissionMessage::ID, base::string16> > kMessagesList; |
|
jww
2014/07/22 21:31:56
I don't see why this needs to be a vector since it
mhm
2014/07/22 21:53:34
So the main issue here is that to be able to creat
jww
2014/07/22 22:14:35
Ah, I see. Well, you can still do something more e
mhm
2014/07/22 23:37:28
Done.
|
| + int host_msg_id = hosts.size() <= kMaxBeforeListOfHosts |
| + ? IDS_EXTENSION_PROMPT_WARNING_HOST_AND_SUBDOMAIN |
| + : IDS_EXTENSION_PROMPT_WARNING_HOST_AND_SUBDOMAIN_LIST; |
| + |
| + for (std::set<std::string>::const_iterator it = hosts.begin(); |
| + it != hosts.end(); |
| + ++it) { |
| + std::string host = *it; |
| + host_list.push_back( |
| + host[0] == '*' && host[1] == '.' |
| + ? l10n_util::GetStringFUTF16(host_msg_id, |
| + base::UTF8ToUTF16(host.erase(0, 2))) |
| + : base::UTF8ToUTF16(host)); |
| + } |
| + DCHECK(host_list.size()); |
| - switch (host_list.size()) { |
| - case 1: |
| - message_id = PermissionMessage::kHosts1; |
| - message = l10n_util::GetStringFUTF16(IDS_EXTENSION_PROMPT_WARNING_1_HOST, |
| - base::UTF8ToUTF16(host_list[0])); |
| - break; |
| - case 2: |
| - message_id = PermissionMessage::kHosts2; |
| - message = l10n_util::GetStringFUTF16(IDS_EXTENSION_PROMPT_WARNING_2_HOSTS, |
| - base::UTF8ToUTF16(host_list[0]), |
| - base::UTF8ToUTF16(host_list[1])); |
| - break; |
| - case 3: |
| - message_id = PermissionMessage::kHosts3; |
| - message = l10n_util::GetStringFUTF16(IDS_EXTENSION_PROMPT_WARNING_3_HOSTS, |
| - base::UTF8ToUTF16(host_list[0]), |
| - base::UTF8ToUTF16(host_list[1]), |
| - base::UTF8ToUTF16(host_list[2])); |
| - break; |
| - default: |
| - message_id = PermissionMessage::kHosts4OrMore; |
| - |
| - const int kRetainedFilesMessageIDs[6] = { |
| - IDS_EXTENSION_PROMPT_WARNING_HOSTS_DEFAULT, |
| - IDS_EXTENSION_PROMPT_WARNING_HOST_SINGULAR, |
| - IDS_EXTENSION_PROMPT_WARNING_HOSTS_ZERO, |
| - IDS_EXTENSION_PROMPT_WARNING_HOSTS_TWO, |
| - IDS_EXTENSION_PROMPT_WARNING_HOSTS_FEW, |
| - IDS_EXTENSION_PROMPT_WARNING_HOSTS_MANY, }; |
| - std::vector<int> message_ids; |
| - for (size_t i = 0; i < arraysize(kRetainedFilesMessageIDs); i++) { |
| - message_ids.push_back(kRetainedFilesMessageIDs[i]); |
| - } |
| - message = l10n_util::GetPluralStringFUTF16(message_ids, host_list.size()); |
| - |
| - for (size_t i = 0; i < host_list.size(); ++i) { |
| - if (i > 0) |
| - details += base::ASCIIToUTF16("\n"); |
| - details += l10n_util::GetStringFUTF16( |
| - IDS_EXTENSION_PROMPT_WARNING_HOST_LIST_ENTRY, |
| - base::UTF8ToUTF16(host_list[i])); |
| - } |
| + kMessagesList.push_back(std::make_pair( |
| + PermissionMessage::kHosts1, |
| + l10n_util::GetStringFUTF16( |
| + IDS_EXTENSION_PROMPT_WARNING_1_HOST, host_list, NULL))); |
| + kMessagesList.push_back(std::make_pair( |
| + PermissionMessage::kHosts2, |
| + l10n_util::GetStringFUTF16( |
| + IDS_EXTENSION_PROMPT_WARNING_2_HOSTS, host_list, NULL))); |
| + kMessagesList.push_back(std::make_pair( |
| + PermissionMessage::kHosts3, |
| + l10n_util::GetStringFUTF16( |
| + IDS_EXTENSION_PROMPT_WARNING_3_HOSTS, host_list, NULL))); |
| + |
| + if (host_list.size() <= kMaxBeforeListOfHosts) { |
| + message_id = kMessagesList[host_list.size() - 1].first; |
| + message = kMessagesList[host_list.size() - 1].second; |
| + } else { |
| + message_id = PermissionMessage::kHosts4OrMore; |
| + message = l10n_util::GetStringUTF16( |
| + IDS_EXTENSION_PROMPT_WARNING_HOSTS_4_OR_MORE_HOSTS); |
| + for (size_t i = 0; i < host_list.size(); ++i) { |
| + if (i > 0) |
| + details += base::ASCIIToUTF16("\n"); |
| + details += l10n_util::GetStringFUTF16( |
| + IDS_EXTENSION_PROMPT_WARNING_HOST_LIST_ENTRY, host_list[i]); |
| + } |
| } |
| return PermissionMessage(message_id, message, details); |