getopt_long_only segmentation fault

Я пытаюсь использовать getopt_long_only для синтаксического анализа командной строки. Мое приложение читает несколько параметров командной строки.

Например. "app --alpha = 1 --beta = 2 --cecil = 3"

getopt_long_only работает нормально, как и ожидалось, до тех пор, пока передаются допустимые параметры командной строки. Но если вы вызываете приложение с недопустимым «одинарным пунктиром» option в конце и в других неподходящих местах, происходит сбой seg fault. Что тут происходит? Похоже, что getopt_long_only не устойчив к ошибкам в аргументах. Или я неправильно вызываю функцию?

Пример:

> ./app --beta=1 -?
starting
index = 1   ret=0  optarg=1
Segmentation fault

Код ниже (C ++: app.cc)

#include <stdio.h>
#include <getopt.h>

void ProcessCommandLineArgs(int argc, char** argv)
{

    option longopts[] = {
        {"alpha", optional_argument, 0, 0},
        {"beta",  optional_argument, 0, 0},
        {"cecil", optional_argument, 0, 0}
    };

    int index;
    int ret;
    bool fParseError = false;

    while (true)
    {
        ret = ::getopt_long_only(argc, argv, "", longopts, &index);

        if (ret < 0)
        {
            break;
        }

        if ((ret == '?') || (ret == ':'))
        {
            fParseError = true;
            break;
        }

        printf("index = %d   ret=%d  optarg=%s\n", index, ret, optarg?optarg:"<null>");
    }
}

int main(int argc, char** argv)
{
    printf("starting\n");
    ProcessCommandLineArgs(argc, argv);
    printf("exiting\n");
    return 0;
}
13
задан selbie 18 July 2011 в 04:40
поделиться