Index: base/strings/string_util.cc |
diff --git a/base/strings/string_util.cc b/base/strings/string_util.cc |
index a0c95ec124f9fd0c4df8e303ced84ad3ff20d6d1..ae5fb80d4f7a16bb1505187cc4e4032c5e31e59a 100644 |
--- a/base/strings/string_util.cc |
+++ b/base/strings/string_util.cc |
@@ -884,35 +884,42 @@ |
return WriteIntoT(str, length_with_null); |
} |
+} // namespace base |
+ |
template<typename STR> |
-static STR JoinStringT(const std::vector<STR>& parts, |
- BasicStringPiece<STR> sep) { |
+static STR JoinStringT(const std::vector<STR>& parts, const STR& sep) { |
if (parts.empty()) |
return STR(); |
STR result(parts[0]); |
- auto iter = parts.begin(); |
+ typename std::vector<STR>::const_iterator iter = parts.begin(); |
++iter; |
for (; iter != parts.end(); ++iter) { |
- sep.AppendToString(&result); |
+ result += sep; |
result += *iter; |
} |
return result; |
} |
+std::string JoinString(const std::vector<std::string>& parts, char sep) { |
+ return JoinStringT(parts, std::string(1, sep)); |
+} |
+ |
+string16 JoinString(const std::vector<string16>& parts, char16 sep) { |
+ return JoinStringT(parts, string16(1, sep)); |
+} |
+ |
std::string JoinString(const std::vector<std::string>& parts, |
- StringPiece separator) { |
+ const std::string& separator) { |
return JoinStringT(parts, separator); |
} |
string16 JoinString(const std::vector<string16>& parts, |
- StringPiece16 separator) { |
+ const string16& separator) { |
return JoinStringT(parts, separator); |
} |
- |
-} // namespace base |
template<class FormatStringType, class OutStringType> |
OutStringType DoReplaceStringPlaceholders(const FormatStringType& format_string, |