lutimes(3) изменяют метки времени файла

Other Alias

futimes

ОБЗОР

#include <sys/time.h>
int futimes(int fd, const struct timeval tv[2]);
int lutimes(const char *filename, const struct timeval tv[2]);

Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

futimes(), lutimes(): _BSD_SOURCE

ОПИСАНИЕ

Функция futimes() изменяет время доступа и изменения файла также как это делает utimes(2); единственное отличие в том, что файл чьи временные метки изменяются, указывается в виде файлового дескриптора, fd, а не в виде пути.

Функция lutimes() изменяет время доступа и изменения файла также как это делает utimes(2); единственное отличие в том, что если filename является символьной ссылкой, то ссылка не разыменовывается — изменяются метки времени самой ссылки.

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

При успешном выполнении возвращается 0. В случае ошибки возвращается -1, а errno устанавливается в соответствующее значение.

ОШИБКИ

Возникают те же ошибки что и для utimes(2), а также дополнительно для futimes():
EBADF
Значение fd не является правильным файловым дескриптором.
ENOSYS
Нет доступа к файловой системе /proc.

Для lutimes() может возникать следующая дополнительная ошибка:

ENOSYS
Ядро не поддерживает этот вызов; требуется Linux версии 2.6.22 или новее.

ВЕРСИИ

Функция futimes() доступна в glibc начиная с версии 2.3. Функция lutimes() доступа в glibc начиная с версии 2.6, и реализована на основе системного вызова utimensat(2), который поддерживается в ядре начиная с версии 2.6.22.

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).
ИнтерфейсАтрибутЗначение
futimes(), lutimes() безвредность в нитяхбезвредно (MT-Safe)

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

Эти функции не определены ни в одном стандарте. Помимо Linux, они доступны только в некоторых BSD.