Changeset 2c60af75
- Timestamp:
- Aug 23, 2019, 6:43:43 AM (5 years ago)
- Branches:
- ADT, arm-eh, ast-experimental, enum, forall-pointer-decay, jacob/cs343-translation, jenkins-sandbox, master, new-ast, new-ast-unique-expr, pthread-emulation, qualifiedEnum
- Children:
- ef22ad6
- Parents:
- e0bd0f9
- Location:
- driver
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
driver/cc1.cc
re0bd0f9 r2c60af75 10 10 // Created On : Fri Aug 26 14:23:51 2005 11 11 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Mon Sep 3 16:57:05 201813 // Update Count : 12512 // Last Modified On : Thu Aug 22 22:29:52 2019 13 // Update Count : 328 14 14 // 15 15 … … 19 19 #include <string> 20 20 using std::string; 21 #include <algorithm> // find 21 22 #include <cstdio> // stderr, stdout, perror, fprintf 22 23 #include <cstdlib> // getenv, exit, mkstemp … … 30 31 31 32 32 string compiler_name( CFA_BACKEND_CC ); // path/name of C compiler 33 34 string D__GCC_BPREFIX__( "-D__GCC_BPREFIX__=" ); 35 string D__CFA_FLAGPREFIX__( "-D__CFA_FLAG__=" ); 36 37 char tmpname[] = P_tmpdir "/CFAXXXXXX"; 38 int tmpfilefd = -1; 39 40 41 bool prefix( string arg, string pre ) { 33 static string installlibdir( CFA_LIBDIR ); // fixed location of cc1 and cfa-cpp commands when installed 34 static string compiler_path( CFA_BACKEND_CC ); // path/name of C compiler 35 static bool CFA_flag = false; // -CFA flag 36 static string o_file; 37 38 static bool prefix( const string & arg, const string & pre ) { 42 39 return arg.substr( 0, pre.size() ) == pre; 43 40 } // prefix 44 41 45 enum { NumSuffixes = 2 }; 46 const string suffixes[NumSuffixes] = { "cfa", "hfa",};47 48 void suffix( string arg, const char * args[], int & nargs ) { 42 static void suffix( const string & arg, const char * args[], int & nargs ) { 43 enum { NumSuffixes = 3 }; 44 static const string suffixes[NumSuffixes] = { "cfa", "hfa", "ifa" }; 45 49 46 //std::cerr << arg << std::endl; 50 47 size_t dot = arg.find_last_of( "." ); 51 48 //std::cerr << dot << " " << (dot != string::npos ? arg.substr( dot + 1 ) : "fred" ) << std::endl; 52 49 if ( dot == string::npos ) return; 53 string sx = arg.substr( dot + 1 ); 54 for ( int i = 0; i < NumSuffixes; i += 1 ) { 55 if ( sx == suffixes[i] ) { 56 args[nargs] = "-x"; 57 nargs += 1; 58 args[nargs] = "c"; 59 nargs += 1; 60 return; 61 } // if 62 } // for 50 const string * end = suffixes + NumSuffixes; 51 if ( std::find( suffixes, end, arg.substr( dot + 1 ) ) != end ) { 52 args[nargs++] = "-x"; 53 args[nargs++] = "c"; 54 } // if 63 55 } // suffix 64 56 65 57 66 void checkEnv( const char * args[], int & nargs ) { 67 char *value; 68 69 value = getenv( "__CFA_COMPILER__" ); 70 if ( value != NULL ) { 71 compiler_name = value; 72 #ifdef __DEBUG_H__ 73 cerr << "env arg:\"" << compiler_name << "\"" << endl; 74 #endif // __DEBUG_H__ 75 } // if 76 77 value = getenv( "__GCC_MACHINE__" ); 78 if ( value != NULL ) { 79 args[nargs] = ( *new string( value ) ).c_str(); // pass the argument along 80 #ifdef __DEBUG_H__ 81 cerr << "env arg:\"" << args[nargs] << "\"" << endl; 82 #endif // __DEBUG_H__ 83 nargs += 1; 84 } // if 85 86 value = getenv( "__GCC_VERSION__" ); 87 if ( value != NULL ) { 88 args[nargs] = ( *new string( value ) ).c_str(); // pass the argument along 89 #ifdef __DEBUG_H__ 90 cerr << "env arg:\"" << args[nargs] << "\"" << endl; 91 #endif // __DEBUG_H__ 92 nargs += 1; 93 } // if 94 } // checkEnv 95 96 97 void rmtmpfile() { 58 static string __CFA_FLAGPREFIX__( "__CFA_FLAG" ); 59 60 static void checkEnv1( const char * args[], int & nargs ) { // stage 1 61 extern char ** environ; 62 63 for ( int i = 0; environ[i]; i += 1 ) { 64 string arg = environ[i]; 65 #ifdef __DEBUG_H__ 66 cerr << "env arg:\"" << arg << "\"" << endl; 67 #endif // __DEBUG_H__ 68 69 if ( prefix( arg, __CFA_FLAGPREFIX__ ) ) { 70 string val = arg.substr( __CFA_FLAGPREFIX__.size() + 4 ); 71 if ( prefix( val, "-compiler=" ) ) { 72 compiler_path = val.substr( 10 ); 73 } // if 74 } // if 75 } // for 76 } // checkEnv1 77 78 79 static void checkEnv2( const char * args[], int & nargs ) { // stage 2 80 extern char ** environ; 81 82 for ( int i = 0; environ[i]; i += 1 ) { 83 string arg = environ[i]; 84 #ifdef __DEBUG_H__ 85 cerr << "env arg:\"" << arg << "\"" << endl; 86 #endif // __DEBUG_H__ 87 88 if ( prefix( arg, __CFA_FLAGPREFIX__ ) ) { 89 string val = arg.substr( __CFA_FLAGPREFIX__.size() + 4 ); 90 if ( prefix( val, "-compiler=" ) ) { 91 compiler_path = val.substr( 10 ); 92 } else if ( prefix( val, "-CFA" ) ) { 93 CFA_flag = true; 94 } else if ( prefix( val, "-o=" ) ) { // output file for -CFA 95 o_file = val.substr( 3 ); 96 } else { 97 args[nargs++] = ( *new string( arg.substr( __CFA_FLAGPREFIX__.size() + 4 ) ) ).c_str(); 98 } // if 99 } // if 100 } // for 101 } // checkEnv2 102 103 104 static char tmpname[] = P_tmpdir "/CFAXXXXXX.i"; 105 static int tmpfilefd = -1; 106 static bool startrm = false; 107 108 static void rmtmpfile() { 109 startrm = true; // RACE with C-c C-c 98 110 if ( unlink( tmpname ) == -1 ) { // remove tmpname 99 perror ( "C FA Translator error: cpp failed" );100 exit( EXIT_FAILURE ); 101 } // if 102 tmpfilefd = -1; // mark closed111 perror ( "CC1 Translator error: failed, unlink" ); 112 exit( EXIT_FAILURE ); 113 } // if 114 tmpfilefd = -1; // mark removed 103 115 } // rmtmpfile 104 116 105 117 106 void sigTermHandler( __attribute__((unused)) int signal ) { 118 static void sigTermHandler( int ) { // C-c C-c 119 if ( startrm ) return; // return and let rmtmpfile finish, and then program finishes 120 107 121 if ( tmpfilefd != -1 ) { // RACE, file created ? 108 rmtmpfile(); // remove 109 exit( EXIT_FAILURE ); // terminate110 } // if122 rmtmpfile(); // remove tmpname 123 } // if 124 exit( EXIT_FAILURE ); // terminate 111 125 } // sigTermHandler 112 126 113 127 114 void Stage1( const int argc, const char * const argv[] ) {128 static void Stage1( const int argc, const char * const argv[] ) { 115 129 int code; 116 117 130 string arg; 118 string bprefix;119 131 120 132 const char *cpp_in = NULL; 121 133 const char *cpp_out = NULL; 122 134 123 bool CFA_flag = false;124 135 bool cpp_flag = false; 125 const char *o_name = NULL;136 bool o_flag = false; 126 137 127 138 const char *args[argc + 100]; // leave space for 100 additional cpp command line values 128 139 int nargs = 1; // number of arguments in args list; 0 => command name 129 const char *cargs[20]; // leave space for 20 additional cfa-cpp command line values130 int ncargs = 1; // 0 => command name131 132 signal( SIGINT, sigTermHandler );133 signal( SIGTERM, sigTermHandler );134 140 135 141 #ifdef __DEBUG_H__ 136 142 cerr << "Stage1" << endl; 137 143 #endif // __DEBUG_H__ 138 checkEnv ( args, nargs ); // arguments passed via environment variables144 checkEnv1( args, nargs ); // arguments passed via environment variables 139 145 #ifdef __DEBUG_H__ 140 146 for ( int i = 1; i < argc; i += 1 ) { … … 168 174 i += 1; // and the argument 169 175 cpp_flag = true; 170 } else if ( arg == "-D__CFA_PREPROCESS__" ) { 171 CFA_flag = true; 172 } else if ( arg == "-D" && string( argv[i + 1] ) == "__CFA_PREPROCESS__" ) { 173 i += 1; // and the argument 174 CFA_flag = true; 175 } else if ( prefix( arg, D__CFA_FLAGPREFIX__ ) ) { 176 cargs[ncargs] = ( *new string( arg.substr( D__CFA_FLAGPREFIX__.size() ) ) ).c_str(); 177 ncargs += 1; 178 } else if ( arg == "-D" && prefix( argv[i + 1], D__CFA_FLAGPREFIX__.substr(2) ) ) { 179 cargs[ncargs] = ( *new string( string( argv[i + 1] ).substr( D__CFA_FLAGPREFIX__.size() - 2 ) ) ).c_str(); 180 ncargs += 1; 181 i += 1; // and the argument 182 } else if ( prefix( arg, D__GCC_BPREFIX__ ) ) { 183 bprefix = arg.substr( D__GCC_BPREFIX__.size() ); 184 } else if ( arg == "-D" && prefix( argv[i + 1], D__GCC_BPREFIX__.substr(2) ) ) { 185 bprefix = string( argv[i + 1] ).substr( D__GCC_BPREFIX__.size() - 2 ); 186 i += 1; // and the argument 187 188 // all other flags 176 177 // all other flags 189 178 190 179 } else if ( arg == "-o" ) { 191 180 i += 1; 192 o_name = argv[i]; 181 o_flag = true; 182 cpp_out = argv[i]; 193 183 } else { 194 args[nargs] = argv[i]; // pass the flag along 195 nargs += 1; 184 args[nargs++] = argv[i]; // pass the flag along 196 185 // CPP flags with an argument 197 186 if ( arg == "-D" || arg == "-U" || arg == "-I" || arg == "-MF" || arg == "-MT" || arg == "-MQ" || … … 199 188 arg == "-iwithprefix" || arg == "-iwithprefixbefore" || arg == "-isystem" || arg == "-isysroot" ) { 200 189 i += 1; 201 args[nargs] = argv[i]; // pass the argument along 202 nargs += 1; 190 args[nargs++] = argv[i]; // pass the argument along 203 191 #ifdef __DEBUG_H__ 204 192 cerr << "argv[" << i << "]:\"" << argv[i] << "\"" << endl; 205 193 #endif // __DEBUG_H__ 206 194 } else if ( arg == "-MD" || arg == "-MMD" ) { 207 args[nargs] = "-MF"; // insert before file 208 nargs += 1; 195 args[nargs++] = "-MF"; // insert before file 209 196 i += 1; 210 args[nargs] = argv[i]; // pass the argument along 211 nargs += 1; 197 args[nargs++] = argv[i]; // pass the argument along 212 198 #ifdef __DEBUG_H__ 213 199 cerr << "argv[" << i << "]:\"" << argv[i] << "\"" << endl; … … 252 238 // output or -o. The call to cfa has a -E so it does not have to be added to the argument list. 253 239 254 args[0] = compiler_ name.c_str();240 args[0] = compiler_path.c_str(); 255 241 suffix( cpp_in, args, nargs ); // check suffix 256 args[nargs] = cpp_in; 257 nargs += 1; 258 if ( o_name != NULL ) { // location for output 259 args[nargs] = "-o"; 260 nargs += 1; 261 args[nargs] = o_name; 262 nargs += 1; 263 } // if 242 args[nargs++] = cpp_in; 243 if ( o_flag ) { // location for output 244 args[nargs++] = "-o"; 245 } // if 246 args[nargs++] = cpp_out; 264 247 args[nargs] = NULL; // terminate argument list 265 248 … … 273 256 274 257 execvp( args[0], (char *const *)args ); // should not return 275 perror( "CFA Translator error: cpp level, execvp" ); 276 exit( EXIT_FAILURE ); 277 } // if 278 279 // Create a temporary file to store output of the C preprocessor. 280 281 tmpfilefd = mkstemp( tmpname ); 282 if ( tmpfilefd == -1 ) { 283 perror( "CFA Translator error: cpp level, mkstemp" ); 284 exit( EXIT_FAILURE ); 285 } // if 286 287 #ifdef __DEBUG_H__ 288 cerr << "tmpname:" << tmpname << " tmpfilefd:" << tmpfilefd << endl; 289 #endif // __DEBUG_H__ 290 291 // Run the C preprocessor and save the output in tmpfile. 258 perror( "CC1 Translator error: stage 1, execvp" ); 259 exit( EXIT_FAILURE ); 260 } // if 261 262 // Run the C preprocessor and save the output in the given file. 292 263 293 264 if ( fork() == 0 ) { // child process ? … … 295 266 // an error (e.g., cannot find include file). Whereas, output is always generated, even when there is an error, 296 267 // when cpp writes to stdout. Hence, stdout is redirected into the temporary file. 297 if ( freopen( tmpname, "w", stdout ) == NULL ) { // redirect stdout to tmpname298 perror( "C FA Translator error: cpp level, freopen" );268 if ( freopen( cpp_out, "w", stdout ) == NULL ) { // redirect stdout to output file 269 perror( "CC1 Translator error: stage 1, freopen" ); 299 270 exit( EXIT_FAILURE ); 300 271 } // if 301 272 302 args[0] = compiler_ name.c_str();273 args[0] = compiler_path.c_str(); 303 274 suffix( cpp_in, args, nargs ); // check suffix 304 args[nargs] = cpp_in; // input to cpp 305 nargs += 1; 275 args[nargs++] = cpp_in; // input to cpp 306 276 args[nargs] = NULL; // terminate argument list 307 277 … … 315 285 316 286 execvp( args[0], (char *const *)args ); // should not return 317 perror( "C FA Translator error: cpp level, execvp" );287 perror( "CC1 Translator error: stage 1, execvp" ); 318 288 exit( EXIT_FAILURE ); 319 289 } // if … … 325 295 #endif // __DEBUG_H__ 326 296 327 if ( WIFSIGNALED(code) != 0 ) { // child failed ?328 rmtmpfile(); // remove tmpname329 cerr << "CFA Translator error: cpp failed with signal " << WTERMSIG(code) << endl;330 exit( EXIT_FAILURE );331 } // if332 333 if ( WEXITSTATUS(code) != 0 ) { // child error ?334 rmtmpfile(); // remove tmpname335 exit( WEXITSTATUS( code ) ); // do not continue336 } // if337 338 // If -CFA flag specified, run the cfa-cpp preprocessor on the temporary file, and output is written to standard339 // output. Otherwise, run the cfa-cpp preprocessor on the temporary file and save the result into the output file.340 341 if ( fork() == 0 ) { // child runs CFA342 cargs[0] = ( *new string( bprefix + "cfa-cpp" ) ).c_str();343 344 // Source file-name used to generate routine names containing global initializations for TU.345 cargs[ncargs] = ( *new string( "-F" ) ).c_str();346 ncargs += 1;347 cargs[ncargs] = ( *new string( string( cpp_in ) ) ).c_str();348 ncargs += 1;349 350 cargs[ncargs] = tmpname;351 ncargs += 1;352 if ( o_name != NULL ) {353 cargs[ncargs] = o_name;354 ncargs += 1;355 } else if ( ! CFA_flag ) { // run cfa-cpp ?356 cargs[ncargs] = cpp_out;357 ncargs += 1;358 } // if359 cargs[ncargs] = NULL; // terminate argument list360 361 #ifdef __DEBUG_H__362 cerr << "cfa-cpp ncargs: " << (o_name ? o_name : "No -o") << " " << CFA_flag << " " << ncargs << endl;363 for ( int i = 0; cargs[i] != NULL; i += 1 ) {364 cerr << cargs[i] << " ";365 } // for366 cerr << endl;367 #endif // __DEBUG_H__368 369 execvp( cargs[0], (char * const *)cargs ); // should not return370 perror( "CFA Translator error: cpp level, execvp" );371 exit( EXIT_FAILURE );372 } // if373 374 wait( &code ); // wait for child to finish375 376 #ifdef __DEBUG_H__377 cerr << "return code from cfa-cpp:" << WEXITSTATUS(code) << endl;378 #endif // __DEBUG_H__379 380 // Must unlink here because file must exist across execvp.381 rmtmpfile(); // remove tmpname382 383 297 if ( WIFSIGNALED(code) ) { // child failed ? 384 cerr << "C FA Translator error: cfa-cpp failed with signal" << WTERMSIG(code) << endl;385 exit( EXIT_FAILURE ); 386 } // if 387 388 exit( WEXITSTATUS(code) ); 298 cerr << "CC1 Translator error: stage 1, child failed " << WTERMSIG(code) << endl; 299 exit( EXIT_FAILURE ); 300 } // if 301 302 exit( WEXITSTATUS(code) ); // bad cpp result stops top-level gcc 389 303 } // Stage1 390 304 391 305 392 void Stage2( const int argc, const char * const * argv ) { 306 static void Stage2( const int argc, const char * const * argv ) { 307 int code; 393 308 string arg; 394 309 395 const char *cpp_in = NULL; 310 const char * cpp_in = NULL; 311 const char * cpp_out = NULL; 396 312 397 313 const char *args[argc + 100]; // leave space for 100 additional cfa command line values 398 314 int nargs = 1; // number of arguments in args list; 0 => command name 315 const char *cargs[20]; // leave space for 20 additional cfa-cpp command line values 316 int ncargs = 1; // 0 => command name 399 317 400 318 #ifdef __DEBUG_H__ 401 319 cerr << "Stage2" << endl; 402 320 #endif // __DEBUG_H__ 403 checkEnv ( args, nargs ); // arguments passed via environment variables321 checkEnv2( cargs, ncargs ); // arguments passed via environment variables 404 322 #ifdef __DEBUG_H__ 405 323 for ( int i = 1; i < argc; i += 1 ) { … … 430 348 431 349 } else { 432 args[nargs] = argv[i]; // pass the flag along 433 nargs += 1; 350 args[nargs++] = argv[i]; // pass the flag along 434 351 if ( arg == "-o" ) { 435 352 i += 1; 436 args[nargs] = argv[i]; // pass the argument along437 nargs += 1;353 cpp_out = argv[i]; 354 args[nargs++] = argv[i]; // pass the argument along 438 355 #ifdef __DEBUG_H__ 439 356 cerr << "arg:\"" << argv[i] << "\"" << endl; … … 447 364 cerr << "cpp_in:\"" << cpp_in << "\"" << endl; 448 365 #endif // __DEBUG_H__ 366 } else if ( cpp_out == NULL ) { 367 cpp_out = argv[i]; 368 #ifdef __DEBUG_H__ 369 cerr << "cpp_out:\"" << cpp_out << "\""<< endl; 370 #endif // __DEBUG_H__ 449 371 } else { 450 372 cerr << "Usage: " << argv[0] << " input-file [output-file] [options]" << endl; … … 454 376 } // for 455 377 378 // Create a temporary file, if needed, to store output of the cfa-cpp preprocessor. Cannot be created in forked 379 // process because variables tmpname and tmpfilefd are cloned. 380 381 if ( ! CFA_flag ) { // run cfa-cpp ? 382 tmpfilefd = mkstemps( tmpname, 2 ); 383 if ( tmpfilefd == -1 ) { 384 perror( "CC1 Translator error: stage 2, mkstemp" ); 385 exit( EXIT_FAILURE ); 386 } // if 387 388 #ifdef __DEBUG_H__ 389 cerr << "tmpname:" << tmpname << " tmpfilefd:" << tmpfilefd << endl; 390 #endif // __DEBUG_H__ 391 } // if 392 393 // If -CFA flag specified, run the cfa-cpp preprocessor on the temporary file, and output is written to standard 394 // output. Otherwise, run the cfa-cpp preprocessor on the temporary file and save the result into the output file. 395 396 if ( fork() == 0 ) { // child runs CFA 397 cargs[0] = ( *new string( installlibdir + "cfa-cpp" ) ).c_str(); 398 399 cargs[ncargs++] = cpp_in; 400 401 if ( CFA_flag ) { // run cfa-cpp ? 402 if ( o_file.size() != 0 ) { // location for output 403 cargs[ncargs++] = ( *new string( o_file.c_str() ) ).c_str(); 404 } // if 405 } else { 406 cargs[ncargs++] = tmpname; 407 } // if 408 cargs[ncargs] = NULL; // terminate argument list 409 410 #ifdef __DEBUG_H__ 411 for ( int i = 0; cargs[i] != NULL; i += 1 ) { 412 cerr << cargs[i] << " "; 413 } // for 414 cerr << endl; 415 #endif // __DEBUG_H__ 416 417 execvp( cargs[0], (char * const *)cargs ); // should not return 418 perror( "CC1 Translator error: stage 2, execvp" ); 419 exit( EXIT_FAILURE ); 420 } // if 421 422 wait( &code ); // wait for child to finish 423 424 if ( WIFSIGNALED(code) ) { // child failed ? 425 rmtmpfile(); // remove tmpname 426 cerr << "CC1 Translator error: stage 2, child failed " << WTERMSIG(code) << endl; 427 exit( EXIT_FAILURE ); 428 } // if 429 430 if ( CFA_flag ) { // no tmpfile created 431 exit( WEXITSTATUS( code ) ); // stop regardless of success or failure 432 } // if 433 434 #ifdef __DEBUG_H__ 435 cerr << "return code from cfa-cpp:" << WEXITSTATUS(code) << endl; 436 #endif // __DEBUG_H__ 437 438 if ( WEXITSTATUS(code) ) { // child error ? 439 rmtmpfile(); // remove tmpname 440 exit( WEXITSTATUS( code ) ); // do not continue 441 } // if 442 456 443 #ifdef __DEBUG_H__ 457 444 cerr << "args:"; … … 463 450 #endif // __DEBUG_H__ 464 451 465 args[0] = compiler_name.c_str(); 466 args[nargs] = "-S"; // only compile and put assembler output in specified file 467 nargs += 1; 468 args[nargs] = cpp_in; 469 nargs += 1; 470 args[nargs] = NULL; // terminate argument list 471 472 #ifdef __DEBUG_H__ 473 cerr << "stage2 nargs: " << nargs << endl; 474 for ( int i = 0; args[i] != NULL; i += 1 ) { 475 cerr << args[i] << " "; 476 } // for 477 cerr << endl; 478 #endif // __DEBUG_H__ 479 480 execvp( args[0], (char * const *)args ); // should not return 481 perror( "CFA Translator error: cpp level, execvp" ); 482 exit( EXIT_FAILURE ); // tell gcc not to go any further 452 if ( fork() == 0 ) { // child runs CFA 453 args[0] = compiler_path.c_str(); 454 args[nargs++] = "-S"; // only compile and put assembler output in specified file 455 args[nargs++] = tmpname; 456 args[nargs] = NULL; // terminate argument list 457 458 #ifdef __DEBUG_H__ 459 cerr << "stage2 nargs: " << nargs << endl; 460 for ( int i = 0; args[i] != NULL; i += 1 ) { 461 cerr << args[i] << " "; 462 } // for 463 cerr << endl; 464 #endif // __DEBUG_H__ 465 466 execvp( args[0], (char * const *)args ); // should not return 467 perror( "CC1 Translator error: stage 2, execvp" ); 468 exit( EXIT_FAILURE ); // tell gcc not to go any further 469 } // if 470 471 wait( &code ); // wait for child to finish 472 473 if ( WIFSIGNALED(code) ) { // child failed ? 474 rmtmpfile(); // remove tmpname 475 cerr << "CC1 Translator error: stage 2, child failed " << WTERMSIG(code) << endl; 476 exit( EXIT_FAILURE ); 477 } // if 478 479 #ifdef __DEBUG_H__ 480 cerr << "return code from gcc cc1:" << WEXITSTATUS(code) << endl; 481 #endif // __DEBUG_H__ 482 483 rmtmpfile(); // remove tmpname 484 exit( WEXITSTATUS( code ) ); // stop regardless of success or failure 483 485 } // Stage2 484 486 487 488 // This program is called twice because of the -no-integrated-cpp. The calls are differentiated by the first 489 // command-line argument. The first call replaces the traditional cpp pass to preprocess the C program. The second call 490 // is to the compiler, which is broken into two steps: preprocess again with cfa-cpp and then call gcc to compile the 491 // doubly preprocessed program. 485 492 486 493 int main( const int argc, const char * const argv[], __attribute__((unused)) const char * const env[] ) { … … 490 497 } // for 491 498 #endif // __DEBUG_H__ 499 500 signal( SIGINT, sigTermHandler ); 501 signal( SIGTERM, sigTermHandler ); 492 502 493 503 string arg = argv[1]; -
driver/cfa.cc
re0bd0f9 r2c60af75 10 10 // Created On : Tue Aug 20 13:44:49 2002 11 11 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Sat Aug 10 08:44:15201913 // Update Count : 31112 // Last Modified On : Thu Aug 22 22:29:50 2019 13 // Update Count : 403 14 14 // 15 15 … … 28 28 #include "config.h" // configure info 29 29 30 31 30 using std::cerr; 32 31 using std::endl; … … 34 33 using std::to_string; 35 34 36 37 35 //#define __DEBUG_H__ 38 36 39 37 40 bool prefix( string arg, string pre ) { 38 void Putenv( char * argv[], string arg ) { 39 static int flags = 0; // environment variables must have unique names 40 41 if ( putenv( (char *)( *new string( string( "__CFA_FLAG" + to_string( flags++ ) + "__=" ) + arg ) ).c_str() ) != 0 ) { 42 cerr << argv[0] << " error, cannot set environment variable." << endl; 43 exit( EXIT_FAILURE ); 44 } // if 45 } // Putenv 46 47 48 bool prefix( const string & arg, const string & pre ) { // check if string has prefix 41 49 return arg.substr( 0, pre.size() ) == pre; 42 50 } // prefix 43 51 44 bool suffix( string arg ) {52 bool suffix( const string & arg ) { // check if string has suffix 45 53 enum { NumSuffixes = 3 }; 46 54 static const string suffixes[NumSuffixes] = { "cfa", "hfa", "ifa" }; 47 //std::cerr << arg << std::endl; 55 48 56 size_t dot = arg.find_last_of( "." ); 49 //std::cerr << dot << " " << (dot != string::npos ? arg.substr( dot + 1 ) : "fred" ) << std::endl;50 57 if ( dot == string::npos ) return false; 51 58 const string * end = suffixes + NumSuffixes; … … 54 61 55 62 56 void shuffle( const char * args[], int S, int E, int N ) { 57 // S & E index 1 passed the end so adjust with -1 58 #ifdef __DEBUG_H__ 59 cerr << "shuffle:" << S << " " << E << " " << N << endl; 60 #endif // __DEBUG_H__ 61 for ( int j = E-1 + N; j > S-1 + N; j -=1 ) { 62 #ifdef __DEBUG_H__ 63 cerr << "\t" << j << " " << j-N << endl; 64 #endif // __DEBUG_H__ 65 args[j] = args[j-N]; 66 } // for 67 } // shuffle 68 69 static inline bool dirExists( const string & path ) { 63 static inline bool dirExists( const string & path ) { // check if directory exists 70 64 struct stat info; 71 if(stat( path.c_str(), &info ) != 0) 72 return false; 73 else if(info.st_mode & S_IFDIR) 74 return true; 75 else 76 return false; 77 } //dirExists 78 79 65 if ( stat( path.c_str(), &info ) != 0 ) return false; 66 if ( info.st_mode & S_IFDIR ) return true; 67 return false; 68 } // dirExists 69 70 71 #define xstr(s) str(s) 80 72 #define str(s) #s 81 73 82 74 int main( int argc, char * argv[] ) { 83 75 string Version( CFA_VERSION_LONG ); // current version number from CONFIG 84 string Major( str( CFA_VERSION_MAJOR ) ), Minor( str( CFA_VERSION_MINOR ) ), Patch(str( CFA_VERSION_PATCH ) );76 string Major( xstr( CFA_VERSION_MAJOR ) ), Minor( xstr( CFA_VERSION_MINOR ) ), Patch( xstr( CFA_VERSION_PATCH ) ); 85 77 86 78 string installincdir( CFA_INCDIR ); // fixed location of include files … … 112 104 bool m64 = false; // -m64 flag 113 105 bool intree = false; 106 int o_file = 0; // -o filename position 114 107 115 108 const char *args[argc + 100]; // cfa command line values, plus some space for additional flags … … 135 128 136 129 if ( arg == "-Xlinker" || arg == "-o" ) { 137 args[nargs] = argv[i]; // pass the argument along 138 nargs += 1; 130 args[nargs++] = argv[i]; // pass argument along 139 131 i += 1; 140 132 if ( i == argc ) continue; // next argument available ? 141 args[nargs ] = argv[i]; // pass theargument along142 nargs += 1;133 args[nargs++] = argv[i]; // pass argument along 134 if ( arg == "-o" ) o_file = i; // remember file 143 135 } else if ( arg == "-XCFA" ) { // CFA pass through 144 136 i += 1; 145 args[nargs] = ( *new string( string("-D__CFA_FLAG__=") + argv[i] ) ).c_str(); 146 nargs += 1; 137 Putenv( argv, argv[i] ); 147 138 148 139 // CFA specific arguments … … 151 142 CFA_flag = true; // strip the -CFA flag 152 143 link = false; 153 args[nargs] = "-E"; // replace the argument with -E 154 nargs += 1; 144 args[nargs++] = "-fsyntax-only"; // stop after stage 2 155 145 } else if ( arg == "-debug" ) { 156 146 debug = true; // strip the debug flag 157 147 } else if ( arg == "-nodebug" ) { 158 debug = false; // strip the debug flag148 debug = false; // strip the nodebug flag 159 149 } else if ( arg == "-nolib" ) { 160 150 nolib = true; // strip the nodebug flag … … 176 166 if ( i == argc ) continue; // next argument available ? 177 167 compiler_path = argv[i]; 178 if ( putenv( (char *)( *new string( string( "__CFA_COMPILER__=" ) + argv[i]) ).c_str() ) != 0 ) { 179 cerr << argv[0] << " error, cannot set environment variable." << endl; 180 exit( EXIT_FAILURE ); 181 } // if 168 Putenv( argv, arg + "=" + argv[i] ); 182 169 183 170 // C specific arguments … … 185 172 } else if ( arg == "-v" ) { 186 173 verbose = true; // verbosity required 187 args[nargs] = argv[i]; // pass the argument along 188 nargs += 1; 174 args[nargs++] = argv[i]; // pass argument along 189 175 } else if ( arg == "-g" ) { 190 176 debugging = true; // symbolic debugging required 191 args[nargs] = argv[i]; // pass the argument along 192 nargs += 1; 177 args[nargs++] = argv[i]; // pass argument along 193 178 } else if ( prefix( arg, "-x" ) ) { // file suffix ? 194 179 string lang; 195 args[nargs] = argv[i]; // pass the argument along 196 nargs += 1; 180 args[nargs++] = argv[i]; // pass argument along 197 181 if ( arg.length() == 2 ) { // separate argument ? 198 182 i += 1; 199 183 if ( i == argc ) continue; // next argument available ? 200 184 lang = argv[i]; 201 args[nargs] = argv[i]; // pass the argument along 202 nargs += 1; 185 args[nargs++] = argv[i]; // pass argument along 203 186 } else { 204 187 lang = arg.substr( 2 ); … … 207 190 } else if ( prefix( arg, "-std=" ) || prefix( arg, "--std=" ) ) { 208 191 std_flag = true; // -std=XX provided 209 args[nargs] = argv[i]; // pass the argument along 210 nargs += 1; 192 args[nargs++] = argv[i]; // pass argument along 211 193 } else if ( arg == "-w" ) { 212 args[nargs] = argv[i]; // pass the argument along 213 nargs += 1; 214 args[nargs] = ( *new string( string("-D__CFA_FLAG__=") + arg ) ).c_str(); // add the argument for cfa-cpp 215 nargs += 1; 194 args[nargs++] = argv[i]; // pass argument along 195 Putenv( argv, arg ); 216 196 } else if ( prefix( arg, "-W" ) ) { // check before next tests 217 197 if ( arg == "-Werror" || arg == "-Wall" ) { 218 args[nargs] = argv[i]; // pass the argument along 219 nargs += 1; 220 args[nargs] = ( *new string( string("-D__CFA_FLAG__=") + arg ) ).c_str(); // add the argument for cfa-cpp 221 nargs += 1; 198 args[nargs++] = argv[i]; // pass argument along 199 Putenv( argv, argv[i] ); 222 200 } else { 223 201 unsigned int adv = prefix( arg, "-Wno-" ) ? 5 : 2; 224 args[nargs] = argv[i]; // conditionally pass theargument along225 const char * warning = argv[i] + adv; 202 args[nargs] = argv[i]; // conditionally pass argument along 203 const char * warning = argv[i] + adv; // extract warning 226 204 if ( SemanticWarning_Exist( warning ) ) { // replace the argument for cfa-cpp 227 args[nargs] = ( *new string( string("-D__CFA_FLAG__=") + arg ) ).c_str();205 Putenv( argv, arg ); 228 206 } // if 229 207 nargs += 1; … … 231 209 } else if ( prefix( arg, "-B" ) ) { 232 210 Bprefix = arg.substr(2); // strip the -B flag 233 args[nargs] = ( *new string( string("-D__GCC_BPREFIX__=") + Bprefix ) ).c_str(); 234 nargs += 1; 235 } else if ( prefix( arg, "-b" ) ) { 236 if ( arg.length() == 2 ) { // separate argument ? 237 i += 1; 238 if ( i == argc ) continue; // next argument available ? 239 arg += argv[i]; // concatenate argument 240 } // if 241 // later versions of gcc require the -b option to appear at the start of the command line 242 shuffle( args, sargs, nargs, 1 ); // make room at front of argument list 243 args[sargs] = ( *new string( arg ) ).c_str(); // pass the argument along 244 if ( putenv( (char *)( *new string( string( "__GCC_MACHINE__=" ) + arg ) ).c_str() ) != 0 ) { 245 cerr << argv[0] << " error, cannot set environment variable." << endl; 246 exit( EXIT_FAILURE ); 247 } // if 248 sargs += 1; 249 nargs += 1; 250 } else if ( prefix( arg, "-V" ) ) { 251 if ( arg.length() == 2 ) { // separate argument ? 252 i += 1; 253 if ( i == argc ) continue; // next argument available ? 254 arg += argv[i]; // concatenate argument 255 } // if 256 // later versions of gcc require the -V option to appear at the start of the command line 257 shuffle( args, sargs, nargs, 1 ); // make room at front of argument list 258 args[sargs] = ( *new string( arg ) ).c_str(); // pass the argument along 259 if ( putenv( (char *)( *new string( string( "__GCC_VERSION__=" ) + arg ) ).c_str() ) != 0 ) { 260 cerr << argv[0] << " error, cannot set environment variable." << endl; 261 exit( EXIT_FAILURE ); 262 } // if 263 sargs += 1; 264 nargs += 1; 211 args[nargs++] = ( *new string( string("-D__GCC_BPREFIX__=") + Bprefix ) ).c_str(); 265 212 } else if ( arg == "-c" || arg == "-S" || arg == "-E" || arg == "-M" || arg == "-MM" ) { 266 args[nargs] = argv[i]; // pass the argument along 267 nargs += 1; 213 args[nargs++] = argv[i]; // pass argument along 268 214 if ( arg == "-E" || arg == "-M" || arg == "-MM" ) { 269 215 cpp_flag = true; // cpp only … … 272 218 } else if ( arg[1] == 'l' ) { 273 219 // if the user specifies a library, load it after user code 274 libs[nlibs] = argv[i]; 275 nlibs += 1; 220 libs[nlibs++] = argv[i]; 276 221 } else if ( arg == "-m32" ) { 277 222 m32 = true; 278 223 m64 = false; 279 args[nargs] = argv[i]; 280 nargs += 1; 224 args[nargs++] = argv[i]; 281 225 } else if ( arg == "-m64" ) { 282 226 m64 = true; 283 227 m32 = false; 284 args[nargs] = argv[i]; 285 nargs += 1; 228 args[nargs++] = argv[i]; 286 229 } else { 287 230 // concatenate any other arguments 288 args[nargs] = argv[i]; 289 nargs += 1; 231 args[nargs++] = argv[i]; 290 232 } // if 291 233 } else { 292 234 bool cfa = suffix( arg ); // check suffix 293 235 if ( ! x_flag && cfa ) { // no explicit suffix and cfa suffix ? 294 args[nargs] = "-x"; 295 nargs += 1; 296 args[nargs] = "c"; 297 nargs += 1; 236 args[nargs++] = "-x"; 237 args[nargs++] = "c"; 298 238 } // if 299 args[nargs] = argv[i]; // concatenate file 300 nargs += 1; 239 args[nargs++] = argv[i]; // concatenate files 301 240 if ( ! x_flag && cfa ) { // no explicit suffix and cfa suffix ? 302 args[nargs] = "-x"; 303 nargs += 1; 304 args[nargs] = "none"; 305 nargs += 1; 241 args[nargs++] = "-x"; 242 args[nargs++] = "none"; 306 243 } // if 307 244 nonoptarg = true; … … 310 247 311 248 #ifdef __x86_64__ 312 args[nargs] = "-mcx16"; // allow double-wide CAA 313 nargs += 1; 249 args[nargs++] = "-mcx16"; // allow double-wide CAA 314 250 #endif // __x86_64__ 315 251 … … 322 258 #endif // __DEBUG_H__ 323 259 324 if ( cpp_flag && CFA_flag ) {325 cerr << argv[0] << " error, cannot use -E and -CFA flags together." << endl;326 exit( EXIT_FAILURE );327 } // if260 // if ( cpp_flag && CFA_flag ) { 261 // cerr << argv[0] << " error, cannot use -E and -CFA flags together." << endl; 262 // exit( EXIT_FAILURE ); 263 // } // if 328 264 329 265 // add the CFA include-library paths, which allow direct access to header files without directory qualification 330 if( !intree ) { 331 args[nargs] = "-I" CFA_INCDIR; 332 nargs += 1; 266 if ( ! intree ) { 267 args[nargs++] = "-I" CFA_INCDIR; 333 268 if ( ! noincstd_flag ) { // do not use during build 334 args[nargs] = "-I" CFA_INCDIR "stdhdr"; 335 nargs += 1; 269 args[nargs++] = "-I" CFA_INCDIR "stdhdr"; 336 270 } // if 337 args[nargs] = "-I" CFA_INCDIR "concurrency"; 338 nargs += 1; 339 args[nargs] = "-I" CFA_INCDIR "containers"; 340 nargs += 1; 341 } else { 342 args[nargs] = "-I" TOP_SRCDIR "libcfa/src"; 343 nargs += 1; 271 args[nargs++] = "-I" CFA_INCDIR "concurrency"; 272 args[nargs++] = "-I" CFA_INCDIR "containers"; 273 } else { 274 args[nargs++] = "-I" TOP_SRCDIR "libcfa/src"; 344 275 if ( ! noincstd_flag ) { // do not use during build 345 args[nargs] = "-I" TOP_SRCDIR "libcfa/src" "/stdhdr"; 346 nargs += 1; 276 args[nargs++] = "-I" TOP_SRCDIR "libcfa/src" "/stdhdr"; 347 277 } // if 348 args[nargs] = "-I" TOP_SRCDIR "libcfa/src" "/concurrency"; 349 nargs += 1; 350 args[nargs] = "-I" TOP_SRCDIR "libcfa/src" "/containers"; 351 nargs += 1; 352 } 278 args[nargs++] = "-I" TOP_SRCDIR "libcfa/src" "/concurrency"; 279 args[nargs++] = "-I" TOP_SRCDIR "libcfa/src" "/containers"; 280 } // if 353 281 354 282 // add stdbool to get defines for bool/true/false 355 args[nargs] = "-imacros"; 356 nargs += 1; 357 args[nargs] = "stdbool.h"; 358 nargs += 1; 283 args[nargs++] = "-imacros"; 284 args[nargs++] = "stdbool.h"; 359 285 360 286 string libbase; 361 if ( !intree ) {287 if ( ! intree ) { 362 288 libbase = CFA_LIBDIR; 363 289 } else { 364 290 libbase = TOP_BUILDDIR "libcfa/"; 365 args[nargs] = "-D__CFA_FLAG__=-t"; 366 nargs += 1; 367 } 291 Putenv( argv, "-t" ); 292 } // if 368 293 369 294 string arch = m32 ? CFA_32_CPU : (m64 ? CFA_64_CPU : CFA_DEFAULT_CPU); 370 295 if ( ! m32 && ! m64 ) { 371 296 if ( arch == "x86" ) { 372 args[nargs] = "-m32"; 373 nargs += 1; 297 args[nargs++] = "-m32"; 374 298 } else if ( arch == "x64" ) { 375 args[nargs] = "-m64"; 376 nargs += 1; 299 args[nargs++] = "-m64"; 377 300 } // if 378 301 } // if 379 const char * config = nolib ? "nolib" : (debug ? "debug": "nodebug"); 380 string libdir = libbase + arch + "-" + config; 381 382 if ( ! nolib && ! dirExists( libdir ) ) { 383 cerr << argv[0] << " internal error, configuration " << config << " not installed." << endl; 384 cerr << "Was looking for " << libdir << endl; 385 libdir = libbase + arch + "-" + "nolib"; 386 } // if 387 302 303 string libdir = libbase + arch + "-" + (nolib ? "nolib" : (debug ? "debug": "nodebug")); 388 304 if ( ! dirExists( libdir ) ) { 389 cerr << argv[0] << " internal error, cannot find prelude directory." << endl; 390 cerr << "Was looking for " << libdir << endl; 305 cerr << argv[0] << " internal error, cannot find prelude directory " << libdir << endl; 391 306 exit( EXIT_FAILURE ); 392 307 } // if 393 308 394 args[nargs] = ( *new string( string("-D__CFA_FLAG__=--prelude-dir=" ) + libdir + (intree ? "/prelude" : "")) ).c_str();395 nargs += 1;396 397 309 for ( int i = 0; i < nlibs; i += 1 ) { // copy non-user libraries after all user libraries 398 args[nargs] = libs[i]; 399 nargs += 1; 310 args[nargs++] = libs[i]; 400 311 } // for 401 312 402 313 if ( link ) { 403 args[nargs] = "-Xlinker"; 404 nargs += 1; 405 args[nargs] = "--undefined=__cfaabi_dbg_bits_write"; 406 nargs += 1; 407 args[nargs] = "-Xlinker"; 408 nargs += 1; 409 args[nargs] = "--undefined=__cfaabi_interpose_startup"; 410 nargs += 1; 411 args[nargs] = "-Xlinker"; 412 nargs += 1; 413 args[nargs] = "--undefined=__cfaabi_appready_startup"; 414 nargs += 1; 314 args[nargs++] = "-Xlinker"; 315 args[nargs++] = "--undefined=__cfaabi_dbg_bits_write"; 316 args[nargs++] = "-Xlinker"; 317 args[nargs++] = "--undefined=__cfaabi_interpose_startup"; 318 args[nargs++] = "-Xlinker"; 319 args[nargs++] = "--undefined=__cfaabi_appready_startup"; 415 320 416 321 // include the cfa library in case it's needed 417 args[nargs] = ( *new string( string("-L" ) + libdir + (intree ? "/src/.libs" : "")) ).c_str(); 418 nargs += 1; 419 args[nargs] = ( *new string( string("-Wl,-rpath," ) + libdir + (intree ? "/src/.libs" : "")) ).c_str(); 420 nargs += 1; 421 args[nargs] = "-Wl,--push-state,--as-needed"; 422 nargs += 1; 423 args[nargs] = "-lcfathread"; 424 nargs += 1; 425 args[nargs] = "-Wl,--pop-state"; 426 nargs += 1; 427 args[nargs] = "-lcfa"; 428 nargs += 1; 429 args[nargs] = "-lpthread"; 430 nargs += 1; 431 args[nargs] = "-ldl"; 432 nargs += 1; 433 args[nargs] = "-lrt"; 434 nargs += 1; 435 args[nargs] = "-lm"; 436 nargs += 1; 437 } // if 438 439 // Add exception flags (unconditionally) 440 args[nargs] = "-fexceptions"; 441 nargs += 1; 442 443 // add the correct set of flags based on the type of compile this is 444 445 args[nargs] = ( *new string( string("-D__CFA_MAJOR__=") + Major ) ).c_str(); 446 nargs += 1; 447 args[nargs] = ( *new string( string("-D__CFA_MINOR__=") + Minor ) ).c_str(); 448 nargs += 1; 449 args[nargs] = ( *new string( string("-D__CFA_PATCH__=") + Patch ) ).c_str(); 450 nargs += 1; 451 args[nargs] = "-D__CFA__"; 452 nargs += 1; 453 args[nargs] = "-D__CFORALL__"; 454 nargs += 1; 455 args[nargs] = "-D__cforall"; 456 nargs += 1; 322 args[nargs++] = ( *new string( string("-L" ) + libdir + (intree ? "/src/.libs" : "")) ).c_str(); 323 args[nargs++] = ( *new string( string("-Wl,-rpath," ) + libdir + (intree ? "/src/.libs" : "")) ).c_str(); 324 args[nargs++] = "-Wl,--push-state,--as-needed"; 325 args[nargs++] = "-lcfathread"; 326 args[nargs++] = "-Wl,--pop-state"; 327 args[nargs++] = "-lcfa"; 328 args[nargs++] = "-lpthread"; 329 args[nargs++] = "-ldl"; 330 args[nargs++] = "-lrt"; 331 args[nargs++] = "-lm"; 332 } // if 333 334 args[nargs++] = "-fexceptions"; // add exception flags (unconditionally) 335 336 // add flags based on the type of compile 337 338 args[nargs++] = ( *new string( string("-D__CFA_MAJOR__=") + Major ) ).c_str(); 339 args[nargs++] = ( *new string( string("-D__CFA_MINOR__=") + Minor ) ).c_str(); 340 args[nargs++] = ( *new string( string("-D__CFA_PATCH__=") + Patch ) ).c_str(); 341 args[nargs++] = "-D__CFA__"; 342 args[nargs++] = "-D__CFORALL__"; 343 args[nargs++] = "-D__cforall"; 457 344 458 345 if ( cpp_flag ) { 459 args[nargs] = "-D__CPP__"; 460 nargs += 1; 461 } // if 462 463 shuffle( args, sargs, nargs, 1 ); // make room at front of argument list 464 nargs += 1; 346 args[nargs++] = "-D__CPP__"; 347 } // if 348 465 349 if ( CFA_flag ) { 466 args[sargs] = "-D__CFA_FLAG__=-N"; 467 args[nargs] = "-D__CFA_PREPROCESS_"; 468 nargs += 1; 469 } else { 470 args[sargs] = "-D__CFA_FLAG__=-L"; 471 } // if 472 sargs += 1; 350 Putenv( argv, "-N" ); 351 Putenv( argv, "-CFA" ); 352 if ( o_file ) Putenv( argv, string( "-o=" ) + argv[o_file] ); 353 } else { 354 Putenv( argv, "-L" ); 355 } // if 356 357 Putenv( argv, "--prelude-dir=" + libdir + (intree ? "/prelude" : "") ); 473 358 474 359 if ( debug ) { 475 360 heading += " (debug)"; 476 args[nargs] = "-D__CFA_DEBUG__"; 477 nargs += 1; 361 args[nargs++] = "-D__CFA_DEBUG__"; 478 362 } else { 479 363 heading += " (no debug)"; … … 483 367 Bprefix = ! intree ? installlibdir : srcdriverdir; 484 368 if ( Bprefix[Bprefix.length() - 1] != '/' ) Bprefix += '/'; 485 args[nargs] = ( *new string( string("-D__GCC_BPREFIX__=") + Bprefix ) ).c_str(); 486 nargs += 1; 487 } // if 488 489 args[nargs] = "-Xlinker"; // used by backtrace 490 nargs += 1; 491 args[nargs] = "-export-dynamic"; 492 nargs += 1; 369 args[nargs++] = ( *new string( string("-D__GCC_BPREFIX__=") + Bprefix ) ).c_str(); 370 } // if 371 372 args[nargs++] = "-Xlinker"; // used by backtrace 373 args[nargs++] = "-export-dynamic"; 493 374 494 375 // execute the compilation command … … 504 385 505 386 if ( prefix( compiler_name, "gcc" ) ) { // allow suffix on gcc name 506 args[nargs] = "-no-integrated-cpp"; 507 nargs += 1; 508 args[nargs] = "-Wno-deprecated"; 509 nargs += 1; 510 #ifdef HAVE_CAST_FUNCTION_TYPE 511 args[nargs] = "-Wno-cast-function-type"; 512 nargs += 1; 513 #endif // HAVE_CAST_FUNCTION_TYPE 387 args[nargs++] = "-no-integrated-cpp"; 388 args[nargs++] = "-Wno-deprecated"; 389 #ifdef HAVE_CAST_FUNCTION_TYPE 390 args[nargs++] = "-Wno-cast-function-type"; 391 #endif // HAVE_CAST_FUNCTION_TYPE 514 392 if ( ! std_flag ) { // default c11, if none specified 515 args[nargs] = "-std=gnu11"; 516 nargs += 1; 393 args[nargs++] = "-std=gnu11"; 517 394 } // if 518 args[nargs] = "-fgnu89-inline"; 519 nargs += 1; 520 args[nargs] = "-D__int8_t_defined"; // prevent gcc type-size attributes 521 nargs += 1; 522 args[nargs] = ( *new string( string("-B") + Bprefix ) ).c_str(); 523 nargs += 1; 395 args[nargs++] = "-fgnu89-inline"; 396 args[nargs++] = "-D__int8_t_defined"; // prevent gcc type-size attributes 397 args[nargs++] = ( *new string( string("-B") + Bprefix ) ).c_str(); 524 398 } else { 525 399 cerr << argv[0] << " error, compiler \"" << compiler_name << "\" unsupported." << endl; … … 527 401 } // if 528 402 529 args[nargs] = NULL; // terminate with NULL403 args[nargs] = NULL; // terminate 530 404 531 405 #ifdef __DEBUG_H__ … … 568 442 569 443 execvp( args[0], (char *const *)args ); // should not return 570 perror( "CFA Translator error: cfa level,execvp" );444 perror( "CFA Translator error: execvp" ); 571 445 exit( EXIT_FAILURE ); 572 446 } // main
Note: See TracChangeset
for help on using the changeset viewer.