Разработка приложений в среде Linux. Второе издание
Шрифт:
46: printf("используется высота %d ширина %d передний план %s фон %s\n",
47: p->height, p->width, p->fg, p->bg);
48:
49: } else {
50: switch (opt->shortName) {
51: case 'h': p->height = strtol(arg, &chptr, 10); break;
52: case 'w': p->width = strtol(arg, &chptr, 10); break;
53: case 'f' : p->fg = (char *) arg; break;
54: case 'b': p->bg = (char *) arg; break;
55: }
56:
57: if (chptr && *chptr) {
58: fprintf(stderr, "для %s ожидался числовой аргумент\n",
59: opt->longName);
60: exit(1);
61: }
62: }
63: }
64:
Программа,
popt
. Обычно этой строкой является макрос, задаваемый в заголовочном файле (подобно тому, как реализуется POPT_AUTOHELP
), но в целях упрощения в данном примере мы просто явным образом покажем эту строку. 1: /* popt-nest.c */
2:
3: #include <popt.h>
4:
5: /* Обычно это объявление осуществляется в заголовочном файле */
6: extern struct poptOption libTable[];
7:
8: int main(int argc, const char * argv[]) {
9: poptContext optCon;
10: int rc;
11: struct poptOption options[] = {
12: { "app1", '\0', POPT_ARG_NONE, NULL, '\0' },
13: { NULL, '\0', POPT_ARG_INCLUDE_TABLE, libTable,
14: '\0', "Nested:", }
15: POPT_AUTOHELP
16: { NULL, '\0', POPT_ARG_NONE, NULL, '\0' }
17: };
18:
19: optCon = poptGetContext("popt-nest", argc, argv, options, 0);
20:
21: if ((rc = poptGetNextOpt (optCon)) < -1) {
22: fprintf(stderr, "%s: %s\n",
23: poptBadOption(optCon, POPT_BADOPTION_NOALIAS),
24: poptStrerror(rc));
25: return 1;
26: }
27:
28: return 0;
29: }
26.4. Обработка ошибок
Каждая из функций
popt
, которая может возвращать ошибки, возвращает целочисленные значения. В случае возникновения ошибки возвращается отрицательный код. В табл. 26.2 перечислены коды возможных ошибок. После таблицы дается подробное обсуждение каждой ошибки. Таблица 26.2. Коды ошибок
popt
Код ошибки | Описание |
---|---|
POPT_ERROR_NOARG | Отсутствует аргумент для данного параметра. |
POPT_ERROR_BADOPT | Невозможно проанализировать синтаксис аргумента параметра. |
POPT_ERROR_OPTSTOODEEP | Слишком глубокое вложение замещений имени параметра. |
POPT_ERROR_BADQUOTE | Несоответствие кавычек. |
POPT_ERROR_BADNUMBER | Невозможно преобразовать параметр в число. |
POPT_ERROR_OVERFLOW | Данное число слишком большое или слишком маленькое. |
POPT_ERROR_NOARG | Параметр, для которого требуется аргумент, был определен в командной строке, однако аргумент не был предоставлен. Эта ошибка может быть возвращена только функцией poptGetNextOpt . |
POPT_ERROR_BADOPT | Параметр был определен в массиве argv , однако его нет в таблице параметров. Эта ошибка может быть возвращена только функцией poptGetNextOpt . |
POPT_ERROR_OPTSTOODEEP | Совокупность замещений имени параметра имеет большую глубину вложений. На данный момент popt отслеживает параметры только до 10 уровня, чтобы избежать возникновения бесконечной рекурсии. Эту ошибку возвращает только функция poptGetNextOpt . |
POPT_ERROR_BADQUOTE | В строке, прошедшей синтаксический анализ, было обнаружено несоответствие кавычек (например, была обнаружена только одна
poptParseArgvString , poptReadConfigFile и poptReadDefaultConfig . |
POPT_ERROR_BADNUMBER | Преобразование строки в число ( int или long ) не было выполнено вследствие того, что строка содержит нецифровые символы. Эта ошибка возникает в том случае, когда функция poptGetNextOpt обрабатывает аргумент типа РOРТ_ARG_INT или POPT_ARG_LONG . |
POPT_ERROR_OVERFLOW | Преобразование из строки в число не было выполнено вследствие того, что число было слишком большим или слишком маленьким. Подобно ошибке POPT_ERROR_BADNUMBER , эта ошибка может возникнуть только в том случае, если функция poptGetNextOpt обрабатывает аргумент типа РОРТ_ARG_INT или POPT_ARG_LONG . |
POPT_ERROR_ERRNO | Системный вызов был возвращен вместе с ошибкой, а errno до сих пор содержит ошибку из системного вызова. Эту ошибку могут возвращать функции poptReadConfigFile и poptReadDefaultConfig . |
Приложения могут генерировать качественные сообщения об ошибках с помощью следующих двух функций.
const char * poptStrerror(const int error);
Эта функция принимает код ошибки
popt
и возвращает строку с описанием ошибки, как и стандартная функция strerror
. char * poptBadOption(poptContext con, int flags);
Если во время выполнения функции
poptGetNextOpt
возникла ошибка, эта функция возвращает параметр, вызвавший ошибку. Если аргументу flags
присвоено значение POPT_BADOPTION_NOALIAS
, возвращается самый внешний параметр. В противном случае аргумент flags
должен иметь нулевое значение, а возвращаемый параметр может быть определен посредством псевдонима. Для большинства приложений эти две функции существенно упрощают обработку ошибок
popt
. Если ошибка возникает во время выполнения большинства функций, то выводится сообщение об ошибке, а функция poptStrerror
возвращает строку с описанием ошибки. Если ошибка возникла во время синтаксического анализа аргумента, то код, подобный представленному ниже, отобразит информативное сообщение об ошибке. fprintf(stderr, "%s: %s\n",
poptBadOption(optCon, POPT_BADOPTION_NOALIAS),
poptStrerror(rc));
26.5. Псевдонимы параметров
Одним из основных преимуществ использования библиотеки
popt
по сравнению с функцией getopt
является возможность использования псевдонимов параметров. Благодаря ним пользователь может определить параметры, которые popt
будет расширять их на другие параметры по мере их определения. Если стандартная программа grep
использовала popt
, то пользователи могли добавлять параметр – -text
, который расширялся до – i -n -Е -2
, облегчая поиск информации в текстовых файлах. 26.5.1. Определение псевдонимов
Псевдонимы обычно определяются в двух местах: в
/etc/popt
и в файле .popt
, хранящемся в домашнем каталоге пользователя (его можно найти через переменную окружения HOME
). Оба файла имеют одинаковую форму в виде произвольного количества строк, форматированных следующим образом: appname alias newoption expansion
appname
представляет имя приложения, которое должно быть таким же именем, как и имя в параметре name
, переданное функции poptGetContext
. Благодаря этому в каждом файле можно определять псевдонимы для нескольких программ. Ключевое слово alias
указывает на то, что определяется псевдоним; на данный момент конфигурационные файлы popt
поддерживают только псевдонимы, однако в будущем появятся новые возможности. Следующим параметром является параметр, для которого необходимо задать псевдоним; это может быть как короткий, так и длинный параметр. Остальная часть строки определяет расширение псевдонима. Синтаксический анализ строки выполняется по аналогии с командой оболочки, в которой в качестве кавычек можно использовать символы \
, "
и '
. Если последним символом строки будет обратная косая черта, то следующая строка в файле трактуется как логическое продолжение строки, содержащей этот символ, как и в оболочке.
Поделиться:
Популярные книги
Приручитель женщин-монстров. Том 7
7. Покемоны? Какие покемоны?
Фантастика:
юмористическое фэнтези
аниме
5.00
рейтинг книги
Темный Лекарь 4
4. Темный Лекарь
Фантастика:
фэнтези
аниме
5.00
рейтинг книги
Младший сын князя
1. Аналитик
Фантастика:
фэнтези
городское фэнтези
аниме
5.00
рейтинг книги
Неудержимый. Книга VI
6. Неудержимый
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Сыночек в награду. Подари мне любовь
1. Суровые отцы
Любовные романы:
современные любовные романы
5.00
рейтинг книги
Неудержимый. Книга XVII
17. Неудержимый
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Гром над Империей. Часть 1
5. Гром над миром
Фантастика:
фэнтези
5.20
рейтинг книги
Возвышение Меркурия. Книга 3
3. Меркурий
Фантастика:
попаданцы
аниме
5.00
рейтинг книги
Жандарм 4
4. Жандарм
Фантастика:
попаданцы
альтернативная история
аниме
5.00
рейтинг книги
Корсар
Вселенная EVE Online
Фантастика:
боевая фантастика
космическая фантастика
6.29
рейтинг книги
Сломанная кукла
5. Серьёзные мальчики в форме
Любовные романы:
современные любовные романы
5.00
рейтинг книги
Отмороженный 3.0
3. Отмороженный
Фантастика:
боевая фантастика
рпг
5.00
рейтинг книги
Крестоносец
7. Помещик
Фантастика:
героическая фантастика
попаданцы
альтернативная история
5.00
рейтинг книги
Чужое наследие
3. Другая сторона
Фантастика:
боевая фантастика
8.47