FUTIMES(3) Руководство программиста Linux FUTIMES(3)

ИМЯ

futimes, lutimes - изменяют метки времени файла

ОБЗОР

#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(): начиная с glibc 2.19: _DEFAULT_SOURCE в glibc 2.19 и старее: _BSD_SOURCE

ОПИСАНИЕ

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

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

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

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

ОШИБКИ

Возникают те же ошибки что и для utimes(2), а также дополнительно для futimes():

Значение fd не является правильным файловым дескриптором.
Нет доступа к файловой системе /proc.

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

Ядро не поддерживает этот вызов; требуется 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.

СМОТРИТЕ ТАКЖЕ

utime(2), utimensat(2), symlink(7)

2017-09-15 Linux