X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=zilasm%2Fmain.c;h=558130c60c868248b39b249858ace05dc11b4fad;hb=674e1038aa0b6b437a2216cf2360896da8dfa473;hp=a6bfa68feeecca39c8f8cac8d89daa91ac61ba66;hpb=96b70de7e75c4a903ee686385a101894403c99b0;p=zilutils.git diff --git a/zilasm/main.c b/zilasm/main.c index a6bfa68..558130c 100644 --- a/zilasm/main.c +++ b/zilasm/main.c @@ -20,6 +20,7 @@ #include #include +#include #include #include #include @@ -33,11 +34,11 @@ static struct option const long_options[] = { { "help", no_argument, NULL, 'h' }, { "version", no_argument, NULL, 'V' }, + { "output", required_argument, NULL, 'o' }, { "zversion", required_argument, NULL, ZVERSION }, { "zorkid", required_argument, NULL, ZORKID }, { "serial", required_argument, NULL, ZSERIAL }, { NULL, 0, NULL, 0 } - }; struct @@ -47,8 +48,15 @@ struct char zserial[7]; /* YYMMDD */ } Config; -void wrong_arg() +void wrong_arg(const char *err, ...) { + if (err) + { + va_list ap; + va_start(ap, err); + vfprintf(stderr, err, ap); + va_end(ap); + } fprintf(stderr, "Try `" PACKAGE_NAME " --help' for more information.\n"); exit(1); } @@ -108,9 +116,8 @@ void parse_intarg(int *dest, const char name[], int min, int max, int defval) *dest = n; return; } - fprintf(stderr, "Wrong %s value %s, must be integer between %d and %d\n", - name, optarg, min, max); - wrong_arg(); + wrong_arg("Wrong %s value %s, must be integer between %d and %d\n", + name, optarg, min, max); } void parse_zserial(void) @@ -132,16 +139,17 @@ void parse_zserial(void) return; } } - fprintf(stderr, "Wrong zserial value %s, must be 6 ascii characters\n", optarg); - wrong_arg(); + wrong_arg("Wrong zserial value %s, must be 6 ascii characters\n", optarg); } int main(int argc, char *argv[], char *envp[]) { + const char *output_file = NULL; + fill_config(); int opt = 0; - while ((opt = getopt_long (argc, argv, "hV", long_options, NULL)) != -1) + while ((opt = getopt_long (argc, argv, "hVo:", long_options, NULL)) != -1) { switch(opt) { @@ -149,6 +157,10 @@ int main(int argc, char *argv[], char *envp[]) print_usage(0); case 'V' : print_version(); + case 'o' : + if (output_file) wrong_arg("Output file must be given once\n"); + output_file = argv[optind]; + break; case ZVERSION: parse_intarg(&Config.zversion, "zversion", 1, 8, 1); break; @@ -159,12 +171,14 @@ int main(int argc, char *argv[], char *envp[]) parse_zserial(); break; default : - wrong_arg(); + wrong_arg(0); } } // TODO: Everything :) + printf("Output file: %s\n\n", output_file ? output_file : "MISSING"); + printf("Config:\n" "- ZVersion: %d\n" "- ZorkID: %d\n"