Вход/Регистрация
Linux программирование в примерах
вернуться

Роббинс Арнольд

Шрифт:

const char *pattern

Шаблон для раскрывания.

int flags

Флаги, управляющие поведением

glob
, вскоре будут описаны.

int (*errfunc)(const char *epath, int eerrno)

Указатель на функцию для использования при сообщениях об ошибках. Это значение может равняться

NULL
. Если нет и если
(*errfunc)
возвращает ненулевое значение или в
flags
установлен
GLOB_ERR
,
glob
прекращает обработку. Аргументами
(*errfunc)
являются путь, вызвавший проблему, и значение errno, установленное функциями
opendir
,
readdir
или
stat
.

glob_t *pglob

Указатель на структуру

glob_t
, использующуюся для хранения результатов. Структура
glob_t
содержит список путей, которые выдает
glob
:

typedef struct { /* POSIX */

 size_t gl_pathc; /* Число найденных подходящих путей */

 char **gl_pathv; /* Список подходящих путей */

 size_t gl_offs; /* Слоты для резервирования в gl_pathv */

} glob_t;

size_t gl_pathc

Число путей, которые подошли.

char **gl_pathv

Массив подходящих путей.

gl_pathv[gl_pathc]
всегда равен
NULL
.

size_t gl_offs

«Зарезервированные слоты» в

gl_pathv
. Идея заключается в резервировании слотов спереди от
gl_pathv
для заполнения их приложением впоследствии, как в случае с именем команды и опциями. Список затем может быть передан непосредственно
execv
или
execvp
(см. раздел 9.1.4 «Запуск новой программы: семейство
exec
»). Зарезервированные слоты устанавливаются в
NULL
. Чтобы все это работало, в
flags
должен быть установлен
GLOB_DOOFFS
.

В табл. 12.2 перечислены стандартные флаги для

glob
.

Таблица 12.2. Флаги для

glob

Флаг Значение
GLOB_APPEND
Добавить результаты текущего вызова к предыдущим
GLOB_DOOFFS
Зарезервировать места
gl_offs
спереди в
gl_pathv
GLOB_MARK
Добавлять символ / в конец каждого имени, которое обозначает каталог
GLOB_NOCHECK
Если шаблон не соответствует имени какого-нибудь файла, вернуть его без изменений
GLOB_NOESCAPE
Рассматривать обратный слеш как обычный символ. Это делает невозможным обозначать метасимволы подстановок
GLOB_NOSORT
Не сортировать результаты, по умолчанию они сортируются

GLIBC версия структуры

glob_t
содержит дополнительные члены:

typedef struct { /* GLIBC */

 /* Компоненты POSIX: */

 size_t gl_pathc; /* Число подходящих путей */

 char **gl_pathv; /* Список подходящих путей */

 size_t gl_offs; /* Резервируемые в gl_pathv слоты */

 /* Компоненты GLIBC: */

 int gl_flags; /* Копия флагов, дополнительные флаги GLIBC */

 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 */

} glob_t;

Члены структуры следующие:

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 перечислены дополнительные флаги.

  • Читать дальше
  • 1
  • ...
  • 209
  • 210
  • 211
  • 212
  • 213
  • 214
  • 215
  • 216
  • 217
  • 218
  • 219
  • ...

Ебукер (ebooker) – онлайн-библиотека на русском языке. Книги доступны онлайн, без утомительной регистрации. Огромный выбор и удобный дизайн, позволяющий читать без проблем. Добавляйте сайт в закладки! Все произведения загружаются пользователями: если считаете, что ваши авторские права нарушены – используйте форму обратной связи.

Полезные ссылки

  • Моя полка

Контакты

  • chitat.ebooker@gmail.com

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