Linux repositories inspector

unlinkat(2) - Russkiy

Linux
2012-05-04

man-pages-ru

Russian man pages from the Linux Documentation Project

man-pages

Linux kernel and C library user-space interface documentation

ИМЯ

unlinkat - удаляет элемент каталога, определяемый относительно файлового дескриптора каталога

ОБЗОР

#include <fcntl.h> /* определения констант AT_* */
#include <unistd.h>

int unlinkat(int dirfd, const char *pathname, int flags);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
unlinkat():
Начиная с glibc 2.10:
_XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L
До glibc 2.10:
_ATFILE_SOURCE

ОПИСАНИЕ

Системный вызов unlinkat() работает также как unlink(2) или rmdir(2) (в зависимости от того, есть ли флаг AT_REMOVEDIR во flags), за исключением случаев, описанных в данной справочной странице.
Если в pathname задан относительный путь, то он считается относительно каталога, на который ссылается файловый дескриптор dirfd (а не относительно текущего рабочего каталога вызывающего процесса, как это делается в unlink(2) и rmdir(2)).
Если в pathname задан относительный путь и dirfd равно специальному значению AT_FDCWD, то pathname рассматривается относительно текущего рабочего каталога вызывающего процесса (как unlink(2) и rmdir(2)).
Если в pathname задан абсолютный путь, то dirfd игнорируется.
Аргумент flags представляет собой битовую маску, значение которой может быть 0, или объединённым значением флагов с помощью OR, определяющих операцию unlinkat(). В настоящее время определены следующие флаги:
AT_REMOVEDIR
По умолчанию, unlinkat() выполняет действие, эквивалентное unlink(2) с параметром pathname. Если указан флаг AT_REMOVEDIR, то выполняется действие, эквивалентное rmdir(2) с параметром pathname.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении unlinkat() возвращается 0. При ошибке возвращается -1, а в errno содержится код ошибки.

ОШИБКИ

В unlinkat() могут возникнуть те же ошибки, что и в unlink(2) и rmdir(2). Также, в unlinkat() могут возникнуть следующие ошибки:
EBADF dirfd не является правильным файловым дескриптором.
EINVAL В flags указано неверное значение флага.
ENOTDIR
Значение pathname содержит относительный путь и dirfd содержит файловый дескриптор, указывающий на файл, а не на каталог.

ВЕРСИИ

Системный вызов unlinkat() был добавлен в ядро Linux версии 2.6.16; поддержка в glibc доступна с версии 2.4.

СООТВЕТСТВИЕ СТАНДАРТАМ

POSIX.1-2008. Подобный системный вызов есть в Solaris.

ЗАМЕЧАНИЯ

Смотрите в openat(2) объяснение необходимости unlinkat().

СМОТРИТЕ ТАКЖЕ

REFERENCED BY

⇧ Top