Некоторые опции предполагают наличие собственных аргументов. Так, рассмотренная выше команда ls -s /
ls
о необходимости отображения размера (в килобайтах) каждого элемента каталога. Аргумент /
задает имя каталога. Опция --size
является синонимом опции -s
, поэтому та же самая команда может быть задана так: ls -- size /
.В документе
% info "(standards)User Interfaces"
2.1.3. Функция getopt_long()
Синтаксический анализ аргументов командной строки — утомительная задача. К счастью. в GNU-библиотеке языка С есть функция getopt_long()
.Предположим, требуется написать программу, которая поддерживает три опции (табл. 2.1).
Таблица 2.1. Опции тестовой программы
Короткая форма | Длинная форма | Назначение |
---|---|---|
-h | --help | Отображение справки по использованию программы и выход |
-o имя_файла | --output имя_файла | Задание имени выходного файла |
-v | --verbose | Отображение развернутых сообщений |
Кроме того, программе могут быть переданы дополнительные аргументы, задающие имена входных файлов
Функции getopt_long()
ho:v
. Это говорит о том, что программа поддерживает опции -h
, -о
и -v
, причем для второй из них требуется аргумент.Список возможных длинных опций задается в виде массива структур option
NULL
; четвертое — символьная константа, задающая короткий эквивалент данной длинной опции. Последний элемент массива должен содержать одни нули. Наш массив будет выглядеть так:const struct option long_options[] = {
{ "help", 0, NULL, 'h' },
{ "output", 1, NULL, 'o' },
{ "verbose", 0, NULL, 'v' },
{ NULL, 0, NULL, 0 }
};
Функции getopt_long()
argc
и argv
функции main()
. Ниже перечислены особенности ее работы.■ При каждом вызове функция getopt_long()
■ Обычно функция getopt_long()
switch
.■ Если опция getopt_long()
?
(знак вопроса). В ответ на это большинство программ завершает свою работу, обычно отображая справку по работе с программой.■ При обработке опции, имеющей аргумент, в глобальную переменную optarg
■ Когда функция getopt_long()
optind
записывается индекс того элемента массива argv
, в котором содержится первый аргумент, не являющийся опцией.В листинге 2.2 приведен пример обработки аргументов программы с помощью функции getopt_long()
getopt_long()
#include
#include
#include
/* Имя программы. */
const char* program_name;
/* Вывод информации об использовании программы в поток STREAM
(обычно stdout или stderr) и завершение работы с выдачей кода
EXIT_CODE. Возврат в функцию main() не происходит */
void print_usage(FILE* stream, int exit_code) {