X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fgmqcc.git;a=blobdiff_plain;f=main.c;h=33bde557176bf0d3a5c6ab9a4077551334f37606;hp=1718e32972ec7e4e90c0be79bdb03fe3f5a91652;hb=64661f54ea4b13657301a975db10aeff6245610f;hpb=5e54db46c44d9517b73d479b583c6d31972ab1aa diff --git a/main.c b/main.c index 1718e32..33bde55 100644 --- a/main.c +++ b/main.c @@ -165,6 +165,9 @@ static bool options_parse(int argc, char **argv) { opts_set(opts.flags, ADJUST_VECTOR_FIELDS, true); opts_set(opts.flags, CORRECT_LOGIC, true); + opts_set(opts.flags, SHORT_LOGIC, true); + opts_set(opts.flags, UNTYPED_NIL, true); + opts_set(opts.flags, VARIADIC_ARGS, true); opts_set(opts.flags, FALSE_EMPTY_STRINGS, false); opts_set(opts.flags, TRUE_EMPTY_STRINGS, true); opts_set(opts.flags, LOOP_LABELS, true); @@ -176,6 +179,7 @@ static bool options_parse(int argc, char **argv) { opts_set(opts.warn, WARN_BREAKDEF, true); + OPTS_OPTION_U32(OPTION_STANDARD) = COMPILER_GMQCC; } else if (!strcmp(argarg, "qcc")) { @@ -355,7 +359,7 @@ static bool options_parse(int argc, char **argv) { else if (!strcmp(argv[0]+2, "NO_ERROR") || !strcmp(argv[0]+2, "NO_ERROR_ALL")) { - for (itr = 0; itr < sizeof(opts.werror)/sizeof(opts.werror[0]); ++itr) + for (itr = 0; itr < GMQCC_ARRAY_COUNT(opts.werror); ++itr) opts.werror[itr] = 0; break; } @@ -363,19 +367,19 @@ static bool options_parse(int argc, char **argv) { !strcmp(argv[0]+2, "ERROR_ALL")) { opts_backup_non_Werror_all(); - for (itr = 0; itr < sizeof(opts.werror)/sizeof(opts.werror[0]); ++itr) + for (itr = 0; itr < GMQCC_ARRAY_COUNT(opts.werror); ++itr) opts.werror[itr] = 0xFFFFFFFFL; opts_restore_non_Werror_all(); break; } else if (!strcmp(argv[0]+2, "NONE")) { - for (itr = 0; itr < sizeof(opts.warn)/sizeof(opts.warn[0]); ++itr) + for (itr = 0; itr < GMQCC_ARRAY_COUNT(opts.warn); ++itr) opts.warn[itr] = 0; break; } else if (!strcmp(argv[0]+2, "ALL")) { opts_backup_non_Wall(); - for (itr = 0; itr < sizeof(opts.warn)/sizeof(opts.warn[0]); ++itr) + for (itr = 0; itr < GMQCC_ARRAY_COUNT(opts.warn); ++itr) opts.warn[itr] = 0xFFFFFFFFL; opts_restore_non_Wall(); break; @@ -426,7 +430,8 @@ static bool options_parse(int argc, char **argv) { else if (!strcmp(argarg, "ALL")) opts_setoptimlevel(OPTS_OPTION_U32(OPTION_O) = 9999); else if (!strncmp(argarg, "NO_", 3)) { - if (!opts_setoptim(argarg+3, false)) { + /* constant folding cannot be turned off for obvious reasons */ + if (!strcmp(argarg, "NO_CONST_FOLD") || !opts_setoptim(argarg+3, false)) { con_out("unknown optimization: %s\n", argarg+3); return false; } @@ -575,13 +580,13 @@ int main(int argc, char **argv) { /* the standard decides which set of operators to use */ if (OPTS_OPTION_U32(OPTION_STANDARD) == COMPILER_GMQCC) { operators = c_operators; - operator_count = c_operator_count; + operator_count = GMQCC_ARRAY_COUNT(c_operators); } else if (OPTS_OPTION_U32(OPTION_STANDARD) == COMPILER_FTEQCC) { operators = fte_operators; - operator_count = fte_operator_count; + operator_count = GMQCC_ARRAY_COUNT(fte_operators); } else { operators = qcc_operators; - operator_count = qcc_operator_count; + operator_count = GMQCC_ARRAY_COUNT(qcc_operators); } if (operators == fte_operators) { @@ -645,8 +650,6 @@ int main(int argc, char **argv) { } } - util_debug("COM", "starting ...\n"); - /* add macros */ if (OPTS_OPTION_BOOL(OPTION_PP_ONLY) || OPTS_FLAG(FTEPP)) { for (itr = 0; itr < vec_size(ppems); itr++) { @@ -767,7 +770,6 @@ int main(int argc, char **argv) { } cleanup: - util_debug("COM", "cleaning ...\n"); if (ftepp) ftepp_finish(ftepp); con_close();