将“getopt_long”与无法识别的长选项一起使用时出现分段错误



我在新程序中使用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 结尾的方式(。否则,它不会知道有多少。

相关内容

最新更新