Чтение онлайн

на главную - закладки

Жанры

Linux программирование в примерах
Шрифт:

while ((ос = getopt(argc, argv, ":ab:")) != -1) {

 switch (oc) {

 case 'a':

/* обработка -a, установка соответствующего флага */

break;

 case 'b':

/* обработка -b, получение значения аргумента из optarg */

b_opt_arg = optarg;

break;

 case ':':

/* отсутствует аргумент опции */

fprintf(stderr, "%s: option '-%c' requires an argument\n",

argv[0], optopt);

break;

 case '?':

 default:

/*
недействительная опция */

fprintf(stderr, "%s: option '-%c' is invalid: ignored\n",

argv[0], optopt);

break;

 }

}

Замечание о соглашениях по именованию флагов или опций: в большом количестве кода для Unix используются имена в виде

xflg
для любого данного символа опции x (например,
nflg
в
echo
V7; обычным является также
xflag
). Это может быть замечательным для авторе программы, который без проверки документации знает, что означает опция x. Но это не подходит для кого-то еще, кто пытается прочесть код и не знает наизусть значений всех символов опций. Гораздо лучше использовать имена, передающие смысл опции, как
no_newline
для опции
– n
echo.

2.3.2. GNU

getopt
и порядок опций

Стандартная функция

getopt
прекращает поиск опций, как только встречает аргумент командной строки, который не начинается с GNU
getopt
отличается: она просматривает в поисках опций всю командную строку. По мере продвижения она переставляет элементы
argv
, так что после ее завершения все опции оказываются переставленными в начало, и код, продолжающий разбирать аргументы с
argv[optind]
до
argv[argc-1]
, работает правильно. Во всех случаях специальный аргумент '
– -
' завершает сканирование опций.

Вы можете изменить поведение по умолчанию, использовав в

optstring
специальный первый символ следующим образом:

optstring[0] == '+'

GNU

getopt
ведет себя, как стандартная
getopt
; она возвращает опции по мере их обнаружения, останавливаясь на первом аргументе, не являющемся опцией. Это работает также в том случае, если в окружении присутствует строка
POSIXLY_CORRECT
.

optstring[0] == '-'

GNU

getopt
возвращает каждый аргумент командной строки независимо от того, представляет он аргумент или нет. В этом случае для каждого такого аргумента функция возвращает целое 1, а указатель на соответствующую строку помещает в
optarg
.

Как и для стандартной

getopt
, если первым символом
optstring
является '
:
', GNU
getopt
различает «неверную опцию» и «отсутствующий аргумент опции», возвращая соответственно '
?
' или '
:
'. Символ '
:
' в
optstring
может быть вторым символом, если первым символом является '
+
' или '
'.

Наконец, если за символом опции в

optstring
следуют два двоеточия, эта опция может иметь необязательный аргумент. (Быстро повторите это три раза!) Такой аргумент считается присутствующим, если он находится
в том же элементе
argv
, что и сама опция, и отсутствующим в противном случае. В случае отсутствия аргумента GNU
getopt
возвращает символ опции, а в
optarg
записывает NULL. Например, пусть имеем:

while ((с = getopt(argc, argv, "ab::")) != -1)

...

для

– bYANKEES
, возвращаемое значение будет '
b
', a
optarg
указывает на «
YANKEES
», тогда как для
– b
или '
– b YANKEES
' возвращаемое значение будет все то же '
b
', но в
optarg
будет помещен NULL. В последнем случае «
YANKEES
» представляет отдельный аргумент командной строки.

2.3.3. Длинные опции

Функция

getopt_long
осуществляет разбор длинных опций в описанном ранее виде. Дополнительная процедура
getopt_long_only
работает идентичным образом, но она используется для программ, в которых все опции являются длинными и начинаются с единичного символа '
'. В остальных случаях обе функции работают точно так же, как более простая функция GNU
getopt
. (Для краткости, везде, где мы говорим «
getopt_long
», можно было бы сказать «
getopt_long
и
getopt_long_only
».) Вот объявления функций из справки getopt(3) GNU/Linux:

#include <getopt.h> /* GLIBC */

int getopt_long(int argc, char *const argv[],

 const char *optstring,

 const struct option *longopts, int *longindex);

int getopt_long_only(int argc, char *const argv[],

 const char *optstring,

 const struct option *longopts, int *longindex);

Первые три аргумента те же, что и в

getopt
. Следующая опция является указателем на массив
struct option
, который мы назовем таблицей длинных опций и который вскоре опишем. Параметр
longindex
, если он не установлен в NULL, указывает на переменную, в которую помешается индекс обнаруженной длинной опции в
longopts
. Это полезно, например, при диагностике ошибок.

2.3.3.1. Таблица длинных опций

Длинные опции описываются с помощью массива структур

struct option
. Структура
struct option
определена в
<getopt.h>
; она выглядит следующим образом:

struct option {

 const char *name;

 int has_arg;

 int *flag;

 int val;

};

Элементы структуры следующие:

const char *name

Это имя опции без предшествующих черточек, например, «

help
» или «
verbose
».

int has_arg

Переменная описывает, имеет ли длинная опция аргумент, и если да, какого вида этот аргумент. Значение должно быть одно из представленных в табл. 2.1. Макроподстановки являются некоторыми символическими именами для числовых значений, приведенных в таблице. Хотя числовые значения тоже работают, макроподстановки гораздо легче читать, и вы должны их использовать вместо соответствующих чисел в любом коде, который пишете.

Поделиться:
Популярные книги

Кровь на эполетах

Дроздов Анатолий Федорович
3. Штуцер и тесак
Фантастика:
альтернативная история
7.60
рейтинг книги
Кровь на эполетах

Студиозус 2

Шмаков Алексей Семенович
4. Светлая Тьма
Фантастика:
юмористическое фэнтези
городское фэнтези
аниме
5.00
рейтинг книги
Студиозус 2

Темный Патриарх Светлого Рода

Лисицин Евгений
1. Темный Патриарх Светлого Рода
Фантастика:
юмористическое фэнтези
попаданцы
аниме
5.00
рейтинг книги
Темный Патриарх Светлого Рода

Изгой Проклятого Клана. Том 2

Пламенев Владимир
2. Изгой
Фантастика:
попаданцы
аниме
фэнтези
фантастика: прочее
5.00
рейтинг книги
Изгой Проклятого Клана. Том 2

Приручитель женщин-монстров. Том 6

Дорничев Дмитрий
6. Покемоны? Какие покемоны?
Фантастика:
юмористическое фэнтези
аниме
5.00
рейтинг книги
Приручитель женщин-монстров. Том 6

Бестужев. Служба Государевой Безопасности

Измайлов Сергей
1. Граф Бестужев
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Бестужев. Служба Государевой Безопасности

На границе империй. Том 10. Часть 2

INDIGO
Вселенная EVE Online
Фантастика:
космическая фантастика
5.00
рейтинг книги
На границе империй. Том 10. Часть 2

70 Рублей

Кожевников Павел
1. 70 Рублей
Фантастика:
фэнтези
боевая фантастика
попаданцы
постапокалипсис
6.00
рейтинг книги
70 Рублей

Ученик. Книга третья

Первухин Андрей Евгеньевич
3. Ученик
Фантастика:
фэнтези
7.64
рейтинг книги
Ученик. Книга третья

Гардемарин Ее Величества. Инкарнация

Уленгов Юрий
1. Гардемарин ее величества
Фантастика:
городское фэнтези
попаданцы
альтернативная история
аниме
фантастика: прочее
5.00
рейтинг книги
Гардемарин Ее Величества. Инкарнация

Метатель

Тарасов Ник
1. Метатель
Фантастика:
боевая фантастика
попаданцы
рпг
фэнтези
фантастика: прочее
постапокалипсис
5.00
рейтинг книги
Метатель

Один на миллион. Трилогия

Земляной Андрей Борисович
Один на миллион
Фантастика:
боевая фантастика
8.95
рейтинг книги
Один на миллион. Трилогия

Завод: назад в СССР

Гуров Валерий Александрович
1. Завод
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Завод: назад в СССР

Треск штанов

Ланцов Михаил Алексеевич
6. Сын Петра
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Треск штанов