utimensat(2) | System Calls Manual | utimensat(2) |
utimensat, futimens - Modifier les horodatages d'un fichier avec une précision d'une nanoseconde
Bibliothèque C standard (libc, -lc)
#include <fcntl.h> /* Définition des constantes AT_* */ #include <sys/stat.h>
int utimensat(int dirfd, const char *pathname, const struct timespec times[_Nullable 2], int flags); int futimens(int fd, const struct timespec times[_Nullable 2]);
utimensat():
Depuis la version 2.10 de la glibc :
_POSIX_C_SOURCE >= 200809L
Avant la version 2.10 de la glibc :
_ATFILE_SOURCE
futimens():
Depuis la glibc 2.10 :
_POSIX_C_SOURCE >= 200809L
Avant la glibc 2.10 :
_GNU_SOURCE
utimensat() et futimens() mettent à jour les horodatages d'un fichier avec une précision d'une nanoseconde. Cela change de l'appel historique ou de utimes(2) qui permettent seulement une précision d'une seconde et d'une microseconde respectivement pour l'établissement des horodatages de fichier.
Avec utimensat(), le fichier est indiqué à l'aide du chemin fournit dans pathname. Avec futimens(), le fichier dont les horodatages doit être mis à jour est indiqué par un descripteur de fichier ouvert, fd.
Pour les deux appels, les nouveaux horodatages de fichier sont indiqués dans le tableau times[0] : times indique l'horodatage du dernier accès (atime) ; times[1] indique l'horodatage de la dernière modification (mtime). Chaque élément de times indique une date par un nombre de secondes et de nanosecondes depuis l'époque (1er janvier 1970 à 00:00:00 UTC). Cette information est transmise dans une structure timespec(3).
Les horodatages de fichier mis à jour sont configurés à la valeur la plus importante gérée par le système de fichiers et qui n'est pas supérieure à l'horodatage fourni.
Si le champ tv_nsec d'une des structures timespec prend la valeur particulière UTIME_NOW, alors l'horodatage correspondant du fichier est défini à l'heure actuelle. Si le champ tv_nsec d'une des structures timespec prend la valeur particulière UTIME_OMIT, alors l'horodatage correspondant du fichier reste inchangé. Dans ces deux cas, la valeur du champ tv_sec est ignoré.
Si times est NULL, les deux horodatages sont définis à l'heure actuelle.
L'heure du changement d'état (ctime) sera réglée à l'heure actuelle, même si les autres horodatages ne sont pas vraiment modifés.
Pour définir les deux horodatages à l'heure actuelle (c'est-à-dire quand times vaut NULL ou que les deux champs tv_nsec valent UTIME_NOW), il faut :
Pour pouvoir effectuer d'autres changements que de définir les horodatage à l'heure actuelle (c'est-à-dire quand times n'est pas NULL et que ni le champ tv_nsec ne vaut UTIME_NOW, ni le champ tv_nsec ne vaut UTIME_OMIT), les conditions 2 ou 3 ci-dessus s'appliquent.
Si les deux champs tv_nsec valent UTIME_OMIT, aucune vérification n'est effectuée sur le propriétaire ou les permissions et les horodatages ne sont pas modifiés, mais les autres situations d'erreur sont toujours détectées.
Si le chemin donné dans pathname est relatif, il est par défaut interprété par rapport au répertoire référencé par le descripteur de fichier ouvert dirfd (plutôt que par rapport au répertoire courant du processus, comme pour utimes(2) pour les chemins relatifs). Consultez openat(2) pour avoir les raisons pour lesquelles cela peut être utile.
Si pathname est un chemin relatif, et si dirfd a la valeur spéciale AT_FDCWD, alors pathname est interprété par rapport au répertoire courant du processus appelant, comme dans utimes(2).
Si pathname est absolu, alors dirfd est ignoré.
Le champ flags est un champ de bits qui peut être nul ou inclure les constantes suivantes, définies dans <fcntl.h> :
S'ils réussissent, les appels utimensat() et futimens() renvoient zéro, sinon ils renvoient -1 et errno est défini pour indiquer l'erreur.
utimensat() a été ajouté à Linux 2.6.22 ; la prise en charge de la glibc a été introduite dans la glibc 2.6.
La prise en charge de futimens() est apparu dans la glibc 2.6.
Pour une explication des termes utilisés dans cette section, consulter attributes(7).
Interface | Attribut | Valeur |
utimensat(), futimens() | Sécurité des threads | MT-Safe |
futimens() et utimensat() sont spécifiés dans POSIX.1-2008.
utimensat() rend futimesat(2) obsolète.
Sous Linux, les horodatages ne peuvent pas être modifiés pour un fichier marqué comme étant immuable, et la seule modification autorisée pour les fichiers n'autorisant que des ajouts est de définir les horodatages à l'heure actuelle. C'est cohérent avec le comportement historique de utime(2) et de utimes(2) sous Linux
Si les deux champs tv_nsec valent UTIME_OMIT, alors l'implémenation de utimensat() dans Linux réussit même si le fichier référencé par dirfd et pathname n'existe pas.
Sous Linux, futimens() est une fonction de bibliothèque implémentée à l'aide de l'appel système utimensat(). Pour cela, l'appel système utimensat() de Linux implémente une fonctionnalité non standard : si pathname est NULL, alors l'appel modifie les horodatages du fichier correspondant au descripteur de fichier dirfd (qui peut correspondre à n'importe quel type de fichier). En utilisant cette fonctionnalité, l'appel futimens(fd, times) est implémenté comme cela :
utimensat(fd, NULL, times, 0);
Notez néanmoins que l'enveloppe de la glibc pour utimensat() n'autorise pas le passage de NULL comme valeur de pathname : dans ce cas, la fonction d'enveloppe renvoie l'erreur EINVAL.
Plusieurs bogues affectent utimensat() et futimens() avant Linux 2.6.26. Ces bogues sont soit des non conformités avec le brouillon de la spécification POSIX.1, soit des incohérences avec le comportement historique de Linux.
chattr(1), touch(1), futimesat(2), openat(2), stat(2), utimes(2), futimes(3), timespec(3), inode(7), path_resolution(7), symlink(7)
La traduction française de cette page de manuel a été créée par Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org> et Jean-Pierre Giraud <jean-pierregiraud@neuf.fr>
Cette traduction est une documentation libre ; veuillez vous reporter à la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.
Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à debian-l10n-french@lists.debian.org.
12 février 2023 | Pages du manuel de Linux 6.03 |