Changeset 829c907
- Timestamp:
- Mar 21, 2017, 10:04:47 PM (8 years ago)
- Branches:
- ADT, aaron-thesis, arm-eh, ast-experimental, cleanup-dtors, deferred_resn, demangler, enum, forall-pointer-decay, jacob/cs343-translation, jenkins-sandbox, master, new-ast, new-ast-unique-expr, new-env, no_list, persistent-indexer, pthread-emulation, qualifiedEnum, resolv-new, with_gc
- Children:
- 87d13cd
- Parents:
- 89d129c
- Location:
- src
- Files:
-
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
src/libcfa/fstream
r89d129c r829c907 10 10 // Created On : Wed May 27 17:56:53 2015 11 11 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Tue Mar 7 14:48:08201713 // Update Count : 9112 // Last Modified On : Tue Mar 21 15:57:24 2017 13 // Update Count : 102 14 14 // 15 15 … … 21 21 enum { separateSize = 16 }; 22 22 struct ofstream { 23 void * file;23 void * file; 24 24 _Bool sepDefault; 25 25 _Bool sepOnOff; 26 const char * sepCur; 26 27 char separator[separateSize]; 28 char tupleSeparator[separateSize]; 27 29 }; // ofstream 28 30 … … 32 34 void sepReset( ofstream * ); 33 35 void sepReset( ofstream *, _Bool ); 36 const char * sepGetCur( ofstream * ); 37 void sepSetCur( ofstream *, const char * ); 34 38 const char * sepGet( ofstream * ); 35 39 void sepSet( ofstream *, const char * ); 40 const char * sepGetTuple( ofstream * ); 41 void sepSetTuple( ofstream *, const char * ); 36 42 _Bool sepDisable( ofstream * ); 37 43 _Bool sepEnable( ofstream * ); … … 42 48 void close( ofstream * ); 43 49 ofstream * write( ofstream *, const char * data, unsigned long int size ); 44 int prtfmt( ofstream *, const char fmt[], ... ); 50 int fmt( ofstream *, const char fmt[], ... ); 51 52 void ?{}( ofstream * ); 45 53 46 54 extern ofstream * sout, * serr; … … 48 56 // implement context istream 49 57 struct ifstream { 50 void * file;58 void * file; 51 59 }; // ifstream 52 60 … … 57 65 ifstream * read( ifstream * is, char * data, unsigned long int size ); 58 66 ifstream * ungetc( ifstream * is, char c ); 59 int scanfmt( ifstream *, const char fmt[], ... );67 int fmt( ifstream *, const char fmt[], ... ); 60 68 61 extern ifstream * sin;69 extern ifstream * sin; 62 70 63 71 #endif // __FSTREAM_H__ -
src/libcfa/fstream.c
r89d129c r829c907 10 10 // Created On : Wed May 27 17:56:53 2015 11 11 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Tue Mar 7 14:48:09201713 // Update Count : 19212 // Last Modified On : Tue Mar 21 20:56:10 2017 13 // Update Count : 215 14 14 // 15 15 … … 33 33 void sepReset( ofstream * os ) { os->sepOnOff = os->sepDefault; } 34 34 void sepReset( ofstream * os, _Bool reset ) { os->sepDefault = reset; os->sepOnOff = os->sepDefault; } 35 36 const char * sepGetCur( ofstream * os ) { return os->sepCur; } 37 void sepSetCur( ofstream * os, const char * sepCur ) { os->sepCur = sepCur; } 38 35 39 const char * sepGet( ofstream * os ) { return &(os->separator[0]); } 36 40 … … 38 42 strncpy( &(os->separator[0]), s, separateSize - 1 ); 39 43 os->separator[separateSize - 1] = '\0'; 44 } // sepSet 45 46 const char * sepGetTuple( ofstream * os ) { return &(os->tupleSeparator[0]); } 47 48 void sepSetTuple( ofstream * os, const char * s ) { 49 strncpy( &(os->tupleSeparator[0]), s, separateSize - 1 ); 50 os->tupleSeparator[separateSize - 1] = '\0'; 40 51 } // sepSet 41 52 … … 95 106 } // write 96 107 97 int prtfmt( ofstream * os, const char fmt[], ... ) {108 int fmt( ofstream * os, const char format[], ... ) { 98 109 va_list args; 99 va_start( args, f mt );100 int len = vfprintf( (FILE *)(os->file), f mt, args );110 va_start( args, format ); 111 int len = vfprintf( (FILE *)(os->file), format, args ); 101 112 if ( len == EOF ) { 102 113 if ( ferror( (FILE *)(os->file) ) ) { … … 109 120 sepReset( os ); // reset separator 110 121 return len; 111 } // prtfmt 112 113 114 static ofstream soutFile = { (FILE *)(&_IO_2_1_stdout_), 1, 0, { ' ', '\0' } }; 122 } // fmt 123 124 void ?{}( ofstream * this, void * file, _Bool sepDefault, _Bool sepOnOff, const char * separator, const char * tupleSeparator ) { 125 this->file = file; 126 this->sepDefault = sepDefault; 127 this->sepOnOff = sepOnOff; 128 sepSet( this, separator ); 129 sepSetCur( this, sepGet( this ) ); 130 sepSetTuple( this, tupleSeparator ); 131 } 132 133 static ofstream soutFile = { (FILE *)(&_IO_2_1_stdout_), 1, 0, " ", ", " }; 115 134 ofstream *sout = &soutFile; 116 static ofstream serrFile = { (FILE *)(&_IO_2_1_stderr_), 1, 0, { ' ', '\0' }};135 static ofstream serrFile = { (FILE *)(&_IO_2_1_stderr_), 1, 0, " ", ", " }; 117 136 ofstream *serr = &serrFile; 118 137 … … 173 192 } // ungetc 174 193 175 int scanfmt( ifstream * is, const char fmt[], ... ) {194 int fmt( ifstream * is, const char format[], ... ) { 176 195 va_list args; 177 196 178 va_start( args, f mt );179 int len = vfscanf( (FILE *)(is->file), f mt, args );197 va_start( args, format ); 198 int len = vfscanf( (FILE *)(is->file), format, args ); 180 199 if ( len == EOF ) { 181 200 if ( ferror( (FILE *)(is->file) ) ) { … … 186 205 va_end( args ); 187 206 return len; 188 } // prtfmt207 } // fmt 189 208 190 209 -
src/libcfa/iostream
r89d129c r829c907 10 10 // Created On : Wed May 27 17:56:53 2015 11 11 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Mon Mar 6 20:51:35201713 // Update Count : 9812 // Last Modified On : Tue Mar 21 15:57:29 2017 13 // Update Count : 104 14 14 // 15 15 … … 25 25 void sepReset( ostype * ); // set separator state to default state 26 26 void sepReset( ostype *, _Bool ); // set separator and default state 27 const char * sepGetCur( ostype * ); // get current separator string 28 void sepSetCur( ostype *, const char * ); // set current separator string 29 const char * sepGet( ostype * ); // get separator string 27 30 void sepSet( ostype *, const char * ); // set separator to string (15 character maximum) 28 const char * sepGet( ostype * ); // get separator string 31 const char * sepGetTuple( ostype * ); // get tuple separator string 32 void sepSetTuple( ostype *, const char * ); // set tuple separator to string (15 character maximum) 29 33 _Bool sepDisable( ostype * ); // set default state to off, and return previous state 30 34 _Bool sepEnable( ostype * ); // set default state to on, and return previous state … … 35 39 void close( ostype * os ); 36 40 ostype * write( ostype *, const char *, unsigned long int ); 37 int prtfmt( ostype *, const char fmt[], ... );41 int fmt( ostype *, const char fmt[], ... ); 38 42 }; 39 43 … … 95 99 istype * read( istype *, char *, unsigned long int ); 96 100 istype * ungetc( istype *, char ); 97 int scanfmt( istype *, const char fmt[], ... );101 int fmt( istype *, const char fmt[], ... ); 98 102 }; 99 103 -
src/libcfa/iostream.c
r89d129c r829c907 10 10 // Created On : Wed May 27 17:56:53 2015 11 11 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Mon Mar 6 20:52:02201713 // Update Count : 3 1312 // Last Modified On : Tue Mar 21 20:58:48 2017 13 // Update Count : 347 14 14 // 15 15 … … 24 24 25 25 forall( dtype ostype | ostream( ostype ) ) 26 ostype * ?|?( ostype * os, char c ) {27 prtfmt( os, "%c", c );28 sepOff( os ); 29 return os; 30 } // ?|? 31 32 forall( dtype ostype | ostream( ostype ) ) 33 ostype * ?|?( ostype * os, signed char c ) {34 prtfmt( os, "%hhd", c );35 sepOff( os ); 36 return os; 37 } // ?|? 38 39 forall( dtype ostype | ostream( ostype ) ) 40 ostype * ?|?( ostype * os, unsigned char c ) {41 prtfmt( os, "%hhu", c );42 sepOff( os ); 43 return os; 44 } // ?|? 45 46 forall( dtype ostype | ostream( ostype ) ) 47 ostype * ?|?( ostype * os, short int si ) {48 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );49 prtfmt( os, "%hd", si );50 return os; 51 } // ?|? 52 53 forall( dtype ostype | ostream( ostype ) ) 54 ostype * ?|?( ostype * os, unsigned short int usi ) {55 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );56 prtfmt( os, "%hu", usi );57 return os; 58 } // ?|? 59 60 forall( dtype ostype | ostream( ostype ) ) 61 ostype * ?|?( ostype * os, int i ) {62 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );63 prtfmt( os, "%d", i );64 return os; 65 } // ?|? 66 67 forall( dtype ostype | ostream( ostype ) ) 68 ostype * ?|?( ostype * os, unsigned int ui ) {69 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );70 prtfmt( os, "%u", ui );71 return os; 72 } // ?|? 73 74 forall( dtype ostype | ostream( ostype ) ) 75 ostype * ?|?( ostype * os, long int li ) {76 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );77 prtfmt( os, "%ld", li );78 return os; 79 } // ?|? 80 81 forall( dtype ostype | ostream( ostype ) ) 82 ostype * ?|?( ostype * os, unsigned long int uli ) {83 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );84 prtfmt( os, "%lu", uli );85 return os; 86 } // ?|? 87 88 forall( dtype ostype | ostream( ostype ) ) 89 ostype * ?|?( ostype * os, long long int lli ) {90 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );91 prtfmt( os, "%lld", lli );92 return os; 93 } // ?|? 94 95 forall( dtype ostype | ostream( ostype ) ) 96 ostype * ?|?( ostype * os, unsigned long long int ulli ) {97 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );98 prtfmt( os, "%llu", ulli );99 return os; 100 } // ?|? 101 102 forall( dtype ostype | ostream( ostype ) ) 103 ostype * ?|?( ostype * os, float f ) {104 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );105 prtfmt( os, "%g", f );106 return os; 107 } // ?|? 108 109 forall( dtype ostype | ostream( ostype ) ) 110 ostype * ?|?( ostype * os, double d ) {111 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );112 prtfmt( os, "%.*lg", DBL_DIG, d );113 return os; 114 } // ?|? 115 116 forall( dtype ostype | ostream( ostype ) ) 117 ostype * ?|?( ostype * os, long double ld ) {118 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );119 prtfmt( os, "%.*Lg", LDBL_DIG, ld );120 return os; 121 } // ?|? 122 123 forall( dtype ostype | ostream( ostype ) ) 124 ostype * ?|?( ostype * os, float _Complex fc ) {26 ostype * ?|?( ostype * os, char c ) { 27 fmt( os, "%c", c ); 28 sepOff( os ); 29 return os; 30 } // ?|? 31 32 forall( dtype ostype | ostream( ostype ) ) 33 ostype * ?|?( ostype * os, signed char c ) { 34 fmt( os, "%hhd", c ); 35 sepOff( os ); 36 return os; 37 } // ?|? 38 39 forall( dtype ostype | ostream( ostype ) ) 40 ostype * ?|?( ostype * os, unsigned char c ) { 41 fmt( os, "%hhu", c ); 42 sepOff( os ); 43 return os; 44 } // ?|? 45 46 forall( dtype ostype | ostream( ostype ) ) 47 ostype * ?|?( ostype * os, short int si ) { 48 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 49 fmt( os, "%hd", si ); 50 return os; 51 } // ?|? 52 53 forall( dtype ostype | ostream( ostype ) ) 54 ostype * ?|?( ostype * os, unsigned short int usi ) { 55 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 56 fmt( os, "%hu", usi ); 57 return os; 58 } // ?|? 59 60 forall( dtype ostype | ostream( ostype ) ) 61 ostype * ?|?( ostype * os, int i ) { 62 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 63 fmt( os, "%d", i ); 64 return os; 65 } // ?|? 66 67 forall( dtype ostype | ostream( ostype ) ) 68 ostype * ?|?( ostype * os, unsigned int ui ) { 69 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 70 fmt( os, "%u", ui ); 71 return os; 72 } // ?|? 73 74 forall( dtype ostype | ostream( ostype ) ) 75 ostype * ?|?( ostype * os, long int li ) { 76 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 77 fmt( os, "%ld", li ); 78 return os; 79 } // ?|? 80 81 forall( dtype ostype | ostream( ostype ) ) 82 ostype * ?|?( ostype * os, unsigned long int uli ) { 83 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 84 fmt( os, "%lu", uli ); 85 return os; 86 } // ?|? 87 88 forall( dtype ostype | ostream( ostype ) ) 89 ostype * ?|?( ostype * os, long long int lli ) { 90 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 91 fmt( os, "%lld", lli ); 92 return os; 93 } // ?|? 94 95 forall( dtype ostype | ostream( ostype ) ) 96 ostype * ?|?( ostype * os, unsigned long long int ulli ) { 97 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 98 fmt( os, "%llu", ulli ); 99 return os; 100 } // ?|? 101 102 forall( dtype ostype | ostream( ostype ) ) 103 ostype * ?|?( ostype * os, float f ) { 104 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 105 fmt( os, "%g", f ); 106 return os; 107 } // ?|? 108 109 forall( dtype ostype | ostream( ostype ) ) 110 ostype * ?|?( ostype * os, double d ) { 111 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 112 fmt( os, "%.*lg", DBL_DIG, d ); 113 return os; 114 } // ?|? 115 116 forall( dtype ostype | ostream( ostype ) ) 117 ostype * ?|?( ostype * os, long double ld ) { 118 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 119 fmt( os, "%.*Lg", LDBL_DIG, ld ); 120 return os; 121 } // ?|? 122 123 forall( dtype ostype | ostream( ostype ) ) 124 ostype * ?|?( ostype * os, float _Complex fc ) { 125 125 os | crealf( fc ); 126 126 _Bool temp = sepDisable( os ); // disable separators within complex value … … 132 132 133 133 forall( dtype ostype | ostream( ostype ) ) 134 ostype * ?|?( ostype * os, double _Complex dc ) {134 ostype * ?|?( ostype * os, double _Complex dc ) { 135 135 os | creal( dc ); 136 136 _Bool temp = sepDisable( os ); // disable separators within complex value … … 142 142 143 143 forall( dtype ostype | ostream( ostype ) ) 144 ostype * ?|?( ostype * os, long double _Complex ldc ) {144 ostype * ?|?( ostype * os, long double _Complex ldc ) { 145 145 os | creall( ldc ); 146 146 _Bool temp = sepDisable( os ); // disable separators within complex value … … 152 152 153 153 forall( dtype ostype | ostream( ostype ) ) 154 ostype * ?|?( ostype * os, const char *cp ) {154 ostype * ?|?( ostype * os, const char * cp ) { 155 155 enum { Open = 1, Close, OpenClose }; 156 156 static const unsigned char mask[256] = { … … 161 161 // closing delimiters, no space before 162 162 [','] : Close, ['.'] : Close, [':'] : Close, [';'] : Close, ['!'] : Close, ['?'] : Close, 163 ['%'] : Close, [(unsigned char)'¢'] : Close, [(unsigned char)'»'] : Close, 163 164 [')'] : Close, [']'] : Close, ['}'] : Close, 164 ['%'] : Close, [(unsigned char)'¢'] : Close, [(unsigned char)'»'] : Close,165 165 // opening-closing delimiters, no space before or after 166 166 ['\''] : OpenClose, ['`'] : OpenClose, ['"'] : OpenClose, … … 173 173 unsigned char ch = cp[0]; // must make unsigned 174 174 if ( sepPrt( os ) && mask[ ch ] != Close && mask[ ch ] != OpenClose ) { 175 prtfmt( os, "%s", sepGet( os ) );175 fmt( os, "%s", sepGetCur( os ) ); 176 176 } // if 177 177 … … 191 191 192 192 forall( dtype ostype | ostream( ostype ) ) 193 ostype * ?|?( ostype * os, const void *p ) {194 if ( sepPrt( os ) ) prtfmt( os, "%s", sepGet( os ) );195 prtfmt( os, "%p", p );193 ostype * ?|?( ostype * os, const void * p ) { 194 if ( sepPrt( os ) ) fmt( os, "%s", sepGetCur( os ) ); 195 fmt( os, "%p", p ); 196 196 return os; 197 197 } // ?|? … … 201 201 forall( dtype ostype, otype T, ttype Params | ostream( ostype ) | writeable( T ) | { ostype * ?|?( ostype *, Params ); } ) 202 202 ostype * ?|?( ostype * os, T arg, Params rest ) { 203 os | arg | ", "; 204 os | rest; 203 sepSetCur( os, sepGetTuple( os ) ); // switch to tuple separator 204 os | arg; // print first argument 205 os | rest; // print remaining arguments 206 sepSetCur( os, sepGet( os ) ); // switch to regular separator 205 207 } // ?|? 206 208 … … 247 249 248 250 forall( otype elttype | writeable( elttype ), otype iteratortype | iterator( iteratortype, elttype ), dtype ostype | ostream( ostype ) ) 249 void write( iteratortype begin, iteratortype end, ostype * os ) {251 void write( iteratortype begin, iteratortype end, ostype * os ) { 250 252 void print( elttype i ) { os | i; } 251 253 for_each( begin, end, print ); … … 253 255 254 256 forall( otype elttype | writeable( elttype ), otype iteratortype | iterator( iteratortype, elttype ), dtype ostype | ostream( ostype ) ) 255 void write_reverse( iteratortype begin, iteratortype end, ostype * os ) {257 void write_reverse( iteratortype begin, iteratortype end, ostype * os ) { 256 258 void print( elttype i ) { os | i; } 257 259 for_each_reverse( begin, end, print ); … … 262 264 forall( dtype istype | istream( istype ) ) 263 265 istype * ?|?( istype * is, char * c ) { 264 scanfmt( is, "%c", c );266 fmt( is, "%c", c ); 265 267 return is; 266 268 } // ?|? … … 268 270 forall( dtype istype | istream( istype ) ) 269 271 istype * ?|?( istype * is, short int * si ) { 270 scanfmt( is, "%hd", si );272 fmt( is, "%hd", si ); 271 273 return is; 272 274 } // ?|? … … 274 276 forall( dtype istype | istream( istype ) ) 275 277 istype * ?|?( istype * is, unsigned short int * usi ) { 276 scanfmt( is, "%hu", usi );278 fmt( is, "%hu", usi ); 277 279 return is; 278 280 } // ?|? … … 280 282 forall( dtype istype | istream( istype ) ) 281 283 istype * ?|?( istype * is, int * i ) { 282 scanfmt( is, "%d", i );284 fmt( is, "%d", i ); 283 285 return is; 284 286 } // ?|? … … 286 288 forall( dtype istype | istream( istype ) ) 287 289 istype * ?|?( istype * is, unsigned int * ui ) { 288 scanfmt( is, "%u", ui );290 fmt( is, "%u", ui ); 289 291 return is; 290 292 } // ?|? … … 292 294 forall( dtype istype | istream( istype ) ) 293 295 istype * ?|?( istype * is, long int * li ) { 294 scanfmt( is, "%ld", li );296 fmt( is, "%ld", li ); 295 297 return is; 296 298 } // ?|? … … 298 300 forall( dtype istype | istream( istype ) ) 299 301 istype * ?|?( istype * is, unsigned long int * ulli ) { 300 scanfmt( is, "%lu", ulli );302 fmt( is, "%lu", ulli ); 301 303 return is; 302 304 } // ?|? … … 304 306 forall( dtype istype | istream( istype ) ) 305 307 istype * ?|?( istype * is, long long int * lli ) { 306 scanfmt( is, "%lld", lli );308 fmt( is, "%lld", lli ); 307 309 return is; 308 310 } // ?|? … … 310 312 forall( dtype istype | istream( istype ) ) 311 313 istype * ?|?( istype * is, unsigned long long int * ulli ) { 312 scanfmt( is, "%llu", ulli );314 fmt( is, "%llu", ulli ); 313 315 return is; 314 316 } // ?|? … … 317 319 forall( dtype istype | istream( istype ) ) 318 320 istype * ?|?( istype * is, float * f ) { 319 scanfmt( is, "%f", f );321 fmt( is, "%f", f ); 320 322 return is; 321 323 } // ?|? … … 323 325 forall( dtype istype | istream( istype ) ) 324 326 istype * ?|?( istype * is, double * d ) { 325 scanfmt( is, "%lf", d );327 fmt( is, "%lf", d ); 326 328 return is; 327 329 } // ?|? … … 329 331 forall( dtype istype | istream( istype ) ) 330 332 istype * ?|?( istype * is, long double * ld ) { 331 scanfmt( is, "%Lf", ld );333 fmt( is, "%Lf", ld ); 332 334 return is; 333 335 } // ?|? … … 337 339 istype * ?|?( istype * is, float _Complex * fc ) { 338 340 float re, im; 339 scanfmt( is, "%g%gi", &re, &im );341 fmt( is, "%g%gi", &re, &im ); 340 342 *fc = re + im * _Complex_I; 341 343 return is; … … 345 347 istype * ?|?( istype * is, double _Complex * dc ) { 346 348 double re, im; 347 scanfmt( is, "%lf%lfi", &re, &im );349 fmt( is, "%lf%lfi", &re, &im ); 348 350 *dc = re + im * _Complex_I; 349 351 return is; … … 353 355 istype * ?|?( istype * is, long double _Complex * ldc ) { 354 356 long double re, im; 355 scanfmt( is, "%Lf%Lfi", &re, &im );357 fmt( is, "%Lf%Lfi", &re, &im ); 356 358 *ldc = re + im * _Complex_I; 357 359 return is; … … 361 363 forall( dtype istype | istream( istype ) ) 362 364 istype * ?|?( istype * is, _Istream_cstrUC cstr ) { 363 scanfmt( is, "%s", cstr.s );365 fmt( is, "%s", cstr.s ); 364 366 return is; 365 367 } // cstr … … 370 372 char buf[16]; 371 373 sprintf( buf, "%%%ds", cstr.size ); 372 scanfmt( is, buf, cstr.s );374 fmt( is, buf, cstr.s ); 373 375 return is; 374 376 } // cstr -
src/tests/.expect/io.txt
r89d129c r829c907 18 18 abc, $xyz 19 19 20 v(27 v[27 v{27 $27 £27 ¥27 ¡27 ¿27 «2721 25, 25. 25: 25; 25! 25? 25 ) 25] 25} 25% 25¢ 25»20 v(27 v[27 v{27 $27 =27 £27 ¥27 ¡27 ¿27 «27 21 25, 25. 25: 25; 25! 25? 25% 25¢ 25» 25) 25] 25} 22 22 25'27 25`27 25"27 25 27 25 23 23 27 25 … … 25 25 27 25 27 25 26 26 27 27 Segmentation fault (core dumped) -
src/tests/io.c
r89d129c r829c907 10 10 // Created On : Wed Mar 2 16:56:02 2016 11 11 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Tue Jul 5 18:29:23 201613 // Update Count : 3112 // Last Modified On : Tue Mar 21 21:24:50 2017 13 // Update Count : 47 14 14 // 15 15 … … 62 62 63 63 sepSet( sout, ", $" ); // change separator, maximum of 15 characters 64 sout | f | d | ld | endl // floating point without separator65 | fc | dc | ldc | endl // complex without separator64 sout | f | d | ld | endl 65 | fc | dc | ldc | endl 66 66 | s1 | s2 | endl; 67 67 sout | endl; … … 74 74 | "v{" | 27 75 75 | "$" | 27 76 | "=" | 27 76 77 | "£" | 27 77 78 | "¥" | 27 … … 87 88 | 25 | "!" 88 89 | 25 | "?" 90 | 25 | "%" 91 | 25 | "¢" 92 | 25 | "»" 89 93 | 25 | ")" 90 94 | 25 | "]" 91 95 | 25 | "}" 92 | 25 | "%"93 | 25 | "¢"94 | 25 | "»"95 96 | endl 96 97 // opening-closing delimiters … … 105 106 | 25 | "\v" | 27 106 107 | endl; 108 109 [int, int, const char *, double] t = { 3, 4, "a", 7.2 }; 110 sout | [ 3, 4, 'a', 7.2 ] | endl; 111 sout | t | endl; 112 sepSetTuple( sout, " " ); 113 sout | t | endl; 114 sout | sepOn | t | sepDisable | t | sepEnable | t | endl; 115 sepSet( sout, "^" ); 116 sepSetTuple( sout, "-" ); 117 sout | t | 3 | 4 | t | endl; 107 118 } 108 119
Note: See TracChangeset
for help on using the changeset viewer.