ОБЗОР
#include <sys/types.h>#include <dirent.h>
int dirfd(DIR *dirp);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
dirfd():
-
_BSD_SOURCE || _SVID_SOURCE
|| /* начиная с glibc 2.10: */- (_POSIX_C_SOURCE >= 200809L || _XOPEN_SOURCE >= 700)
ОПИСАНИЕ
Функция dirfd() возвращает файловый дескриптор, связанный с потоком каталога dirp.Этот файловый дескриптор используется внутри функции потоком каталога. В результате он полезен только для функций, которые не зависят и не изменяют положение в файле, например fstat(2) и fchdir(2). Он автоматически закрывается при вызове closedir(3).
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
При успешном выполнении возвращается неотрицательный файловый дескриптор. При ошибке возвращается -1 и errno устанавливается в соответствующее значение.ОШИБКИ
В POSIX.1-2008 определены две ошибки, ни одна из которых не возвращается текущей реализацией.- EINVAL
- Значение dirp не указывает на допустимый поток каталога.
- ENOTSUP
- Реализация не поддерживает связь файлового дескриптора с каталогом.
АТРИБУТЫ
Описание терминов данного раздела смотрите в attributes(7).Интерфейс | Атрибут | Значение |
dirfd() | безвредность в нитях | безвредно (MT-Safe) |