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

на главную

Жанры

Разработка приложений в среде 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
рейтинг книги
Приручитель женщин-монстров. Том 7

Темный Лекарь 4

Токсик Саша
4. Темный Лекарь
Фантастика:
фэнтези
аниме
5.00
рейтинг книги
Темный Лекарь 4

Младший сын князя

Ткачев Андрей Сергеевич
1. Аналитик
Фантастика:
фэнтези
городское фэнтези
аниме
5.00
рейтинг книги
Младший сын князя

Неудержимый. Книга VI

Боярский Андрей
6. Неудержимый
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Неудержимый. Книга VI

Сыночек в награду. Подари мне любовь

Лесневская Вероника
1. Суровые отцы
Любовные романы:
современные любовные романы
5.00
рейтинг книги
Сыночек в награду. Подари мне любовь

Неудержимый. Книга XVII

Боярский Андрей
17. Неудержимый
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Неудержимый. Книга XVII

Гром над Империей. Часть 1

Машуков Тимур
5. Гром над миром
Фантастика:
фэнтези
5.20
рейтинг книги
Гром над Империей. Часть 1

Возвышение Меркурия. Книга 3

Кронос Александр
3. Меркурий
Фантастика:
попаданцы
аниме
5.00
рейтинг книги
Возвышение Меркурия. Книга 3

Жандарм 4

Семин Никита
4. Жандарм
Фантастика:
попаданцы
альтернативная история
аниме
5.00
рейтинг книги
Жандарм 4

Корсар

Русич Антон
Вселенная EVE Online
Фантастика:
боевая фантастика
космическая фантастика
6.29
рейтинг книги
Корсар

Сломанная кукла

Рам Янка
5. Серьёзные мальчики в форме
Любовные романы:
современные любовные романы
5.00
рейтинг книги
Сломанная кукла

Отмороженный 3.0

Гарцевич Евгений Александрович
3. Отмороженный
Фантастика:
боевая фантастика
рпг
5.00
рейтинг книги
Отмороженный 3.0

Крестоносец

Ланцов Михаил Алексеевич
7. Помещик
Фантастика:
героическая фантастика
попаданцы
альтернативная история
5.00
рейтинг книги
Крестоносец

Чужое наследие

Кораблев Родион
3. Другая сторона
Фантастика:
боевая фантастика
8.47
рейтинг книги
Чужое наследие