From 25e49a669dde9736e36a03fe7cea1a4f2287fb11 Mon Sep 17 00:00:00 2001 From: Wolfgang Bumiller Date: Sat, 28 Jul 2012 19:09:44 +0200 Subject: [PATCH] flags.def and warns.def containing defined flags and warnings --- flags.def | 7 +++++++ gmqcc.h | 35 ++++++++++++++++--------------- main.c | 63 +++++++++++++++++++++++++++++++++++++++++++------------ warns.def | 5 +++++ 4 files changed, 80 insertions(+), 30 deletions(-) create mode 100644 flags.def create mode 100644 warns.def diff --git a/flags.def b/flags.def new file mode 100644 index 0000000..a7387d1 --- /dev/null +++ b/flags.def @@ -0,0 +1,7 @@ +#ifndef GMQCC_DEFINE_FLAG +#define GMQCC_DEFINE_FLAG(x) +#endif + +GMQCC_DEFINE_FLAG(OVERLAP_LOCALS) +GMQCC_DEFINE_FLAG(DARKPLACES_STRING_TABLE_BUG) +GMQCC_DEFINE_FLAG(OMIT_NULL_BYTES) diff --git a/gmqcc.h b/gmqcc.h index 5324a72..c52db8a 100644 --- a/gmqcc.h +++ b/gmqcc.h @@ -987,29 +987,30 @@ typedef struct { /*===================================================================*/ /* list of -f flags, like -fdarkplaces-string-table-bug */ enum { - OVERLAP_LOCALS, - DP_STRING_TABLE_BUG, - OMIT_NULLBYTES, - - NUM_F_FLAGS +# define GMQCC_DEFINE_FLAG(X) X, +# include "flags.def" +# undef GMQCC_DEFINE_FLAG + COUNT_FLAGS }; static const opt_flag_def opt_flag_list[] = { - { "overlap-locals", LONGBIT(OVERLAP_LOCALS) }, - { "darkplaces-string-table-bug", LONGBIT(DP_STRING_TABLE_BUG) }, - { "omit-nullbytes", LONGBIT(OMIT_NULLBYTES) } +# define GMQCC_DEFINE_FLAG(X) { #X, LONGBIT(X) }, +# include "flags.def" +# undef GMQCC_DEFINE_FLAG + { NULL, LONGBIT(0) } }; -static const size_t opt_flag_list_count = sizeof(opt_flag_list) / sizeof(opt_flag_list[0]); enum { - WARN_UNUSED_VARIABLE, - - NUM_W_FLAGS +# define GMQCC_DEFINE_FLAG(X) X, +# include "warns.def" +# undef GMQCC_DEFINE_FLAG + COUNT_WARNINGS }; static const opt_flag_def opt_warn_list[] = { - /* only contains single flags, no groups like 'all' */ - { "unused-variable", LONGBIT(WARN_UNUSED_VARIABLE) } +# define GMQCC_DEFINE_FLAG(X) { #X, LONGBIT(X) }, +# include "warns.def" +# undef GMQCC_DEFINE_FLAG + { NULL, LONGBIT(0) } }; -static const size_t opt_warn_list_count = sizeof(opt_warn_list) / sizeof(opt_warn_list[0]); /* other options: */ extern uint32_t opt_O; /* -Ox */ @@ -1024,8 +1025,8 @@ enum { /*===================================================================*/ #define OPT_FLAG(i) (!! (opt_flags[(i)/32] & (1<< ((i)%32)))) -extern uint32_t opt_flags[1 + (NUM_F_FLAGS / 32)]; +extern uint32_t opt_flags[1 + (COUNT_FLAGS / 32)]; #define OPT_WARN(i) (!! (opt_warn[(i)/32] & (1<< ((i)%32)))) -extern uint32_t opt_warn[1 + (NUM_W_FLAGS / 32)]; +extern uint32_t opt_warn[1 + (COUNT_WARNINGS / 32)]; #endif diff --git a/main.c b/main.c index 2749275..cf78b1e 100644 --- a/main.c +++ b/main.c @@ -22,8 +22,8 @@ */ #include "gmqcc.h" -uint32_t opt_flags[1 + (NUM_F_FLAGS / 32)]; -uint32_t opt_warn [1 + (NUM_W_FLAGS / 32)]; +uint32_t opt_flags[1 + (COUNT_FLAGS / 32)]; +uint32_t opt_warn [1 + (COUNT_WARNINGS / 32)]; uint32_t opt_O = 1; const char *opt_output = "progs.dat"; @@ -64,6 +64,36 @@ static int usage() { return -1; } +static void strtocmd(char *str) +{ + for(; *str; ++str) { + if (*str == '-') { + *str = '_'; + continue; + } + if (isalpha(*str) && !isupper(*str)) { + *str += 'A' - 'a'; + continue; + } + } +} + +static void strtononcmd(char *buf, const char *str) +{ + for(; *str; ++buf, ++str) { + if (*str == '_') { + *buf = '-'; + continue; + } + if (isalpha(*str) && isupper(*str)) { + *buf = *str + 'a' - 'A'; + continue; + } + *buf = *str; + } + *buf = 0; +} + static bool options_setflag_all(const char *name, bool on, uint32_t *flags, const opt_flag_def *list, size_t listsize) { size_t i; @@ -87,10 +117,10 @@ static bool options_setflag_all(const char *name, bool on, uint32_t *flags, cons return false; } static bool options_setflag(const char *name, bool on) { - return options_setflag_all(name, on, opt_flags, opt_flag_list, opt_flag_list_count); + return options_setflag_all(name, on, opt_flags, opt_flag_list, COUNT_FLAGS); } static bool options_setwarn(const char *name, bool on) { - return options_setflag_all(name, on, opt_warn, opt_warn_list, opt_warn_list_count); + return options_setflag_all(name, on, opt_warn, opt_warn_list, COUNT_WARNINGS); } static bool options_witharg(int *argc_, char ***argv_, char **out) { @@ -146,6 +176,7 @@ static bool options_long_gcc(const char *optname, int *argc_, char ***argv_, cha static bool options_parse(int argc, char **argv) { bool argend = false; size_t itr; + char buffer[1024]; while (!argend && argc > 1) { char *argarg; argitem item; @@ -178,13 +209,16 @@ static bool options_parse(int argc, char **argv) { /* handle all -fflags */ case 'f': - if (!strcmp(argv[0]+2, "help")) { + strtocmd(argv[0]+2); + if (!strcmp(argv[0]+2, "HELP")) { printf("Possible flags:\n"); - for (itr = 0; itr < opt_flag_list_count; ++itr) - printf(" -f%s\n", opt_flag_list[itr].name); + for (itr = 0; itr < COUNT_FLAGS; ++itr) { + strtononcmd(buffer, opt_flag_list[itr].name); + printf(" -f%s\n", buffer); + } exit(0); } - else if (!strncmp(argv[0]+2, "no-", 3)) { + else if (!strncmp(argv[0]+2, "NO-", 3)) { if (!options_setflag(argv[0]+5, false)) { printf("unknown flag: %s\n", argv[0]+2); return false; @@ -196,10 +230,13 @@ static bool options_parse(int argc, char **argv) { } break; case 'W': - if (!strcmp(argv[0]+2, "help")) { + strtocmd(argv[0]+2); + if (!strcmp(argv[0]+2, "HELP")) { printf("Possible warnings:\n"); - for (itr = 0; itr < opt_warn_list_count; ++itr) - printf(" -W%s\n", opt_warn_list[itr].name); + for (itr = 0; itr < COUNT_WARNINGS; ++itr) { + strtononcmd(buffer, opt_warn_list[itr].name); + printf(" -W%s\n", buffer); + } exit(0); } else if (!strcmp(argv[0]+2, "all")) { @@ -295,10 +332,10 @@ int main(int argc, char **argv) { return usage(); } - for (itr = 0; itr < opt_flag_list_count; ++itr) { + for (itr = 0; itr < COUNT_FLAGS; ++itr) { printf("Flag %s = %i\n", opt_flag_list[itr].name, OPT_FLAG(itr)); } - for (itr = 0; itr < opt_warn_list_count; ++itr) { + for (itr = 0; itr < COUNT_WARNINGS; ++itr) { printf("Warning %s = %i\n", opt_warn_list[itr].name, OPT_WARN(itr)); } printf("output = %s\n", opt_output); diff --git a/warns.def b/warns.def new file mode 100644 index 0000000..6238e50 --- /dev/null +++ b/warns.def @@ -0,0 +1,5 @@ +#ifndef GMQCC_DEFINE_FLAG +#define GMQCC_DEFINE_FLAG(x) +#endif + +GMQCC_DEFINE_FLAG(UNUSED_VARIABLE) -- 2.39.5