C Getopts:管理所有收到的选项和可选的optargs

时间:2018-09-24 19:34:23

标签: c bit-manipulation getopt

我正在编写一个程序,该程序最多可以包含3个选项,同时也可以将它们组合在一起。该部分如下所示:

char flag = 0; // to mark which options were set
int aopt = INT_MAX; // default to INT_MAX if no args delivered
char bemerkung[100];
memset(bemerkung, '\0', 100); // string to receive via '-b'

char option;

while((option = getopt (argc, argv, "m:a:b:")) != EOF){
    switch( option ){
        case 'm': {
            flag = flag | 1;
            break;
        } 
        case 'a': {
            flag = flag | 2;
            char * arg = optarg;
            aopt = atoi(arg);
            if(aopt == 0 && strcmp("0", arg) != 0) // if no valid optarg was entered
                aopt = INT_MAX; // get back the default value
            break;
        }
        case 'b': {
            flag = flag | 4;
            strcpy(bemerkung, optarg);
            break;
        }
        default: {
            fprintf(stderr, "Unknown option entered.\n");
            return -1;
        }
    }
}

// some code here, not touching `flag`

if(flag == 1){
    // deal with `-m`, no optargs
}
if(flag == 2){
    // `-a aopt` called
}
if(flag == 3){
    // `-m -a aopt` called
}

基本思想是设置flag中的位,以便我以后可以处理选项及其组合。但是我现在面临的麻烦是-m需要参数(仅对于-m是可选的),并且./main -m -a 0的结果将变成flag = 1而不是flag = 3。 / p>

我如何使-m的参数成为可选参数,并使OR正确完成flag

1 个答案:

答案 0 :(得分:1)

如果您希望-m不接受任何参数,请在选项字符串中省略其后的::意味着前面的选项需要一个参数:

while((option = getopt (argc, argv, "ma:b:")) != EOF){