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

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

Жанры

Разработка приложений в среде 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
поддерживают только псевдонимы, однако в будущем появятся новые возможности. Следующим параметром является параметр, для которого необходимо задать псевдоним; это может быть как короткий, так и длинный параметр. Остальная часть строки определяет расширение псевдонима. Синтаксический анализ строки выполняется по аналогии с командой оболочки, в которой в качестве кавычек можно использовать символы
\
,
"
и
'
. Если последним символом строки будет обратная косая черта, то следующая строка в файле трактуется как логическое продолжение строки, содержащей этот символ, как и в оболочке.

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

Сама себе хозяйка

Красовская Марианна
Любовные романы:
любовно-фантастические романы
5.00
рейтинг книги
Сама себе хозяйка

Ученичество. Книга 2

Понарошку Евгений
2. Государственный маг
Фантастика:
фэнтези
попаданцы
5.00
рейтинг книги
Ученичество. Книга 2

Надуй щеки!

Вишневский Сергей Викторович
1. Чеболь за партой
Фантастика:
попаданцы
дорама
5.00
рейтинг книги
Надуй щеки!

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

INDIGO
17. Фортуна дама переменчивая
Фантастика:
космическая фантастика
попаданцы
5.00
рейтинг книги
На границе империй. Том 9. Часть 4

Эволюционер из трущоб. Том 6

Панарин Антон
6. Эволюционер из трущоб
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Эволюционер из трущоб. Том 6

Идеальный мир для Лекаря 19

Сапфир Олег
19. Лекарь
Фантастика:
юмористическое фэнтези
аниме
5.00
рейтинг книги
Идеальный мир для Лекаря 19

Гарем на шагоходе. Том 1

Гремлинов Гриша
1. Волк и его волчицы
Фантастика:
боевая фантастика
юмористическая фантастика
попаданцы
5.00
рейтинг книги
Гарем на шагоходе. Том 1

Академия проклятий. Книги 1 - 7

Звездная Елена
Академия Проклятий
Фантастика:
фэнтези
8.98
рейтинг книги
Академия проклятий. Книги 1 - 7

Беглец

Бубела Олег Николаевич
1. Совсем не герой
Фантастика:
фэнтези
попаданцы
8.94
рейтинг книги
Беглец

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

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

Офицер-разведки

Поселягин Владимир Геннадьевич
2. Красноармеец
Фантастика:
боевая фантастика
попаданцы
5.00
рейтинг книги
Офицер-разведки

Имя нам Легион. Том 9

Дорничев Дмитрий
9. Меж двух миров
Фантастика:
боевая фантастика
рпг
аниме
5.00
рейтинг книги
Имя нам Легион. Том 9

(Не)нужная жена дракона

Углицкая Алина
5. Хроники Драконьей империи
Любовные романы:
любовно-фантастические романы
6.89
рейтинг книги
(Не)нужная жена дракона

Этот мир не выдержит меня. Том 2

Майнер Максим
2. Первый простолюдин в Академии
Фантастика:
фэнтези
попаданцы
5.00
рейтинг книги
Этот мир не выдержит меня. Том 2