X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=flower%2Fstd-string.cc;h=593a286d84e291313a3266c4f0d874549268bc56;hb=77267b700c377fd170abcbf4863728937038eb5e;hp=5232574366c79c950c4e99101b09e5c88535764d;hpb=41d87651a93844bceca9a8ccb6417642aca24457;p=lilypond.git diff --git a/flower/std-string.cc b/flower/std-string.cc index 5232574366..593a286d84 100644 --- a/flower/std-string.cc +++ b/flower/std-string.cc @@ -1,16 +1,28 @@ /* - std-string.cc -- implement external interface for Std_String + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter + Copyright (C) 2006--2015 Jan Nieuwenhuizen - (c) 2006--2007 Jan Nieuwenhuizen + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . */ #include "std-string.hh" #include "string-convert.hh" +#include "std-vector.hh" string -to_string (string s) +to_string (const string &s) { return s; } @@ -48,7 +60,7 @@ to_string (long b) string to_string (long unsigned b) { - return String_convert::unsigned_string (b); + return String_convert::unsigned_long_string (b); } string @@ -57,6 +69,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, ...) { @@ -74,8 +92,9 @@ string & 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); + ssize replen = replace.length (); + for (ssize i = str->find (find); i != NPOS; i = str->find (find, i + replen)) + * str = str->replace (i, len, replace); return *str; } @@ -88,24 +107,16 @@ replace_all (string *str, char find, char replace) } char * -string_copy (string s) +string_copy (const string &s) { ssize len = s.length (); char *dest = new char[len + 1]; copy (s.begin (), s.end (), dest); dest[len] = 0; - - return dest; -} -int -string_compare (string const &a, string const &b) -{ - return a.compare (b); + return dest; } -#include "std-vector.hh" - vector string_split (string str, char c) { @@ -116,7 +127,7 @@ string_split (string str, char c) { string s = str.substr (0, i); a.push_back (s); - i ++; + i++; str = str.substr (i); i = str.find (c); } @@ -126,13 +137,13 @@ string_split (string str, char c) } string -string_join (vector const &strs, string infix) +string_join (vector const &strs, const string &infix) { string result; - for (vsize i = 0; i < strs.size (); i ++) + for (vsize i = 0; i < strs.size (); i++) { if (i) - result += infix; + result += infix; result += strs[i]; }