]> git.donarmstrong.com Git - lilypond.git/blob - flower/std-string.cc
Merge master into nested-bookparts
[lilypond.git] / flower / std-string.cc
1 /*
2   std-string.cc -- implement external interface for Std_String
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 2006--2007  Jan Nieuwenhuizen <janneke@gnu.org>
7 */
8
9 #include "std-string.hh"
10 #include "string-convert.hh"
11
12 string
13 to_string (string s)
14 {
15   return s;
16 }
17
18 string
19 to_string (char c, int n)
20 {
21   return string (max (n, 0), c);
22 }
23
24 string
25 to_string (double f, char const *format)
26 {
27   return String_convert::double_string (f, format);
28 }
29
30 string
31 to_string (int i, char const *format)
32 {
33   return String_convert::int_string (i, format);
34 }
35
36 string
37 to_string (bool b)
38 {
39   return String_convert::bool_string (b);
40 }
41
42 string
43 to_string (long b)
44 {
45   return String_convert::long_string (b);
46 }
47
48 string
49 to_string (long unsigned b)
50 {
51   return String_convert::unsigned_string (b);
52 }
53
54 string
55 to_string (unsigned u)
56 {
57   return String_convert::unsigned_string (u);
58 }
59
60 string
61 to_string (I64 b, char const *format)
62 {
63   return String_convert::i64_string (b, format);
64 }
65
66 string
67 to_string (char const *format, ...)
68 {
69   va_list args;
70   va_start (args, format);
71   string str = String_convert::vform_string (format, args);
72   va_end (args);
73   return str;
74 }
75
76 /*
77   TODO: this O(n^2) in #occurences of find, due to repeated copying.
78  */
79 string &
80 replace_all (string *str, string const &find, string const &replace)
81 {
82   ssize len = find.length ();
83   for (ssize i = str->find (find); i != NPOS; i = str->find (find, i + len))
84     *str = str->replace (i, len, replace);
85   return *str;
86 }
87
88 string &
89 replace_all (string *str, char find, char replace)
90 {
91   for (ssize i = str->find (find); i != NPOS; i = str->find (find, i + 1))
92     (*str)[i] = replace;
93   return *str;
94 }
95
96 char *
97 string_copy (string s)
98 {
99   ssize len = s.length ();
100   char *dest = new char[len + 1];
101   copy (s.begin (), s.end (), dest);
102   dest[len] = 0;
103   
104   return dest;
105 }
106
107 int
108 string_compare (string const &a, string const &b)
109 {
110   return a.compare (b);
111 }
112
113 #include "std-vector.hh"
114
115 vector<string>
116 string_split (string str, char c)
117 {
118   ssize i = str.find (c);
119
120   vector<string> a;
121   while (i != NPOS)
122     {
123       string s = str.substr (0, i);
124       a.push_back (s);
125       i ++;
126       str = str.substr (i);
127       i = str.find (c);
128     }
129   if (str.length ())
130     a.push_back (str);
131   return a;
132 }
133
134 string
135 string_join (vector<string> const &strs, string infix)
136 {
137   string result;
138   for (vsize i = 0; i < strs.size (); i ++)
139     {
140       if (i)
141         result += infix;
142       result += strs[i];
143     }
144
145   return result;
146 }