我在新程序中使用getopt_long
函数。当传递有效的多头期权时,它运行良好。但是如果我尝试使用无效选项调用程序,即 --unknown
,执行停止,表示发生了分段错误。完整命令是program version --unknown
。
我需要在哪里更改代码以使我的程序再次工作?(注意:传递无效的短选项时没问题(
这适用于命令行程序。它需要接收子命令作为其第一个参数和特定于每个子命令的选项。我想添加对长选项的支持,因为使用短选项真的很困难。
char* subcommand = /* ... */;
int option_char = 0;
int exit_code = 0;
/* ... */
// Note: argv should be an array of strings containing the command-line arguments
int pm_parse_arguments(int argc, char** argv) {
opterr = 0;
if(strcmp(subcommand, "version") == 0) {
return pm_parse_version_arguments(argc, argv);
} else {
// No recognized subcommand
pm_global_unrecognized_subcommand(subcommand);
}
return exit_code;
}
int pm_parse_version_arguments(int argc, char** argv) {
// List of long options
struct option long_options[] = {
{"help", no_argument, 0, 'h'},
{"major", no_argument, 0, 'm'},
{"minor", no_argument, 0, 0},
{"revision", no_argument, 0, 'r'},
};
// Index of option
int option_index = 0;
while((option_char = getopt_long(argc, argv, ":hmr", long_options, &option_index)) != -1) {
switch(option_char) {
/* ... */
}
return exit_code;
}
在传递长选项时,它应该打印Unrecognized option: --unknown
--unknown
就像短选项一样。相反,将返回分段错误。
这是瓦尔格林德在详细模式下的完整输出日志。
>getopt_long
要求长选项数组以零选项结构终止(类似于字符串以 null 结尾的方式(。否则,它不会知道有多少。