Chromium Code Reviews| Index: ui/base/template_expressions.cc |
| diff --git a/ui/base/template_expressions.cc b/ui/base/template_expressions.cc |
| index 1d63e0c34eac113f386f5a80d5817faa092a5270..fae84923d6b8f4c94a5d52ae20b5b72ccf0aab1e 100644 |
| --- a/ui/base/template_expressions.cc |
| +++ b/ui/base/template_expressions.cc |
| @@ -8,29 +8,36 @@ |
| #include "base/logging.h" |
| +namespace { |
| + const char kLeader[] = "$i18n{"; |
| + const size_t kLeaderSize = arraysize(kLeader) - 1; |
| + const char kTail[] = "}"; |
| + const size_t kTailSize = arraysize(kTail) - 1; |
|
Dan Beam
2016/01/23 03:31:55
nit: don't indent inside of namespaces
dschuyler
2016/01/25 22:19:11
Done.
|
| +} // namespace |
| + |
| namespace ui { |
| std::string ReplaceTemplateExpressions( |
| base::StringPiece format_string, |
| - const std::map<base::StringPiece, std::string>& substitutions) { |
| + const TemplateReplacements& substitutions) { |
| std::string formatted; |
| const size_t kValueLengthGuess = 16; |
| formatted.reserve(format_string.length() + |
| substitutions.size() * kValueLengthGuess); |
| base::StringPiece::const_iterator i = format_string.begin(); |
| while (i < format_string.end()) { |
| - if (*i == '$' && i + 2 < format_string.end() && i[1] == '{' && |
| - i[2] != '}') { |
| - size_t key_start = i + strlen("${") - format_string.begin(); |
| - size_t key_length = format_string.find('}', key_start); |
| + if (base::StringPiece(i).starts_with(kLeader)) { |
| + size_t key_start = i + kLeaderSize - format_string.begin(); |
| + size_t key_length = format_string.find(kTail, key_start); |
| if (key_length == base::StringPiece::npos) |
| - NOTREACHED() << "TemplateExpression missing ending brace '}'"; |
| + NOTREACHED() << "TemplateExpression missing ending tag"; |
| key_length -= key_start; |
| - base::StringPiece key(format_string.begin() + key_start, key_length); |
| + std::string key(format_string.begin() + key_start, key_length); |
| + DCHECK(!key.empty()); |
| const auto& replacement = substitutions.find(key); |
| if (replacement != substitutions.end()) { |
| formatted.append(replacement->second); |
| - i += strlen("${") + key_length + strlen("}"); |
| + i += kLeaderSize + key_length + kTailSize; |
| continue; |
| } else { |
| NOTREACHED() << "TemplateExpression key not found: " << key; |