如何防止 getopt 与缺少参数的选项混淆?
How to prevent getopt from being confused with option with missing argument?
说,我有代码:
while ((c = getopt(argc, argv, ":n:p")) != -1) {
switch (c) {
case 'n':
syslog(LOG_NOTICE, "n: %s", optarg);
break;
case 'p':
/* ... some code ... */
break;
case ':':
/* handle missing arguments to options requiring arguments */
break;
/* some cases like '?', ... */
default:
abort();
}
}
当我调用我的程序时
./main -n -p
它打印:
n: -p
为什么不 getopt return : 表示缺少 -n 参数而是使用 -p 作为参数参数?
拥有一个以破折号开头且通常类似于另一个选项的选项参数是完全可以的。 getopt没有理由报错
如果一个程序不想接受这样的选项参数,它应该专门检查它们,例如
if (optarg[0] == '-') {
// oops, looks like user forgot an argument
err("Option requires an argument");
}
我有一个类似的问题,我让它落入默认情况。不确定操作 optopt 变量是否是一个问题,但它似乎有效:
while ((c = getopt(argc, argv, "a:d:x")) != -1)
{
switch (c)
{
case 'a':
if (optarg[0] == '-' && err == 0)
{
err = 1;
optopt = 'a';
}
else if (err == 0)
{
aflag = 1;
aArg = optarg;
break;
}
case 'd':
if (optarg[0] == '-' && err == 0)
{
err = 1;
optopt = 'd';
}
else if (err == 0)
{
dflag = 1;
dArg = optarg;
break;
}
case 'x':
if (err == 0)
{
xflag = 1;
break;
}
default:
if (optopt == 'a' || optopt == 'd')
{
fprintf(stderr, "Option -%c requires an argument.\n", optopt);
return 1;
}
else
{
fprintf(stderr, "Unknown option '-%c'\n", optopt);
return 2;
}
}//end of switch
}//end of while
说,我有代码:
while ((c = getopt(argc, argv, ":n:p")) != -1) {
switch (c) {
case 'n':
syslog(LOG_NOTICE, "n: %s", optarg);
break;
case 'p':
/* ... some code ... */
break;
case ':':
/* handle missing arguments to options requiring arguments */
break;
/* some cases like '?', ... */
default:
abort();
}
}
当我调用我的程序时
./main -n -p
它打印:
n: -p
为什么不 getopt return : 表示缺少 -n 参数而是使用 -p 作为参数参数?
拥有一个以破折号开头且通常类似于另一个选项的选项参数是完全可以的。 getopt没有理由报错
如果一个程序不想接受这样的选项参数,它应该专门检查它们,例如
if (optarg[0] == '-') {
// oops, looks like user forgot an argument
err("Option requires an argument");
}
我有一个类似的问题,我让它落入默认情况。不确定操作 optopt 变量是否是一个问题,但它似乎有效:
while ((c = getopt(argc, argv, "a:d:x")) != -1)
{
switch (c)
{
case 'a':
if (optarg[0] == '-' && err == 0)
{
err = 1;
optopt = 'a';
}
else if (err == 0)
{
aflag = 1;
aArg = optarg;
break;
}
case 'd':
if (optarg[0] == '-' && err == 0)
{
err = 1;
optopt = 'd';
}
else if (err == 0)
{
dflag = 1;
dArg = optarg;
break;
}
case 'x':
if (err == 0)
{
xflag = 1;
break;
}
default:
if (optopt == 'a' || optopt == 'd')
{
fprintf(stderr, "Option -%c requires an argument.\n", optopt);
return 1;
}
else
{
fprintf(stderr, "Unknown option '-%c'\n", optopt);
return 2;
}
}//end of switch
}//end of while