Index: base/string_util.cc |
diff --git a/base/string_util.cc b/base/string_util.cc |
index 19c1735308acf7dd908a9e1c966b356db7e6626c..494d09d2a605171ea0eab162b7e8fc70ed8c97d9 100644 |
--- a/base/string_util.cc |
+++ b/base/string_util.cc |
@@ -1324,6 +1324,54 @@ void SplitStringDontTrim(const std::string& str, |
SplitStringT(str, s, false, r); |
} |
+template <typename STR> |
+static void SplitStringUsingSubstrT(const STR& str, |
+ const STR& s, |
+ std::vector<STR>* r) { |
+ typename STR::size_type begin_index = 0; |
+ while (true) { |
+ const typename STR::size_type end_index = str.find(s, begin_index); |
+ if (end_index == STR::npos) { |
+ const STR term = str.substr(begin_index); |
+ STR tmp; |
+ TrimWhitespace(term, TRIM_ALL, &tmp); |
+ r->push_back(tmp); |
+ return; |
+ } |
+ const STR term = str.substr(begin_index, end_index - begin_index); |
+ STR tmp; |
+ TrimWhitespace(term, TRIM_ALL, &tmp); |
+ r->push_back(tmp); |
+ begin_index = end_index + s.size(); |
+ } |
+} |
+ |
+void SplitStringUsingSubstr(const string16& str, |
+ const string16& s, |
+ std::vector<string16>* r) { |
+ SplitStringUsingSubstrT(str, s, r); |
+} |
+ |
+void SplitStringUsingSubstr(const std::string& str, |
+ const std::string& s, |
+ std::vector<std::string>* r) { |
+ SplitStringUsingSubstrT(str, s, r); |
+} |
+ |
+std::vector<string16> SplitStringUsingSubstr(const string16& str, |
+ const string16& s) { |
+ std::vector<string16> result; |
+ SplitStringUsingSubstr(str, s, &result); |
+ return result; |
+} |
+ |
+std::vector<std::string> SplitStringUsingSubstr(const std::string& str, |
+ const std::string& s) { |
+ std::vector<std::string> result; |
+ SplitStringUsingSubstr(str, s, &result); |
+ return result; |
+} |
+ |
template<typename STR> |
static size_t TokenizeT(const STR& str, |
const STR& delimiters, |