lilypond-1.1.55
[lilypond.git] / flower / string.cc
blob70278756b450177380b29f69e8ae5ee72f99fd3d
1 /*
3 string.cc - implement String
5 (c) 1997--1998 Han-Wen Nienhuys & Jan Nieuwenhuizen
7 */
9 #ifndef _GNU_SOURCE // we want memmem
10 #define _GNU_SOURCE
11 #endif
13 #include <stdlib.h>
14 #include <stdio.h>
16 #include <assert.h>
17 #include <string.h>
18 #include <stdarg.h>
20 #include "string.hh"
21 #include "libc-extension.hh"
22 #include "string-convert.hh"
24 #ifdef STRING_DEBUG
25 void* mymemmove (void* dest, void const* src, size_t n);
26 #define memmove mymemmove
27 #endif
29 // return array, alloced with new.
30 Byte*
31 String::copy_byte_p () const
33 Byte const* src = strh_.byte_C ();
34 Byte* dest = new Byte[strh_.length_i () + 1];
35 memcpy (dest, src, strh_.length_i () + 1);
36 return dest;
39 char*
40 String::copy_ch_p () const
42 return (char*)copy_byte_p ();
45 void
46 String::print_on (ostream& os) const
48 if (!strh_.is_binary_bo ())
49 os << ch_C ();
50 else
51 for (int i = 0; i < length_i (); i++)
52 os << (Byte) (*this)[ i ];
56 copying, constructing.
58 String&
59 String::operator = (String const&source)
61 strh_ = source.strh_;
62 return *this;
65 String::String (char const* source)
67 assert (source);
68 strh_ = source;
71 String::String (Byte const* byte_l, int length_i)
73 strh_.set (byte_l, length_i);
76 /**
77 @see
78 String_convert::
80 String
81 to_str (char c, int n)
83 return String_convert::char_str (c, n);
86 String
87 to_str (double f, char const* format)
89 return String_convert::double_str (f, format);
92 String
93 to_str (int i, char const * format)
95 return String_convert::int_str (i, format);
98 String
99 to_str (bool b)
101 return String_convert::bool_str (b);
104 String
105 to_str (char const* format, ... )
107 va_list args;
108 va_start (args, format);
109 String str = String_convert::vform_str (format, args);
110 va_end (args);
111 return str;
115 void
116 String::append (String s)
118 strh_.append (s.byte_C (), s.length_i ());
120 void
121 String::operator += (String s)
123 append (s);
126 void
127 String::prepend (String s)
129 s += *this;
130 *this = s;
134 String::length_i () const
136 return strh_.length_i ();
139 Byte const*
140 String::byte_C () const
142 return strh_.byte_C ();
145 char const*
146 String::ch_C () const
148 return strh_.ch_C ();
151 Byte*
152 String::byte_l ()
154 return strh_.byte_l ();
157 char*
158 String::ch_l ()
160 return strh_.ch_l ();
163 bool
164 String::empty_b () const
166 return !length_i ();
169 Do a signed comparison, analogous to memcmp;
172 String::compare_i (String const& s1, String const& s2)
174 Byte const* p1 = s1.byte_C ();
175 Byte const* p2 = s2.byte_C ();
176 if (p1 == p2)
177 return 0;
180 don't forget the terminating '\0'
182 int f = (s1.length_i () <? s2.length_i ());
183 int cmp_length = 1+ f;
184 int i = memcmp (p1, p2, cmp_length);
185 return i;
190 String::index_last_i (char const c) const
192 if (!length_i ())
193 return -1;
195 char const* me = strh_.ch_C ();
196 char const* p = (char const*)memrchr ( (Byte*)me, length_i (), c);
197 if (p)
198 return p - me;
199 return -1;
203 String::index_last_i (char const* string) const // UGK!
205 assert (false); // broken
206 int length = strlen (string); // ugrh
207 if (!length_i () || !length)
208 return -1;
210 int next_i = index_i (string);
211 if (next_i == -1)
212 return -1;
214 int index_i = 0;
215 while (next_i >= 0)
217 index_i += next_i;
218 next_i = right_str (length_i () - index_i - length).index_i (string );
220 return index_i;
223 /** find a character.
225 @return
226 the index of the leftmost character #c# (0 <= return < length_i ()),
227 or -1 if not found.
229 ? should return length_i ()?, as in string.left_str (index_i (delimiter))
232 String::index_i (char c) const
234 char const* me = strh_.ch_C ();
235 char const* p = (char const *) memchr (me,c, length_i ());
236 if (p)
237 return p - me;
238 return -1;
242 find a substring.
244 @return
245 1 index of leftmost occurrence of #searchfor#
248 String::index_i (String searchfor) const
250 char const* me = strh_.ch_C ();
252 char const* p = (char const *)
253 memmem (me, length_i (), searchfor.ch_C (), searchfor.length_i ());
255 if (p)
256 return p - me;
257 else
258 return -1;
261 /** find chars of a set.
263 @return
265 the index of the leftmost occurance of an element of #set#. -1 if
266 nothing is found.
271 String::index_any_i (String set) const
273 int n = length_i ();
274 if (!n)
275 return -1;
277 void const * me_l = (void const *) strh_.ch_C ();
278 for (int i=0; i < set.length_i (); i++)
280 char * found= (char*) memchr (me_l, set[i], n );
281 if (found)
283 return found - me_l;
286 return -1;
289 String
290 String::left_str (int n) const
292 if (n >= length_i ())
293 return *this;
295 String retval;
296 if (n < 1)
297 return retval;
299 retval = *this;
300 retval.strh_.trunc (n);
301 return retval;
304 String
305 String::right_str (int n) const
307 if (n > length_i ())
308 return *this;
310 if (n < 1)
311 return "";
313 return String (strh_.byte_C () + length_i () - n, n);
317 String
318 String::nomid_str (int index_i, int n) const
320 if (index_i < 0)
322 n += index_i;
323 index_i = 0;
325 if (n <= 0)
326 return *this;
328 return
329 left_str (index_i) +
330 right_str (length_i () - index_i - n) ;
333 String
334 String::cut_str (int index_i, int n) const
336 if (index_i <0)
338 n += index_i;
339 index_i=0;
342 if (!length_i () || (index_i < 0) || (index_i >= length_i () ) || (n < 1 ) )
343 return String ();
345 if ( (n > length_i ()) || (index_i + n > length_i () ) )
346 n = length_i () - index_i;
348 return String (byte_C () + index_i, n);
351 String
352 String::upper_str () const
354 String str = *this;
355 str.to_upper ();
356 return str;
358 void
359 String::to_upper ()
361 char *s = (char*)strh_.byte_l ();
362 strnupr (s ,length_i ());
365 void
366 String::to_lower ()
368 char* s = strh_.ch_l ();
369 strnlwr (s,length_i ());
373 String
374 String::lower_str () const
376 String str = *this;
377 str.to_lower ();
378 return str;
380 String
381 String::reversed_str () const
383 String str = *this;
384 strrev (str.byte_l (), str.length_i ());
385 return str;
389 String::value_i () const
391 return String_convert::dec2_i (*this);
394 double
395 String::value_f () const
397 return String_convert::dec2_f (*this);