use getopt(3) instead of our hand-rolled flag parsing

Simplify and standardize the code by using the standard getopt()
function for parsing command-line flags.

This is a backwards-incompatible change.
This commit is contained in:
anthony
2010-01-12 14:25:54 -07:00
parent 8f5e767615
commit 16c7a49ffa

View File

@@ -224,6 +224,9 @@ MBC_String(unsigned char mbc_type)
int
main(int argc, char *argv[])
{
int ch;
char *ep;
int argn = 1;
char filename[512];
char cartname[32];
@@ -239,56 +242,37 @@ main(int argc, char *argv[])
if (argc == 1)
PrintUsage();
while (argn < argc) {
if (argv[argn][0] == '-') {
switch (argv[argn][1]) {
case '?':
case 'h':
PrintUsage();
break;
while ((ch = getopt(argc, argv, "b:cdjk:m:op:qrst:v")) != -1) {
switch (ch) {
case 'd':
ulOptions |= OPTF_DEBUG;
break;
case 'm':
ulOptions |= OPTF_RAMSIZE;
if (strlen(argv[argn] + 2) > 0 && strlen(argv[argn] + 2) <= 2) {
int result;
result = sscanf(argv[argn] + 2,"%x", &ram_size);
if (!((result == EOF) || (result == 1))) {
ram_size = strtoul(optarg, &ep, 0);
if (optarg[0] == '\0' || *ep != '\0')
FatalError("Invalid argument for option 'm'");
}
} else if (strlen(argv[argn] + 2) > 0) {
FatalError("RAM size must be between 0 and FF");
} else {
FatalError("Invalid argument for option 'm'");
}
if (ram_size < 0 || ram_size > 0xFF)
FatalError("Argument for option 'm' must be between 0 and 0xFF");
break;
case 'j':
ulOptions |= OPTF_JAPAN;
break;
case 'b':
ulOptions |= OPTF_MBCTYPE;
if (strlen(argv[argn] + 2) > 0 && strlen(argv[argn] + 2) <= 2) {
int result;
result = sscanf(argv[argn] + 2, "%x", &mbc_type);
if (!((result == EOF) || (result == 1))) {
mbc_type = strtoul(optarg, &ep, 0);
if (optarg[0] == '\0' || *ep != '\0')
FatalError("Invalid argument for option 'b'");
}
} else if (strlen(argv[argn] + 2) > 0) {
FatalError("MBC type must be between 0 and FF");
} else {
FatalError("Invalid argument for option 'b'");
}
if (mbc_type < 0 || mbc_type > 0xFF)
FatalError("Argument for option 'b' must be between 0 and 0xFF");
break;
case 'p':
ulOptions |= OPTF_PAD;
if (strlen(argv[argn] + 2) > 0 && strlen(argv[argn] + 2) <= 2) {
int result;
result = sscanf(argv[argn] + 2, "%x", &pad_value);
if (!((result == EOF) || (result == 1))) {
pad_value = strtoul(optarg, &ep, 0);
if (optarg[0] == '\0' || *ep != '\0')
FatalError("Invalid argument for option 'p'");
}
}
if (pad_value < 0 || pad_value > 0xFF)
FatalError("Argument for option 'p' must be between 0 and 0xFF");
break;
case 'r':
ulOptions |= OPTF_TRUNCATE;
@@ -297,11 +281,11 @@ main(int argc, char *argv[])
ulOptions |= OPTF_VALIDATE;
break;
case 't':
strncpy(cartname, argv[argn] + 2, 16);
strncpy(cartname, optarg, 16);
ulOptions |= OPTF_TITLE;
break;
case 'k':
strncpy(nlicensee, argv[argn] + 2, 2);
strncpy(nlicensee, optarg, 2);
ulOptions |= OPTF_NLICENSEE;
break;
case 'q':
@@ -324,12 +308,15 @@ main(int argc, char *argv[])
case 's':
ulOptions |= OPTF_SGBMODE;
break;
default:
PrintUsage();
/* NOTREACHED */
}
}
argn++;
}
argc -= optind;
argv += optind;
if (argv[argc - 1][0] == '-')
if (argc == 0)
PrintUsage();
strcpy(filename, argv[argc - 1]);