}
Во время обработки возвращенных параметров приложению необходимо знать значение каждого аргумента, который был определен после параметра. Это можно сделать двумя способами. Один из них заключается в том, чтобы popt
присваивала переменной значение параметра из элементов arg таблицы параметров. Другой способ предусматривает применение функции poptGetOptArg()
.
#include <popt.h>
char * poptGetOptArg(poptContext con);
Эта функция возвращает аргумент, заданный для последнего параметра, возвращенного функцией poptGetNextOpt()
, или возвращает значение NULL
, если ни один из аргументов не был определен.
26.2.3. Остаточные аргументы
Многие приложения принимают произвольное количество аргументов командной строки, например, список имен файлов. Когда popt
встречает аргумент, перед которым отсутствует дефис -
, она считает его таким аргументом и добавляет его в список остаточных аргументов. Доступ к этим аргументам в приложениях можно реализовать с помощью описанных далее трех функций.
char * poptGetArg(poptContext con);
Эта функция возвращает следующий остаточный аргумент и помечает его как обработанный.
char * poptPeekArg(poptContext con);
Эта функция возвращает следующий аргумент, не помечая его как обработанный. Таким образом, приложение может продолжить рассмотрение списка аргументов, не модифицируя список.
char ** poptGetArgs(poptContext con);
Эта функция возвращает все остаточные аргументы в виде argv
. Последний элемент в возвращаемом массиве указывает на NULL
, подтверждая конец аргументов.
26.2.4. Автоматические справочные сообщения
Одним из преимуществ использования библиотеки popt
является ее способность автоматически генерировать справочные сообщения и сообщения об использовании. В справочных сообщениях указывается каждый параметр командной строки и приводится его подробное описание, а в сообщениях об использовании приводится краткий перечень доступных параметров без какого-либо сопроводительного текста. Для создания каждого типа сообщения в библиотеке popt
предусмотрена отдельная функция.
#include <popt.h>
void poptPrintHelp(poptContext con, FILE * f, int flags);
void poptPrintUsage(poptContext con, FILE * f, int flags);
Обе эти функции ведут себя практически одинаково, записывая соответствующий тип сообщения в файл f
. Аргумент flags
на данный момент не используется ни одной из этих функций, и должен быть равен нулю для совместимости с будущими версиями библиотеки popt
.
Поскольку за справочное сообщение отвечает параметр --help
, а за сообщение об использовании — параметр --usage
, библиотека popt
предлагает простой способ добавления этих двух параметров в программу. Чтобы добавить эти параметры в таблицу параметров, можно использовать макрос POPT_AUTOHELP
[185], который выводит соответствующие сообщения в STDOUT
и закрывается после возвращения кода 0
[186]. В следующем примере показана таблица параметров в файле grep.с
; мы должны добавить одну строку в таблицу параметров для grep, чтобы активизировать автоматическое генерирование справочных сообщений.
95: struct poptOption optionsTable[] = {
96: { 'extended-regexp', 'E', POPT_ARG_VAL,
97: &mode, MODE_EXTENDED,
98: 'шаблоном для соответствия является расширенное регулярное '
99: 'выражение' },
100: { 'fixed-strings', 'F', POPT_ARG_VAL,
101: &mode, MODE_FIXED,
102: 'шаблоном для соответствия является базовая строка, (не '
103: 'регулярное выражение)', NULL },
104: { 'basic-regexp', 'G', POPT_ARG_VAL,
105: &mode, MODE_REGEXP,
106: 'шаблоном для соответствия является базовое регулярное выражение' },
107: { 'ignore-case', 'i', POPT_ARG_NONE, &ignoreCase, 0,
108: 'выполнять поиск, чувствительный к регистру', NULL },
109: { 'max-count', 'm', POPT_ARG_INT, &maxCount, 0,
110: 'завершить после получения N совпадений', 'N' },
111: { 'regexp', 'е', POPT_ARG_STRING, &pattern, 0,
112: 'регулярное выражение для поиска', 'pattern' },
113: POPT_AUTOHELP
114: { NULL, ' ', POPT_ARG_NONE, NULL, 0, NULL, NULL }
115: };
Ниже показан пример того, как выглядит справочное сообщение, сгенерированное данной таблицей параметров.
Usage: grep [OPTION...]
-Е, --extended-regexp шаблоном для соответствия является
расширенное регулярное выражение
-F, --fixed-strings шаблоном для соответствия является
базовая строка (не регулярное выражение)
-G, --basic-regexp шаблоном для соответствия является базовое
регулярное выражение
-i, --ignore-case выполнять поиск, чувствительный к регистру
-m, --max-count=N завершить после получения N совпадений
-е, --regexp=pattern регулярное выражение для поиска
Help options:
-?, --help Show this help message
--usage Display brief usage message