Linux |
CentOS 5.3 |
|
utimes(2) |
utime, utimes − Changer la date d’accès ou de modification d’un i−noeud. |
#include <sys/types.h> #include <utime.h> int utime(const char *filename, const struct utimbuf *buf); #include <sys/time.h> int utimes(const char *filename, const struct timeval times[2]); |
utime() modifie les dates d’accès et de modification de l’i−noeud indiqué par filename pour les valeurs contenues respectivement dans les champs actime et modtime de buf. Si buf est NULL, les dates d’accès et de modification sont mises à la date actuelle. La modification des horodatages est permise lorsque soit le processus a les privilèges appropriés (sous Linux : avoir la capacité CAP_FOWNER) soit l’UID effectif est égal à l’UID du fichier, soit buf est nul et le processus a la permission d’écriture sur le fichier. La structure utimbuf est la suivante : |
struct utimbuf { time_t actime; /* heure d’accès */ time_t modtime; /* heure de modification */ }; |
La fonction utime() permet des spécifications d’horodatage avec une résolution d’une seconde. La fonction utimes() est similaire mais permet un résolution d’une microseconde. Ici, times[0] fait référence à l’heure d’accès, et times[1] à l’heure de modification. La structure timeval est la suivante : |
struct timeval { long tv_sec; /* secondes */ long tv_usec; /* microsecondes */ }; |
utime et utimes renvoient 0 s’ils réussissent ou −1 s’ils échouent auquel cas errno contient le code d’erreur. |
Plusieurs erreurs peuvent se produire, les plus courantes étant : |
EACCES |
La permission de parcours est refusée pour l’un des répertoires du chemin path (voir aussi path_resolution(2)), ou buf est nul et le processus n’a pas l’autorisation de modifier les horodatages (voir plus haut). |
||
ENOENT |
filename n’existe pas. |
||
EPERM |
buf n’est pas nul et le processus n’a pas l’autorisation de modifier les horodatages. |
||
EROFS |
path se trouve sur un système de fichier en lecture seule. |
Linux n’autorise pas la modification d’horodatages sur les fichiers immuables, ou l’horodatage avec autre chose que la date courante sur les fichiers en ajout seulement. Dans libc4 et libc5, utimes() est juste une enveloppe à utime() et ne permet donc pas des résolutions inférieure à la seconde. POSIX.1-2001 considère utimes() comme un héritage du passé, ce qui est étrange puisqu’il fournit plus de fonctionnalités que utime(). |
Linux ne prend pas soin de distinguer les erreurs de retour EACCES et EPERM. D’un autre coté, POSIX.1-2003 est bogué dans sa description d’erreur pour utimes(). |
utime() : SVr4, POSIX.1-2001. |
chattr(1), futimesat(2), stat(2), futimes(3) |
Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 15 octobre 1996 et révisée le 14 août 2006. L’équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 2 utime ». N’hésitez pas à signaler à l’auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel. |
utimes(2) |