ОБЗОР
#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.