*** empty log message ***
[chuck-blob.git] / v2 / util_string.cpp
blobc9cd013c358b65abe32cb9e3eb5a2c1f0fea745e
1 /*----------------------------------------------------------------------------
2 ChucK Concurrent, On-the-fly Audio Programming Language
3 Compiler and Virtual Machine
5 Copyright (c) 2004 Ge Wang and Perry R. Cook. All rights reserved.
6 http://chuck.cs.princeton.edu/
7 http://soundlab.cs.princeton.edu/
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
22 U.S.A.
23 -----------------------------------------------------------------------------*/
25 //-----------------------------------------------------------------------------
26 // name: util_string.cpp
27 // desc: ...
29 // author: Ge Wang (gewang@cs.princeton.edu)
30 // Perry R. Cook (prc@cs.princeton.edu)
31 // date: Summer 2005
32 //-----------------------------------------------------------------------------
33 #include "util_string.h"
34 using namespace std;
39 //-----------------------------------------------------------------------------
40 // name: itoa()
41 // desc: ...
42 //-----------------------------------------------------------------------------
43 string itoa( t_CKINT val )
45 char buffer[128];
46 sprintf( buffer, "%li", val );
47 return string(buffer);
52 //-----------------------------------------------------------------------------
53 // name: ftoa()
54 // desc: ...
55 //-----------------------------------------------------------------------------
56 string ftoa( t_CKFLOAT val, t_CKUINT precision )
58 char str[32];
59 char buffer[128];
60 if( precision > 32 ) precision = 32;
61 sprintf( str, "%%.%lif", precision );
62 sprintf( buffer, str, val );
63 return string(buffer);
69 //-----------------------------------------------------------------------------
70 // name: tolower()
71 // desc: ...
72 //-----------------------------------------------------------------------------
73 string tolower( const string & str )
75 string s = str;
76 t_CKUINT len = s.length();
78 // loop
79 for( t_CKUINT i = 0; i < len; i++ )
80 if( s[i] >= 'A' && s[i] <= 'Z' )
81 s[i] += 32;
83 return s;
89 //-----------------------------------------------------------------------------
90 // name: toupper()
91 // desc: ...
92 //-----------------------------------------------------------------------------
93 string toupper( const string & str )
95 string s = str;
96 t_CKUINT len = s.length();
98 // loop
99 for( t_CKUINT i = 0; i < len; i++ )
100 if( s[i] >= 'a' && s[i] <= 'z' )
101 s[i] -= 32;
103 return s;
109 //-----------------------------------------------------------------------------
110 // name: trim()
111 // desc: ...
112 //-----------------------------------------------------------------------------
113 string trim( const string & val )
115 // two ends
116 t_CKINT start = 0;
117 t_CKINT end = val.length() - 1;
119 // left trim
120 for( start = 0; start < end; start++ )
122 // non-white space
123 if( val[start] != ' ' && val[start] != '\t' )
124 break;
127 // if start > end, then all white space
128 if( start > end ) return "";
130 // right trim
131 for( ; end >= start; end-- )
133 // non-white space
134 if( val[end] != ' ' && val[end] != '\t' )
135 break;
138 // cannot be
139 assert( end >= start );
141 // return
142 return val.substr( start, end - start + 1 );
147 //-----------------------------------------------------------------------------
148 // name: ltrim()
149 // desc: ...
150 //-----------------------------------------------------------------------------
151 string ltrim( const string & val )
153 // two ends
154 t_CKINT start = 0;
155 t_CKINT end = val.length() - 1;
157 // left trim
158 for( start = 0; start < end; start++ )
160 // non-white space
161 if( val[start] != ' ' && val[start] != '\t' )
162 break;
165 // if start > end, then all white space
166 if( start > end ) return "";
168 // return
169 return val.substr( start, end - start + 1 );
175 //-----------------------------------------------------------------------------
176 // name: rtrim()
177 // desc: ...
178 //-----------------------------------------------------------------------------
179 string rtrim( const string & val )
181 // two ends
182 t_CKINT start = 0;
183 t_CKINT end = val.length() - 1;
185 // right trim
186 for( ; end >= start; end-- )
188 // non-white space
189 if( val[end] != ' ' && val[end] != '\t' )
190 break;
193 // if end < start, then all white space
194 if( end < start ) return "";
196 // return
197 return val.substr( start, end - start + 1 );
203 //-----------------------------------------------------------------------------
204 // name: extract_args()
205 // desc: extract argument from format filename:arg1:arg2:etc
206 //-----------------------------------------------------------------------------
207 t_CKBOOL extract_args( const string & token,
208 string & filename, vector<string> & args )
210 // clear vector
211 args.clear();
212 // clear filename
213 filename = "";
215 // last : found pos
216 t_CKINT prev_pos = 0;
217 // curr : pos
218 t_CKINT i = 0;
220 // copy and trim
221 string s = trim( token );
223 // detect
224 t_CKBOOL scan = FALSE;
225 t_CKBOOL ret = TRUE;
226 char * buf = NULL;
227 char * mask = NULL;
228 for( i = 0; i < s.length(); i++ )
229 if( s[i] == '\\' )
231 scan = TRUE;
232 break;
235 // mad...
236 if( scan )
238 buf = new char[s.length()+1];
239 mask = new char[s.length()];
240 t_CKINT len = 0;
242 // loop through
243 for( i = 0; i < s.length(); i++ )
245 // zero
246 mask[len] = 0;
248 // escape
249 if( s[i] == '\\' && (i+1) < s.length() && s[i+1] == ':' )
251 i++;
252 mask[len] = 1;
255 // add
256 buf[len++] = s[i];
259 // end
260 buf[len] = '\0';
262 // copy
263 s = buf;
266 // loop through
267 for( i = 0; i < s.length(); i++ )
269 // look for :
270 if( s[i] == ':' && ( !mask || !mask[i] ) )
272 // sanity
273 if( i == 0 )
275 ret = FALSE;
276 goto done;
279 // copy
280 if( filename == "" )
281 filename = s.substr( prev_pos, i - prev_pos );
282 else
283 args.push_back( s.substr( prev_pos, i - prev_pos ) );
285 // update
286 prev_pos = i + 1;
290 // get the remainder, if any
291 if( prev_pos < s.length() )
293 // copy
294 if( filename == "" )
295 filename = s.substr( prev_pos, s.length() - prev_pos );
296 else
297 args.push_back( s.substr( prev_pos, s.length() - prev_pos ) );
300 done:
301 // reclaim
302 SAFE_DELETE_ARRAY( buf );
303 SAFE_DELETE_ARRAY( mask );
305 return ret;