- if(strncmp(arg, "-o", 2) == 0) {
- GET_ARG_AFTER(outname, "-o");
- } else if(strcmp(arg, "-c") == 0) {
- mode = CompileAssemble;
- } else if(strcmp(arg, "-S") == 0) {
- mode = Compile;
- } else if(strcmp(arg, "--gcc") == 0) {
- c_mode |= _GNUC;
- } else if(strcmp(arg, "--no-gcc") == 0) {
- c_mode &= ~_GNUC;
- } else if(strcmp(arg, "--ms") == 0) {
- c_mode |= _MS;
- } else if(strcmp(arg, "--signed-chars") == 0) {
- char_is_signed = true;
- } else if(strcmp(arg, "--unsigned-chars") == 0) {
- char_is_signed = false;
- } else if(strcmp(arg, "--strict") == 0) {
- strict_mode = true;
- } else if(strcmp(arg, "--no-ms") == 0) {
- c_mode &= ~_MS;
- } else if(strcmp(arg, "--lextest") == 0) {
- mode = LexTest;
- } else if(strcmp(arg, "--print-ast") == 0) {
- mode = PrintAst;
- } else if(strcmp(arg, "--print-fluffy") == 0) {
- mode = PrintFluffy;
- } else if(strcmp(arg, "--version") == 0) {
- firm_version_t ver;
- firm_get_version(&ver);
- printf("cparser (%d.%d %s) using libFirm (%u.%u", 0, 1, cparser_REVISION, ver.major, ver.minor);
- if(ver.revision[0] != 0) {
- putchar(' ');
- fputs(ver.revision, stdout);
- }
- if(ver.build[0] != 0) {
- putchar(' ');
- fputs(ver.build, stdout);
- }
- puts(")\n");
- exit(EXIT_SUCCESS);
- } else if(strcmp(arg, "-fsyntax-only") == 0) {
- mode = ParseOnly;
- } else if(strncmp(arg, "-I", 2) == 0) {
- const char *opt;
- GET_ARG_AFTER(opt, "-I");
- obstack_printf(&cppflags_obst, " -I%s", opt);
- } else if(strncmp(arg, "-D", 2) == 0) {
- const char *opt;
- GET_ARG_AFTER(opt, "-D");
- obstack_printf(&cppflags_obst, " -D%s", opt);
- } else if(strncmp(arg, "-U", 2) == 0) {
- const char *opt;
- GET_ARG_AFTER(opt, "-U");
- obstack_printf(&cppflags_obst, " -U%s", opt);
- } else if(strcmp(arg, "--dump-function") == 0) {
- ++i;
- if(i >= argc) {
- fprintf(stderr, "error: "
- "expected argument after '--dump-function'\n");
- argument_errors = true;
- break;
- }
- dumpfunction = argv[i];
- mode = CompileDump;
- } else if(strcmp(arg, "-v") == 0) {
- verbose = 1;
- } else if(arg[0] == '-' && arg[1] == 'f') {
- const char *opt;
- GET_ARG_AFTER(opt, "-f");
-
- if(strcmp(opt, "omit-frame-pointer") == 0) {
- firm_be_option("omitfp");
- } else if(strcmp(opt, "no-omit-frame-pointer") == 0) {