lilypond-1.3.141
[lilypond.git] / flower / string-convert.cc
blobd44857c423976bfbc333c221191cc688d08e4ee6
1 /*
2 PROJECT: FlowerSoft C++ library
3 FILE : string-convert.cc
5 --*/
7 #include <string.h>
8 #include <stdio.h>
9 #include <assert.h>
10 #include <limits.h>
11 #include "libc-extension.hh"
12 #include "string.hh"
13 #include "string-convert.hh"
14 #include "rational.hh"
15 #include "array.hh"
17 /**
18 A safe length for stringconversion buffers.
20 worst case would be %f printing HUGE (or 1/HUGE), which is approx
21 2e318, this number would have approx 318 zero's in its string.
23 Should enlarge buff dynamically.
25 @see
26 man 3 snprintf
28 static const int STRING_BUFFER_LEN=1024;
30 String
31 String_convert::bool_str (bool b)
33 return String (b ? "true" : "false");
36 String
37 String_convert::bin2hex_str (String bin_str)
39 String str;
40 Byte const* byte_C = bin_str.byte_C ();
41 for (int i = 0; i < bin_str.length_i (); i++)
43 str += to_str ((char)nibble2hex_byte (*byte_C >> 4));
44 str += to_str ((char)nibble2hex_byte (*byte_C++));
46 return str;
49 int
50 String_convert::bin2_i (String bin_str)
52 return bin2_u (bin_str);
55 unsigned
56 String_convert::bin2_u (String bin_str)
58 assert (bin_str.length_i () <= (int)sizeof (unsigned));
60 unsigned result_u = 0;
61 for (int i = 0; i < bin_str.length_i (); i++)
63 result_u <<= 8;
64 result_u += (Byte)bin_str[ i ];
66 return result_u;
69 // breendet imp from String
70 int
71 String_convert::dec2_i (String dec_str)
73 if (!dec_str.length_i ())
74 return 0;
76 long l = 0;
77 int conv = sscanf (dec_str.ch_C (), "%ld", &l);
78 assert (conv);
80 return (int)l;
83 String
84 String_convert::i64_str (I64 i64, char const* fmt)
86 char buffer[STRING_BUFFER_LEN];
87 snprintf (buffer, STRING_BUFFER_LEN,
88 (fmt ? fmt : "%Ld"), i64); // assume radix 10
89 return String (buffer);
92 // breendet imp from String
93 double
94 String_convert::dec2_f (String dec_str)
96 if (!dec_str.length_i ())
97 return 0;
98 double d = 0;
99 int conv = sscanf (dec_str.ch_C (), "%lf", &d);
100 assert (conv);
101 return d;
105 String_convert::hex2bin_i (String hex_str, String& bin_str_r)
107 if (hex_str.length_i () % 2)
108 hex_str = "0" + hex_str;
110 bin_str_r = "";
111 Byte const* byte_C= hex_str.byte_C ();
112 int i = 0;
113 while (i < hex_str.length_i ())
115 int high_i = hex2nibble_i (*byte_C++);
116 int low_i = hex2nibble_i (*byte_C++);
117 if (high_i < 0 || low_i < 0)
118 return 1; // illegal char
119 bin_str_r += to_str ((char) (high_i << 4 | low_i), 1 );
120 i += 2;
122 return 0;
125 String
126 String_convert::hex2bin_str (String hex_str)
128 String str;
129 // silly, asserts should alway be "on"!
130 // assert (!hex2bin_i (hex_str, str) );
131 int error_i = hex2bin_i (hex_str, str);
132 assert (!error_i);
133 return str;
136 int
137 String_convert::hex2nibble_i (Byte byte)
139 if (byte >= '0' && byte <= '9')
140 return byte - '0';
141 if (byte >= 'A' && byte <= 'F')
142 return byte - 'A' + 10;
143 if (byte >= 'a' && byte <= 'f')
144 return byte - 'a' + 10;
145 return -1;
148 // stupido. Should use int_str ()
149 String
150 String_convert::i2dec_str (int i, int length_i, char ch)
152 char fill_ch = ch;
153 if (fill_ch)
154 fill_ch = '0';
156 // ugh
157 String dec_str = to_str (i);
159 // ugh
160 return to_str (fill_ch, length_i - dec_str.length_i ()) + dec_str;
164 // stupido. Should use int_str ()
165 String
166 String_convert::u2hex_str (unsigned u, int length_i, char fill_ch)
168 String str;
169 if (!u)
170 str = "0";
172 #if 1 // both go...
173 while (u)
175 str = to_str ((char) ((u % 16)["0123456789abcdef"] ) ) + str;
176 u /= 16;
178 #else
179 str += int_str (u, "%x"); // hmm. %lx vs. %x -> portability?
180 #endif
182 str = to_str (fill_ch, length_i - str.length_i ()) + str;
183 while ((str.length_i () > length_i) && (str[ 0 ] == 'f' ) )
184 str = str.cut_str (2, INT_MAX);
186 return str;
189 String
190 String_convert::i2hex_str (int i, int length_i, char fill_ch)
192 return u2hex_str ((unsigned)i, length_i, fill_ch);
195 Byte
196 String_convert::nibble2hex_byte (Byte byte)
198 if ((byte & 0x0f) <= 9 )
199 return (byte & 0x0f) + '0';
200 else
201 return (byte & 0x0f) - 10 + 'a';
204 Convert an integer to a string
206 @param
207 #fmt# is a printf style format, default assumes "%d" as format.
209 String
210 String_convert::int_str (int i, char const* fmt)
212 char buffer[STRING_BUFFER_LEN];
213 snprintf (buffer, STRING_BUFFER_LEN,
214 (fmt ? fmt : "%d"), i); // assume radix 10
215 return String (buffer);
218 String
219 String_convert::form_str (char const* format, ...)
221 va_list args;
222 va_start (args, format);
223 char buffer[STRING_BUFFER_LEN];
224 vsnprintf (buffer, STRING_BUFFER_LEN, format, args);
225 va_end (args);
226 return String (buffer);
229 String
230 String_convert::vform_str (char const* format, va_list args)
232 char buffer[STRING_BUFFER_LEN];
233 vsnprintf (buffer, STRING_BUFFER_LEN, format, args);
234 return String (buffer);
238 Convert a double to a string.
240 @param #fmt# is a printf style format, default assumes "%lf" as format
242 String
243 String_convert::double_str (double f, char const* fmt)
245 char buf[STRING_BUFFER_LEN];
247 snprintf (buf, STRING_BUFFER_LEN, fmt ? fmt : "%f", f);
248 return String (buf);
252 Make a string from a single character.
254 @param
255 #n# is a repetition count, default value is 1
257 String
258 String_convert::char_str (char c, int n)
260 n = n >= 0 ? n : 0;
261 char* ch_p = new char[ n ];
262 memset (ch_p, c, n);
263 String s ((Byte*)ch_p, n);
264 delete[] ch_p;
265 return s;
268 String
269 String_convert::rational_str (Rational r)
271 return r.str ();
274 String
275 String_convert::pointer_str (void const *l)
277 char buffer[STRING_BUFFER_LEN];
278 snprintf (buffer, STRING_BUFFER_LEN, "%p", l); // assume radix 10
279 return String (buffer);
283 Convert a double to a string.
285 @param
286 #n# is the number of nonzero digits
288 String
289 String_convert::precision_str (double x, int n)
291 String format = "%." + to_str (0 >? n - 1) + "e";
292 String str = double_str (abs (x), format.ch_C ());
294 int exp = str.right_str (3).value_i ();
295 str = str.left_str (str.length_i () - 4);
297 while (str[str.length_i () - 1] == '0')
298 str = str.left_str (str.length_i () - 1);
299 if (str[str.length_i () - 1] == '.')
300 str = str.left_str (str.length_i () - 1);
302 if (exp == 0)
303 return (sign (x) > 0 ? str : "-" + str);
305 str = str.left_str (1) + str.cut_str (2, INT_MAX);
306 int dot = 1 + exp;
307 if (dot <= 0)
308 str = "0." + to_str ('0', -dot) + str;
309 else if (dot >= str.length_i ())
310 str += to_str ('0', dot - str.length_i ());
311 else if (( dot > 0) && (dot < str.length_i ()))
312 str = str.left_str (dot) + "." + str.cut_str (dot, INT_MAX);
313 else
314 assert (0);
316 return (sign (x) > 0 ? str : "-" + str);
319 Array<String>
320 String_convert::split_arr (String str, char c)
322 Array<String> a;
323 int i = str.index_i (c);
324 while (i >=0)
326 String s = str.left_str (i);
327 a.push (s);
328 while (str[++i] == c)
330 str = str.cut_str (i, INT_MAX);
331 i = str.index_i (c);
333 if (str.length_i ())
334 a.push (str);
335 return a;
339 String
340 String_convert::long_str (long l)
342 char s[STRING_BUFFER_LEN];
343 sprintf (s,"%ld", l);
344 return s;
347 String
348 String_convert::pad_to (String s, int n)
350 return s + to_str (' ' , (n - s.length_i ()) >? 0);