X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=flower%2Fstd-string.cc;h=ec5ddffbd4bd05f013b666004938e7350a50ec15;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=b78b0196616aa1adde6f46b9ab64df379b523ed5;hpb=f9214bac21e9926dc3248416f58190c98c4167a9;p=lilypond.git diff --git a/flower/std-string.cc b/flower/std-string.cc index b78b019661..ec5ddffbd4 100644 --- a/flower/std-string.cc +++ b/flower/std-string.cc @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 2006--2007 Jan Nieuwenhuizen + (c) 2006--2008 Jan Nieuwenhuizen */ #include "std-string.hh" @@ -57,6 +57,12 @@ to_string (unsigned u) return String_convert::unsigned_string (u); } +string +to_string (I64 b, char const *format) +{ + return String_convert::i64_string (b, format); +} + string to_string (char const *format, ...) { @@ -67,21 +73,24 @@ to_string (char const *format, ...) return str; } +/* + TODO: this O(n^2) in #occurences of find, due to repeated copying. + */ string & -replace_all (string &str, string find, string replace) +replace_all (string *str, string const &find, string const &replace) { ssize len = find.length (); - for (ssize i = str.find (find); i != NPOS; i = str.find (find, i + len)) - str = str.replace (i, len, replace); - return str; + for (ssize i = str->find (find); i != NPOS; i = str->find (find, i + len)) + *str = str->replace (i, len, replace); + return *str; } string & -replace_all (string &str, char find, char replace) +replace_all (string *str, char find, char replace) { - for (ssize i = str.find (find); i != NPOS; i = str.find (find, i + 1)) - str[i] = replace; - return str; + for (ssize i = str->find (find); i != NPOS; i = str->find (find, i + 1)) + (*str)[i] = replace; + return *str; } char * @@ -113,8 +122,7 @@ string_split (string str, char c) { string s = str.substr (0, i); a.push_back (s); - while (str[++i] == c) - ; + i ++; str = str.substr (i); i = str.find (c); } @@ -122,3 +130,17 @@ string_split (string str, char c) a.push_back (str); return a; } + +string +string_join (vector const &strs, string infix) +{ + string result; + for (vsize i = 0; i < strs.size (); i ++) + { + if (i) + result += infix; + result += strs[i]; + } + + return result; +}