futimesat - изменяет временные отметки файла, определяемого относительно
futimesat(2)
изменяет временные отметки файла, определяемого относительно
ОБЗОР
#include <fcntl.h> /* определения констант AT_* */
#include <sys/time.h>
int futimesat(int dirfd, const char *pathname,
const struct timeval times[2]);
Требования макроса тестирования свойств для glibc
(см. feature_test_macros(7)):
futimesat(): _GNU_SOURCE
ОПИСАНИЕ
Данный системный вызов устарел. Используйте вместо него
utimensat(2).
Системный вызов futimesat() работает также как системный вызов
utimes(2), за исключением случаев, описанных в данной справочной
странице.
Если в pathname задан относительный путь, то он считается относительно
каталога, на который ссылается файловый дескриптор dirfd (а не
относительно текущего рабочего каталога вызывающего процесса, как это
делается в utimes(2)).
Если в pathname задан относительный путь и dirfd равно специальному
значению AT_FDCWD, то pathname рассматривается относительно текущего
рабочего каталога вызывающего процесса (как utimes(2)).
Если в pathname задан абсолютный путь, то dirfd игнорируется.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
При успешном выполнении
futimesat() возвращает 0; при ошибке --- -1, а в
errno задаётся причина ошибки.
ОШИБКИ
В
futimesat() могут возникнуть те же ошибки, что и в
utimes(2). Также,
в
futimesat() могут возникнуть следующие ошибки:
EBADF
dirfd не является правильным файловым дескриптором.
ENOTDIR
Значение pathname содержит относительный путь и dirfd содержит
файловый дескриптор, указывающий на файл, а не на каталог.
ВЕРСИИ
Вызов
futimesat() был добавлен в ядро Linux версии 2.6.16; поддержка в
glibc доступна с версии 2.4.
СООТВЕТСТВИЕ СТАНДАРТАМ
Данный системный вызов не является стандартным. Он был реализован по
спецификации POSIX.1, но она была заменена на
utimensat(2).
Подобный системный вызов есть в Solaris.
ЗАМЕЧАНИЯ
Замечания по glibc
Если
pathname равно NULL, то обёрточная функция glibc
futimesat()
обновляет временные метки файла, указанного в
dirfd.