| 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,
|
|
|