table of contents
SYMLINKAT(2) | Руководство программиста Linux | SYMLINKAT(2) |
ИМЯ¶
symlinkat - создаёт символьную ссылку, определяемую относительно файлового дескриптора каталога
ОБЗОР¶
#include <fcntl.h> /* определения констант AT_* */ #include <unistd.h> int symlinkat(const char *oldpath, int newdirfd, const char *newpath);
Требования
макроса
тестирования
свойств
для glibc (см.
feature_test_macros(7)):
symlinkat():
- Начиная с glibc 2.10:
- _XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L
- До glibc 2.10:
- _ATFILE_SOURCE
ОПИСАНИЕ¶
Системный вызов symlinkat() работает также как symlink(2), за исключением описанных, описанных в данной справочной странице.
Если в newpath задан относительный путь, то он считается относительно каталога, на который ссылается файловый дескриптор newdirfd (а не относительно текущего рабочего каталога вызывающего процесса, как это делается в symlink(2)).
Если в newpath задан относительный путь и newdirfd равно специальному значению AT_FDCWD, то newpath рассматривается относительно текущего рабочего каталога вызывающего процесса (как symdlink(2)).
Если в newpath задан абсолютный путь, то newdirfd игнорируется.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ¶
При успешном выполнении symlinkat() возвращается 0; при ошибке возвращается -1, а в errno содержится код ошибки.
ОШИБКИ¶
В symlinkat() могут возникнуть те же ошибки, что и в symdlink(2). Также, в symlinkat() могут возникнуть следующие ошибки:
ВЕРСИИ¶
Системный вызов symlinkat() был добавлен в ядро Linux версии 2.6.16; поддержка в glibc доступна с версии 2.4.
СООТВЕТСТВИЕ СТАНДАРТАМ¶
POSIX.1-2008.
ЗАМЕЧАНИЯ¶
Смотрите в openat(2) объяснение необходимости symlinkat().
СМОТРИТЕ ТАКЖЕ¶
2012-05-04 | Linux |