.\" -*- coding: UTF-8 -*- '\" t .\" Copyright (c) 1993 by Thomas Koenig (ig25@rz.uni-karlsruhe.de) .\" .\" SPDX-License-Identifier: Linux-man-pages-copyleft .\" .\" Modified Wed Jul 28 11:12:17 1993 by Rik Faith (faith@cs.unc.edu) .\" Modified Mon May 13 23:08:50 1996 by Martin Schulze (joey@linux.de) .\" Modified 11 May 1998 by Joseph S. Myers (jsm28@cam.ac.uk) .\" Modified 990912 by aeb .\" 2007-10-10 mtk .\" Added description of GLOB_TILDE_NOMATCH .\" Expanded the description of various flags .\" Various wording fixes. .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH glob 3 "2 мая 2024 г." "Linux man\-pages 6.8" .SH ИМЯ glob, globfree \- ищет имена путей по шаблону, освобождает память после glob() .SH LIBRARY Standard C library (\fIlibc\fP, \fI\-lc\fP) .SH СИНТАКСИС .nf \fB#include \fP .P \fBint glob(const char *restrict \fP\fIpattern\fP\fB, int \fP\fIflags\fP\fB,\fP \fB int (*\fP\fIerrfunc\fP\fB)(const char *\fP\fIepath\fP\fB, int \fP\fIeerrno\fP\fB),\fP \fB glob_t *restrict \fP\fIpglob\fP\fB);\fP \fBvoid globfree(glob_t *\fP\fIpglob\fP\fB);\fP .fi .SH ОПИСАНИЕ Функция \fBglob\fP() ищет все совпадения имён путей с заданным шаблоном \fIpattern\fP, согласно правилам, используемым оболочкой (смотрите \fBglob\fP(7)). Расширения тильды или подстановка параметров не выполняется; если это нужно, то используйте \fBwordexp\fP(3). .P Функция \fBglobfree\fP() освобождает динамически выделенное хранилище, полученное в последнем вызове \fBglob\fP(). .P Результаты вызова \fBglob\fP() сохраняются в структуре, на которую указывает \fIpglob\fP. Эта структура имеет тип \fIglob_t\fP (объявлен в \fI\fP) и содержит следующие элементы, определённые в POSIX.2 (их может быть и больше, в виде расширений): .P .in +4n .EX typedef struct { size_t gl_pathc; /* количество совпавших путей */ char **gl_pathv; /* список совпавших имён путей. */ size_t gl_offs; /* зарезервированные в \fIgl_pathv\fP слоты. */ } glob_t; .EE .in .P Результаты размещаются в динамически выделяемом хранилище. .P Значение параметра \fIflags\fP формируется побитовым сложением нуля или более следующих символических констант, которые меняют ход работы \fBglob\fP(): .TP \fBGLOB_ERR\fP Выполнять возврат при ошибке чтения (например, нет прав для чтения каталога). По умолчанию \fBglob\fP() пытается продолжить работу не смотря на ошибки, читая все каталоги, которые может. .TP \fBGLOB_MARK\fP Добавлять косую черту к каждому пути, который соответствует каталогу. .TP \fBGLOB_NOSORT\fP Не сортировать возвращаемые имена. Это экономит процессорное время. По умолчанию имена сортируются. .TP \fBGLOB_DOOFFS\fP Резервировать слоты \fIpglob\->gl_offs\fP у начала списка строк в \fIpglob\->pathv\fP. Зарезервированные слоты содержат указатели null. .TP \fBGLOB_NOCHECK\fP Если не найдено совпадений по шаблону, возвращать в качестве результата заданный шаблон. По умолчанию при отсутствии совпадений \fBglob\fP() возвращает \fBGLOB_NOMATCH\fP. .TP \fBGLOB_APPEND\fP Добавлять результаты вызова к вектору результатов, полученному от предыдущего вызова \fBglob\fP(). Не следует включать этот флаг при первом вызове \fBglob\fP(). .TP \fBGLOB_NOESCAPE\fP Don't allow backslash (\[aq]\e\[aq]) to be used as an escape character. Normally, a backslash can be used to quote the following character, providing a mechanism to turn off the special meaning metacharacters. .P В \fIflags\fP также могу быть включены следующие флаги, которые являются расширениями GNU и отсутствуют в POSIX.2: .TP \fBGLOB_PERIOD\fP Разрешить начальной точке соответствовать метасимволам. По умолчанию метасимволы не считаются совпадающими с начальной точкой. .TP \fBGLOB_ALTDIRFUNC\fP Для доступа к файловой системе использовать функции \fIpglob\->gl_closedir\fP, \fIpglob\->gl_readdir\fP, \fIpglob\->gl_opendir\fP, \fIpglob\->gl_lstat\fP и \fIpglob\->gl_stat\fP вместо стандартных библиотечных функций. .TP \fBGLOB_BRACE\fP Раскрывать выражения в фигурных скобках \fB{a,b}\fP аналогичны используемым в \fBcsh\fP(1). Выражения могут быть вложенными. То есть, например, по шаблону "{foo/{,cat,dog},bar}" возвращаются те же результаты что и при четырёх отдельных вызовах \fBglob\fP() со строками: "foo/", "foo/cat", "foo/dog" и "bar". .TP \fBGLOB_NOMAGIC\fP Возвращать сам шаблон, если в нём не содержатся метасимволы, даже при отсутствии файла с таким именем. .TP \fBGLOB_TILDE\fP Carry out tilde expansion. If a tilde (\[aq]\[ti]\[aq]) is the only character in the pattern, or an initial tilde is followed immediately by a slash (\[aq]/\[aq]), then the home directory of the caller is substituted for the tilde. If an initial tilde is followed by a username (e.g., "\[ti]andrea/bin"), then the tilde and username are substituted by the home directory of that user. If the username is invalid, or the home directory cannot be determined, then no substitution is performed. .TP \fBGLOB_TILDE_CHECK\fP Поведение подобно \fBGLOB_TILDE\fP. Отличие в том, что если имя пользователя некорректно или домашний каталог невозможно определить, то вместо использования самого шаблона как имени, \fBglob\fP() возвращает \fBGLOB_NOMATCH\fP для указания на ошибку. .TP \fBGLOB_ONLYDIR\fP Это только \fIуказание\fP \fBglob\fP() на то, что вызывающего интересуют только каталоги, соответствующие шаблону. Если реализация может легко определить информацию о типе файла, то файлы не каталоги не возвращаются вызывающему. Однако, вызывающий всё равно должен проверять, что полученные файлы — каталоги (назначение этого флага — все лишь оптимизация производительности в случае, когда вызывающему нужны только каталоги). .P Если \fIerrfunc\fP не равно NULL, то в случае ошибки она будет вызвана с параметрами \fIepath\fP (указатель на путь, в котором произошла ошибка) и \fIeerrno\fP (полученное значение \fIerrno\fP после вызова одной из функций \fBopendir\fP(3), \fBreaddir\fP(3) или \fBstat\fP(2)).Если \fIerrfunc\fP вернёт ненулевое значение или если флаг \fBGLOB_ERR\fP установлен, то \fBglob\fP() закончит работу после вызова \fIerrfunc\fP. .P При успешном выполнении в \fIpglob\->gl_pathc\fP содержится количество совпадающих имён, а \fIpglob\->gl_pathv\fP содержит указатель на список указателей на найденные имена. Список указателей завершается указателем null. .P Вызов \fBglob\fP() может выполняться несколько раз. В этом случае флаг \fBGLOB_APPEND\fP должен быть включён в \fIflags\fP при втором и последующих вызовах. .P Как расширение GNU, при обнаружении метасимволов \fIpglob\->gl_flags\fP — набор задаваемых флагов, сложенный с \fBGLOB_MAGCHAR\fP (с помощью операции ИЛИ). .SH "ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ" При успешном выполнении \fBglob\fP() возвращает ноль. Другие возможные возвращаемые значения: .TP \fBGLOB_NOSPACE\fP занята вся свободная память .TP \fBGLOB_ABORTED\fP ошибка чтения .TP \fBGLOB_NOMATCH\fP не найдено совпадений с шаблоном .SH АТРИБУТЫ Описание терминов данного раздела смотрите в \fBattributes\fP(7). .TS allbox; lb lb lbx l l l. Интерфейс Атрибут Значение T{ .na .nh \fBglob\fP() T} Безвредность в нитях T{ .na .nh MT\-Unsafe race:utent env sig:ALRM timer locale T} T{ .na .nh \fBglobfree\fP() T} Безвредность в нитях MT\-Safe .TE .P В приведённой выше таблице \fIutent\fP в \fIrace:utent\fP означает, что если любая из функций \fBsetutent\fP(3), \fBgetutent\fP(3) или \fBendutent\fP(3) используется одновременно в нескольких нитях программы, то может возникнуть состязательность по данным. Эти функции вызываются из \fBglob\fP(), поэтому мы используем race:utent для напоминания. .SH СТАНДАРТЫ POSIX.1\-2008. .SH ИСТОРИЯ POSIX.1\-2001, POSIX.2. .SH ПРИМЕЧАНИЯ Элементы структуры \fIgl_pathc\fP и \fIgl_offs\fP объявлены с типом \fIsize_t\fP в glibc 2.1 (как и должны указываться, согласно POSIX.2), но указаны как \fIint\fP в glibc 2.0. .SH ОШИБКИ Функция \fBglob\fP() может завершиться с ошибкой из\-за ошибок в используемых её функций: \fBmalloc\fP(3) или \fBopendir\fP(3). Эти функции записывают коды своих ошибок в переменную \fIerrno\fP. .SH ПРИМЕРЫ Пример использования приводится ниже, в нём имитируется набор строки .P .in +4n .EX ls \-l *.c ../*.c .EE .in .P в оболочке: .P .in +4n .EX glob_t globbuf; \& globbuf.gl_offs = 2; glob("*.c", GLOB_DOOFFS, NULL, &globbuf); glob("../*.c", GLOB_DOOFFS | GLOB_APPEND, NULL, &globbuf); globbuf.gl_pathv[0] = "ls"; globbuf.gl_pathv[1] = "\-l"; execvp("ls", &globbuf.gl_pathv[0]); .EE .in .SH "СМОТРИТЕ ТАКЖЕ" \fBls\fP(1), \fBsh\fP(1), \fBstat\fP(2), \fBexec\fP(3), \fBfnmatch\fP(3), \fBmalloc\fP(3), \fBopendir\fP(3), \fBreaddir\fP(3), \fBwordexp\fP(3), \fBglob\fP(7) .PP .SH ПЕРЕВОД Русский перевод этой страницы руководства разработал Azamat Hackimov , Dmitry Bolkhovskikh , Vladislav , Yuri Kozlov и Иван Павлов . .PP Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, .UR https://www.gnu.org/licenses/gpl-3.0.html .UE версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ. .PP Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику по его адресу электронной почты или по адресу .MT списка рассылки русских переводчиков .ME .