Linux программирование в примерах
Шрифт:
int gl_flags
Копия флагов. Включает также
GLOB_MAGCHAR
, если pattern
включал какие-либо метасимволы. void (*gl_closedir)(DIR *)
Указатель на альтернативную версию
closedir
. struct dirent *(*gl_readdir)(DIR *)
Указатель на альтернативную версию
readdir
. DIR *(*gl_opendir)(const char *)
Указатель на альтернативную версию
opendir
. int (*gl_lstat)(const char *, struct stat*)
Указатель на альтернативную версию
lstat
. int (*gl_stat)(const char*, struct stat*)
Указатель
stat
. Указатели на альтернативные версии стандартных функций предназначены главным образом для использования в реализации GLIBC; крайне маловероятно, что вы когда-нибудь их используете. Поскольку GLIBC предусматривает поле
gl_flags
и дополнительные значения флагов, справочная страница и руководство Info документируют оставшуюся часть структуры GLIBC glob_t
. В табл. 12.3 перечислены дополнительные флаги. Таблица 12.3. Дополнительные флаги GLIBC для
glob
Флаг | Значение |
---|---|
GLOB_ALTDIRFUNC | Использовать для доступа к каталогам альтернативные функции (см. текст) |
GLOB_BRACE | Выполнить раскрытие фигурных скобок в стиле csh и Bash. |
GLOB_MAGCHAR | Вставить gl_flags , если были найдены метасимволы. |
GLOB_NOMAGIC | Вернуть шаблон, если он не содержит метасимволов |
GLOB_ONLYDIR | По возможности сопоставлять лишь каталоги. См. текст. |
GLOB_PERIOD | Разрешить соответствие метасимволов наподобие * и ? начальной точке |
GLOB_TILDE | Выполнить раскрывание тильды в стиле оболочки. |
GLOB_TILDE_CHECK | Подобно GLOB_TILDE , но если есть проблемы с указанным домашним каталогом, вернуть GLOB_NOMATCH вместо помещения pattern в список. |
Флаг
GLOB_ONLYDIR
действует в качестве подсказки реализации, потому что вызывающий интересуется лишь каталогами. Главным его предназначением является использование другими функциями в GLIBC, а вызывающий по-прежнему должен быть готов обрабатывать файлы, не являющиеся каталогами. Вам не следует использовать этот флаг в своих программах. glob
может быть вызвана более одного раза: при первом вызове флаг GLOB_APPEND
не должен быть указан, при всех последующих вызовах он должен быть указан. Вы не можете между вызовами изменять gl_offs
, а если вы изменили какие-нибудь значения в gl_pathv
или gl_pathc
, нужно их восстановить перед последующим вызовом glob
. Возможность многократного вызова
glob
позволяет накапливать результаты в одном списке. Это довольно практично, приближается к мощным возможностям раскрывания групповых символов оболочки, но на уровне языка программирования С. glob
возвращает 0, если не было проблем, или одно из значений из табл. 12.4, если были. Таблица 12.4. Возвращаемые
glob
значения Флаг | Значение |
---|---|
GLOB_ABORTED | Просмотр
GLOB_ERR или функция (*errfunc) возвратила ненулевой результат |
GLOB_NOMATCH | Ни одно имя файла не соответствовало pattern , а флаг GLOB_NOCHECK не был установлен |
GLOB_NOSPACE | Была проблема с выделением динамической памяти |
globfree
освобождает всю память, которую динамически выделила glob
Следующая программа, ch12-glob.с
, демонстрирует glob
: 1 /* ch12-glob.c --- демонстрирует glob. */
2
3 #include <stdio.h>
4 #include <errno.h>
5 #include <glob.h>
6
7 char *myname;
8
9 /* globerr --- выводит сообщение об ошибке для glob */
10
11 int globerr(const char *path, int eerrno)
12 {
13 fprintf(stderr, "%s: %s: %s\n", myname, path, strerror(eerrno));
14 return 0; /* let glob keep going */
15 }
16
17 /* main --- раскрывает символы подстановки в командной строке и выводит результаты */
18
19 int main(int argc, char **argv)
20 {
21 int i;
22 int flags = 0;
23 glob_t results;
24 int ret;
25
26 if (argc == 1) {
27 fprintf(stderr, "usage: %s wildcard ...\n", argv[0]);
28 exit(1);
29 }
30
31 myname = argv[0]; /* для globerr */
32
33 for (i = 1; i < argc; i++) {
34 flags |= (i > 1 ? GLOB_APPEND : 0);
35 ret = glob(argv[i], flags, globerr, &results);
36 if (ret != 0) {
37 fprintf(stderr, "%s: problem with %s (%s),
38 stopping early\n", myname, argv[i],
39 /* опасно: */ (ret == GLOB_ABORTED ? "filesystem problem" :
40 ret == GLOB_NOMATCH ? "no match of pattern" :
41 ret == GLOB_NOSPACE ? "no dynamic memory" :
42 "unknown problem"));
43 break;
44 }
45 }
46
47 for (i = 0; i < results.gl_pathc; i++)
48 printf("%s\n", results.gl_pathv[i]);
49
50 globfree(&results);
51 return 0;
52 }
Строка 7 определяет
myname
, которая указывает на имя программы; эта переменная для сообщений об ошибках от globerr
, определенной в строках 11–15.
Поделиться:
Популярные книги
Авиатор: назад в СССР 12+1
13. Покоряя небо
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Третий
Фантастика:
космическая фантастика
попаданцы
5.00
рейтинг книги
В зоне особого внимания
12. Девяностые
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Кровавая весна
6. Изгой
Фантастика:
фэнтези
9.36
рейтинг книги
Неудержимый. Книга XVIII
18. Неудержимый
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Вперед в прошлое!
1. Вперед в прошлое
Фантастика:
попаданцы
5.00
рейтинг книги
Начальник милиции. Книга 3
3. Начальник милиции
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Не грози Дубровскому!
1. РОС: Не грози Дубровскому!
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Свадьба по приказу, или Моя непокорная княжна
Любовные романы:
любовно-фантастические романы
5.57
рейтинг книги
Муж на сдачу
Любовные романы:
любовно-фантастические романы
5.00
рейтинг книги
Кодекс Крови. Книга I
1. РОС: Кодекс Крови
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Польская партия
3. Фрунзе
Фантастика:
попаданцы
альтернативная история
5.25
рейтинг книги
Лорд Системы
1. Лорд Системы
Фантастика:
фэнтези
попаданцы
рпг
4.00
рейтинг книги
Газлайтер. Том 2
2. История Телепата
Фантастика:
попаданцы
альтернативная история
аниме
5.00