2285 return 1;
2286
2287 return 0;
2288 }
Цикл в строках 2276–2278 сопоставляет имя файла со списком шаблонов для игнорируемых файлов. Если один из шаблонов подходит, файл не интересен и file_interesting()
возвращает false (то есть 0).
Переменная all_files
соответствует опции -А
, которая показывает файлы, имена которых начинаются с точки, но не являются '.
' и '..
'. Переменная really_all_files
соответствует опции -а
, которая предполагает -А
, а также показывает '.
' и '..
'. При наличии таких сведений, условие в строках 228–2284 может быть представлено следующим псевдокодом:
if (/*
OR /*
OR (/*
AND /*
AND (/*
OR /*
return TRUE;
ЗАМЕЧАНИЕ. fnmatch()
может оказаться дорогостоящей функцией, если она используется в локали с многобайтным набором символов. Обсудим многобайтные наборы символов в разделе 13.4 «Можете произнести это для меня по буквам?»
12.7.2. Раскрытие имени файла: glob()
и globfree()
Функции glob()
и globfree()
более разработанные, чем fnmatch()
:
#include
int glob(const char *pattern, int flags,
int (*errfunc)(const char *epath, int eerrno), glob_t *pglob);
void globfree(glob_t *pglob);
Функция glob()
осуществляет просмотр каталога и сопоставление с шаблонами, возвращая список всех путей, соответствующих pattern
. Символы подстановки могут быть включены в нескольких местах пути, а не только в качестве последнего компонента (например, '/usr/*/*.so
'). Аргументы следующие:
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()