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.