.\" -*- coding: UTF-8 -*-
.\" Copyright (c) 1992 Drew Eckhardt (drew@cs.colorado.edu), March 28, 1992
.\" Parts Copyright (c) 1995 Nicolai Langfeldt (janl@ifi.uio.no), 1/1/95
.\" and Copyright (c) 2006, 2007, 2014 Michael Kerrisk <mtk.manpages@gmail.com>
.\"
.\" %%%LICENSE_START(VERBATIM)
.\" Permission is granted to make and distribute verbatim copies of this
.\" manual provided the copyright notice and this permission notice are
.\" preserved on all copies.
.\"
.\" Permission is granted to copy and distribute modified versions of this
.\" manual under the conditions for verbatim copying, provided that the
.\" entire resulting derived work is distributed under the terms of a
.\" permission notice identical to this one.
.\"
.\" Since the Linux kernel and libraries are constantly changing, this
.\" manual page may be incorrect or out-of-date.  The author(s) assume no
.\" responsibility for errors or omissions, or for damages resulting from
.\" the use of the information contained herein.  The author(s) may not
.\" have taken the same level of care in the production of this manual,
.\" which is licensed free of charge, as they might when working
.\" professionally.
.\"
.\" Formatted or processed versions of this manual, if unaccompanied by
.\" the source, must acknowledge the copyright and authors of this work.
.\" %%%LICENSE_END
.\"
.\" Modified by Michael Haardt <michael@moria.de>
.\" Modified 1993-07-24 by Rik Faith <faith@cs.unc.edu>
.\" Modified 1995-05-18 by Todd Larason <jtl@molehill.org>
.\" Modified 1997-01-31 by Eric S. Raymond <esr@thyrsus.com>
.\" Modified 1995-01-09 by Richard Kettlewell <richard@greenend.org.uk>
.\" Modified 1998-05-13 by Michael Haardt <michael@cantor.informatik.rwth-aachen.de>
.\" Modified 1999-07-06 by aeb & Albert Cahalan
.\" Modified 2000-01-07 by aeb
.\" Modified 2004-06-23 by Michael Kerrisk <mtk.manpages@gmail.com>
.\" 2007-06-08 mtk: Added example program
.\" 2007-07-05 mtk: Added details on underlying system call interfaces
.\"
.\"*******************************************************************
.\"
.\" This file was generated with po4a. Translate the source file.
.\"
.\"*******************************************************************
.TH STAT 2 "13 août 2020" Linux "Manuel du programmeur Linux"
.SH NOM
stat, fstat, lstat, fstatat \- Obtenir l'état d'un fichier (file status)
.SH SYNOPSIS
.nf
\fB#include <sys/types.h>\fP
\fB#include <sys/stat.h>\fP
\fB#include <unistd.h>\fP
.PP
\fBint stat(const char *\fP\fIchemin\fP\fB, struct stat *\fP\fIstatbuf\fP\fB);\fP
\fBint fstat(int \fP\fIfd\fP\fB, struct stat *\fP\fIstatbuf\fP\fB);\fP
\fBint lstat(const char *\fP\fIchemin\fP\fB, struct stat *\fP\fIstatbuf\fP\fB);\fP

\fB#include <fcntl.h>           \fP/* Définition des constantes AT_* */
\fB#include <sys/stat.h>\fP
.PP
\fBint fstatat(int \fP\fIdirfd\fP\fB, const char *\fP\fIchemin\fP\fB, struct stat *\fP\fIstatbuf\fP\fB,\fP
\fB            int \fP\fIattributs\fP\fB);\fP
.fi
.PP
.RS -4
Exigences de macros de test de fonctionnalités pour la glibc (consulter
\fBfeature_test_macros\fP(7))\ :
.RE
.PP
.ad l
\fBlstat\fP()\ :
.RS 4
.\"   _XOPEN_SOURCE\ &&\ _XOPEN_SOURCE_EXTENDED
/* Pour la glibc antérieure et égale à 2.19 */ _BSD_SOURCE
    || /* Depuis la glibc 2.20 */ _DEFAULT_SOURCE
    || _XOPEN_SOURCE\ >=\ 500
    || /* Depuis la glibc 2.10 : */ _POSIX_C_SOURCE\ >=\ 200112L
.RE
.PP
\fBfstatat\fP()\ :
.ad l
.RS 4
.PD 0
.TP  4
Depuis la glibc 2.10 :
_POSIX_C_SOURCE\ >=\ 200809L
.TP 
Avant la glibc 2.10 :
_ATFILE_SOURCE
.RE
.PD
.ad
.SH DESCRIPTION
Ces fonctions renvoient des renseignements sur le fichier indiqué, dans le
tampon pointé par \fIstatbuf\fP. Vous n'avez besoin d'aucun droit d'accès au
fichier pour obtenir les informations, mais vous devez \(em\ dans le cas de
\fBstat\fP(), \fBfstatat\fP() et \fBlstat\fP()\ \(em avoir le droit d'exécuter
(search) sur tous les répertoires mentionnés dans le \fIchemin\fP menant au
fichier.
.PP
\fBstat\fP() et \fBfstatat\fP() récupèrent des renseignements sur le fichier
pointé par \fIchemin\fP. Les différences de \fBfstatat\fP() sont décrites
ci\-dessous\ :
.PP
\fBlstat\fP() est identique à \fBstat\fP(), sauf que dans le cas où \fIchemin\fP est
un lien symbolique, auquel cas il renvoie des renseignements sur le lien
lui\-même plutôt que celui du fichier visé.
.PP
.\"
\fBfstat\fP() est identique à \fBstat\fP(), sauf que le fichier dont les
renseignements sont à récupérer est référencé par le descripteur de fichier
\fIfd\fP.
.SS "La structure stat"
Les trois fonctions renvoient une structure \fIstat\fP contenant les champs
suivants\ :
.PP
.in +4n
.EX
struct stat {
    dev_t     st_dev;         /* ID du périphérique contenant le fichier */
    ino_t     st_ino;         /* Numéro d’inœud                   */
    mode_t    st_mode;        /* Type de fichier et mode          */
    nlink_t   st_nlink;       /* Nombre de liens physiques        */
    uid_t     st_uid;         /* UID du propriétaire              */
    gid_t     st_gid;         /* GID du propriétaire              */
    dev_t     st_rdev;        /* ID du périphérique (si fichier spécial)  */
    off_t     st_size;        /* Taille totale en octets          */
    blksize_t st_blksize;     /* Taille de bloc pour E/S          */
    blkcnt_t  st_blocks;      /* Nombre de blocs de 512 o alloués */

    /* Depuis Linux 2.6, le noyau permet une précision à la
       nanoseconde pour les champs temporels suivants. Pour
       plus de précisions avant Linux 2.6, consultez les NOTES.   */

    struct timespec st_atim;  /* Heure dernier accès */
    struct timespec st_mtim;  /* Heure dernière modification */
    struct timespec st_ctim;  /* Heure dernier changement état */

#define st_atime st_atim.tv_sec      /* Rétrocompatibilité        */
#define st_mtime st_mtim.tv_sec
#define st_ctime st_ctim.tv_sec
};
.EE
.in
.PP
\fIRemarque\fP\ : l’ordre des champs de la structure \fIstat\fP varie un peu en
fonction des architectures. De plus, la définition ci\-dessus ne montre pas
les octets de remplissage qui peuvent être présents entre certains champs
sur plusieurs architectures. Consultez le code source de la glibc et du
noyau pour plus de précisions.
.PP
.\" Background: inode attributes are modified with i_mutex held, but
.\" read by stat() without taking the mutex.
\fINote\fP\ : pour des raisons de performance et de simplicité, différents
champs dans la structure \fIstat\fP peuvent contenir des informations d'état à
différents moments durant l'exécution de l'appel système. Par exemple, si
\fIst_mode\fP ou \fIst_uid\fP sont modifiés par un autre processus en appelant
\fBchmod\fP(2) ou \fBchown\fP(2), \fBstat\fP() peut renvoyer l'ancien \fIst_mode\fP en
même temps que le nouveau \fIst_uid\fP ou l'ancien \fIst_uid\fP en même temps que
le nouveau \fIst_mode\fP.
.PP
Les champs dans la structure \fIstat\fP ont la signification suivante :
.TP 
\fIst_dev\fP
Ce champ décrit le périphérique sur lequel ce fichier réside. Les macros
\fBmajor\fP(3) et \fBminor\fP(3) peuvent être utiles pour décomposer l'identifiant
de périphérique de ce champ.
.TP 
\fIst_ino\fP
Ce champs contient le nombre d'inœuds du fichier.
.TP 
\fIst_mode\fP
Ce champ contient le type et le mode du fichier. Consultez \fBinode\fP(7) pour
plus d'informations.
.TP 
\fIst_nlink\fP
Ce champ contient le nombre de liens physiques du fichier.
.TP 
\fIst_uid\fP
Ce champ contient l'identifiant de l'utilisateur propriétaire du fichier.
.TP 
\fIst_gid\fP
Ce champ contient l'identifiant du groupe propriétaire du fichier.
.TP 
\fIst_rdev\fP
Ce champ décrit le périphérique que ce fichier (inœud) représente.
.TP 
\fIst_size\fP
Ce champ indique la taille du fichier (s'il s'agit d'un fichier ordinaire ou
d'un lien symbolique) en octets. La taille d'un lien symbolique est la
longueur du nom de chemin qu'il vise, sans l’octet NULL final.
.TP 
\fIst_blksize\fP
Ce champ indique la taille de bloc «\ préférée\ » pour des E/S efficaces du
système de fichiers.
.TP 
\fIst_blocks\fP
Le champ indique le nombre de blocs de 512\ octets alloués au fichier. Cette
valeur peut être inférieure à \fIst_size\fP/512 si le fichier a des trous.
.TP 
\fIst_atime\fP
C'est l'heure du dernier accès aux données du fichier.
.TP 
\fIst_mtime\fP
C'est l'heure de la dernière modification des données du fichier.
.TP 
\fIst_ctime\fP
C'est l'horodatage de la dernière modification de l'état du fichier (heure
de la dernière modification de l'inœud).
.PP
.\"
Pour plus d'informations sur les champs ci\-dessus, consultez \fBinode\fP(7).
.SS fstatat()
L'appel système \fBfstatat\fP() est une interface plus générale pour accéder à
des informations de fichier qui peut encore fournir exactement le
comportement de chaque appel à \fBstat\fP(), \fBlstat\fP() et \fBfstat\fP().
.PP
Si le chemin donnée dans \fIchemin\fP est un chemin relatif, il est interprété
par rapport au répertoire référencé par le descripteur de fichier \fIdirfd\fP,
(plutôt que par rapport au répertoire courant du processus appelant, comme
avec \fBstat\fP() et \fBlstat\fP() pour un chemin relatif).
.PP
Si \fIchemin\fP est relatif, et si \fIdirfd\fP est la valeur spéciale \fBAT_FDCWD\fP,
\fIchemin\fP est interprété comme étant relatif au répertoire courant du
processus appelant, comme \fBstat\fP() et \fBlstat\fP().
.PP
Si \fIpathname\fP est absolu, alors \fIdirfd\fP est ignoré.
.PP
L'argument \fIattributs\fP est soit 0, soit un \fIOU\fP binaire «\ |\ » avec les
options suivantes\ :
.TP 
\fBAT_EMPTY_PATH\fP (depuis Linux 2.6.39)
.\" commit 65cfc6722361570bfe255698d9cd4dccaf47570d
.\" Before glibc 2.16, defining _ATFILE_SOURCE sufficed
Si \fIchemin\fP est une chaîne vide, opérer sur le fichier référencé par
\fIdirfd\fP (qui peut avoir été obtenu en utilisant \fBopen\fP(2) avec l’attribut
\fBO_PATH\fP). Dans ce cas, \fIdirfd\fP peut référencer tout type de fichier, pas
uniquement un répertoire et le comportement de \fBfstatat\fP() est similaire à
celui de \fBfstat\fP(). Si \fIdirfd\fP est \fBAT_FDCWD\fP, l’appel opère sur le
répertoire de travail actuel. Cet attribut est spécifique à Linux,
\fB_GNU_SOURCE\fP doit être définie pour obtenir sa définition.
.TP 
\fBAT_NO_AUTOMOUNT\fP (depuis Linux\ 2.6.38)
.\" commit 42f46148217865a545e129612075f3d828a2c4e4
Ne pas monter automatiquement le composant terminal («\ nom de base\ ») de
\fIchemin\fP s'il s'agit d'un répertoire qui est un point de montage
automatique. Cela permet à l'appelant de rassembler les attributs d'un point
de montage automatique (plutôt que l'emplacement qu'il monterait). Depuis
Linux\ 4.14, ne pas créer également d'instance d'un nom qui n'existe pas dans
un répertoire créé à la demande comme utilisé pour des mappages indirects
d'auto\-monteur. Cet attribut n'a aucun effet si le point de montage est déjà
attaché.
.IP
\fBstat\fP() et \fBlstat\fP() agissent comme si \fBAT_NO_AUTOMOUNT\fP était défini.
.IP
L'attribut \fBAT_NO_AUTOMOUNT\fP peut être utilisé dans les outils qui balayent
les répertoires pour éviter un montage automatique massif dans un répertoire
avec des points de montage automatiques.
.IP
.\" Before glibc 2.16, defining _ATFILE_SOURCE sufficed
Cet attribut est spécifique à Linux\ ; définir \fB_GNU_SOURCE\fP pour obtenir sa
définition.
.TP 
\fBAT_SYMLINK_NOFOLLOW\fP
Si \fIchemin\fP est un lien symbolique, ne pas le déréférencer, mais renvoyer
des informations sur le lien lui\(hymême, comme le fait \fBlstat\fP(2). (Par
défaut, \fBfstatat\fP() déréférence les liens symboliques, comme \fBstat\fP(2).)
.PP
Consultez \fBopenat\fP(2) pour une explication de la nécessité de \fBfstatat\fP().
.SH "VALEUR RENVOYÉE"
En cas de succès, zéro est renvoyé. En cas d'erreur, \fB\-1\fP est renvoyé et
\fIerrno\fP reçoit une valeur adéquate.
.SH ERREURS
.TP 
\fBEACCES\fP
La permission de parcours est refusée pour un des répertoires contenu dans
le chemin \fIchemin\fP. (Consultez aussi \fBpath_resolution\fP(7).)
.TP 
\fBEBADF\fP
Le descripteur de fichier \fIfd\fP est non valable.
.TP 
\fBEFAULT\fP
Un pointeur se trouve en dehors de l'espace d'adressage.
.TP 
\fBELOOP\fP
Trop de liens symboliques rencontrés dans le chemin d'accès.
.TP 
\fBENAMETOOLONG\fP
\fInom_chemin\fP est trop long.
.TP 
\fBENOENT\fP
Un composant du chemin d'accès \fIchemin\fP n'existe pas ou est un lien
symbolique pointant nulle part.
.TP 
\fBENOENT\fP
\fIchemin\fP est une chaîne vide et \fBAT_EMPTY_PATH\fP n'a pas été spécifié dans
\fIattributs\fP.
.TP 
\fBENOMEM\fP
Pas assez de mémoire (c'est\-à\-dire, mémoire du noyau).
.TP 
\fBENOTDIR\fP
Un élément du préfixe de \fIchemin\fP n'est pas un répertoire.
.TP 
\fBEOVERFLOW\fP
\fIchemin\fP ou \fIfd\fP font référence à un fichier dont la taille, l'inœud ou le
nombre de blocs ne peut pas être représenté respectivement avec le type
\fIoff_t\fP, \fIino_t\fP ou \fIblkcnt_t\fP. Cela peut arriver par exemple quand une
application compilée sans l'option \fI\-D_FILE_OFFSET_BITS=64\fP sur une
plate\-forme 32\ bits appelle \fBstat\fP() pour un fichier dont la taille est
supérieure à \fI(1<<31)\-1\fP octets.
.PP
Les erreurs supplémentaires suivantes peuvent également se produire pour
\fBfstatat\fP()\ :
.TP 
\fBEBADF\fP
\fIdirfd\fP n'est pas un descripteur de fichier valable.
.TP 
\fBEINVAL\fP
\fIflags\fP contient un attribut non valable.
.TP 
\fBENOTDIR\fP
\fIpathname\fP est relatif et \fIdirfd\fP est un descripteur de fichier faisant
référence à un fichier qui n'est pas un dossier.
.SH VERSIONS
\fBfstatat\fP() a été ajouté au noyau Linux dans sa version 2.6.16\ ; la glibc
le gère depuis la version\ 2.4.
.SH CONFORMITÉ
.\" SVr4 documents additional
.\" .BR fstat ()
.\" error conditions EINTR, ENOLINK, and EOVERFLOW.  SVr4
.\" documents additional
.\" .BR stat ()
.\" and
.\" .BR lstat ()
.\" error conditions EINTR, EMULTIHOP, ENOLINK, and EOVERFLOW.
\fBstat\fP(), \fBfstat\fP(), \fBlstat\fP()\ : SVr4, 4.3BSD, POSIX.1\-2001,
POSIX.1.2008.
.PP
\fBfstatat\fP()\ : POSIX.1\-2008.
.PP
D'après POSIX.1\-2001, \fBlstat\fP() sur un lien symbolique ne doit renvoyer des
informations valables que dans le champ \fIst_size\fP et le type de fichier du
champ \fIst_mode\fP de la structure \fIstat\fP. POSIX.1\-2008 renforce la
spécification, obligeant \fBlstat\fP() à renvoyer des informations valables
dans tous les champs à part les bits de mode dans \fIst_mode\fP.
.PP
L'utilisation des champs \fIst_blocks\fP et \fIst_blksize\fP risque d'être moins
portable (ils ont été introduits dans BSD. Leur interprétation change
suivant les systèmes, voire sur un même système s'il y a des montages NFS).
.SH NOTES
.SS "Champs temporels"
Les anciens noyaux et les anciennes normes ne permettaient pas d’utiliser
des champs temporels en nanosecondes. À la place, trois champs temporels
—\ \fIst_atime\fP, \fIst_mtime\fP et \fIst_ctime\fP\ — étaient utilisés pour \fItime_t\fP
qui enregistraient des horodatages avec une précision à la seconde.
.PP
.\"
Depuis le noyau\ 2.5.48, la structure \fIstat\fP permet une résolution d'une
nanoseconde pour les trois champs temporels. Les composants en nanosecondes
de chaque horodatage sont disponibles en utilisant des noms de la forme
\fIst_atim.tv_nsec\fP si des macros de test de fonctionnalités appropriées sont
définis. Les horodatages en nanosecondes ont été normalisés dans
POSIX.1\-2008 et, à partir de la version\ 2.12, la glibc expose les noms de
composants en nanosecondes si \fB_POSIX_C_SOURCE\fP est définie avec une valeur
supérieure ou égale à 200809L ou si \fB_XOPEN_SOURCE\fP est définie avec une
valeur supérieure ou égale à 700. Jusqu'à la version 2.19 comprise de la
glibc, les définitions des composants en nanosecondes sont aussi fixée si
\fB_BSD_SOURCE\fP ou \fB_SVID_SOURCE\fP est définie. Si aucune de ces macros
susmentionnées n'est définie, alors les valeurs en nanosecondes sont
exposées avec des noms de la forme \fIst_atimensec\fP.
.SS "différences entre bibliothèque C et noyau"
.\" See include/asm-i386/stat.h in the Linux 2.4 source code for the
.\" various versions of the structure definitions
Avec le temps, l'augmentation de la taille de la structure \fIstat\fP a conduit
à trois versions successives de \fBstat\fP()\ : \fIsys_stat\fP() (slot
\fI__NR_oldstat\fP), \fIsys_newstat\fP() (slot \fI__NR_stat\fP) et \fIsys_stat64\fP()
\fI__NR_stat64\fP) sur les plateformes 32\ bits telles que i386. Les deux
premières versions étaient déjà présentes dans Linux\ 1.0 (quoiqu'avec des
noms différents), la dernière a été ajoutée dans Linux\ 2.4. La même remarque
s'applique à \fBfstat\fP() et \fBlstat\fP().
.PP
Les versions internes du noyau de la structure \fIstat\fP traitées par les
différentes versions étaient respectivement\ :
.TP 
\fI__old_kernel_stat\fP
La structure d'origine avec des champs plutôt étroits et pas de remplissage.
.TP 
\fIstat\fP
Un champ plus grand \fIst_ino\fP et le remplissage ont été ajoutés dans
différentes parties de la structure pour autoriser un agrandissement futur.
.TP 
\fIstat64\fP
Un champ \fIst_ino\fP encore plus grand, des champs \fIst_uid\fP et \fIst_gid\fP plus
grands pour s'adapter à l'extension à 32\ bits des UID et GID dans Linux\ 2.4
et d'autres champs agrandis ainsi que plus de remplissage dans la
structure. (Divers octets de remplissage étaient finalement consommés dans
Linux\ 2.6 avec l'introduction d'ID de périphérique 32\ bits et des composants
en nanosecondes dans les champs d'horodatage.)
.PP
.\"
.\" A note from Andries Brouwer, July 2007
.\"
.\" > Is the story not rather more complicated for some calls like
.\" > stat(2)?
.\"
.\" Yes and no, mostly no. See /usr/include/sys/stat.h .
.\"
.\" The idea is here not so much that syscalls change, but that
.\" the definitions of struct stat and of the types dev_t and mode_t change.
.\" This means that libc (even if it does not call the kernel
.\" but only calls some internal function) must know what the
.\" format of dev_t or of struct stat is.
.\" The communication between the application and libc goes via
.\" the include file <sys/stat.h> that defines a _STAT_VER and
.\" _MKNOD_VER describing the layout of the data that user space
.\" uses. Each (almost each) occurrence of stat() is replaced by
.\" an occurrence of xstat() where the first parameter of xstat()
.\" is this version number _STAT_VER.
.\"
.\" Now, also the definitions used by the kernel change.
.\" But glibc copes with this in the standard way, and the
.\" struct stat as returned by the kernel is repacked into
.\" the struct stat as expected by the application.
.\" Thus, _STAT_VER and this setup cater for the application-libc
.\" interface, rather than the libc-kernel interface.
.\"
.\" (Note that the details depend on gcc being used as c compiler.)
La fonction d'enveloppe \fBstat\fP() de la glibc dissimule ces détails aux
applications invoquant la version la plus récente de l'appel système fourni
par le noyau, et recompresse l'information renvoyée si nécessaire pour les
binaires anciens.
.PP
Dans les systèmes modernes 64\ bits, la vie est plus simple\ : il n'y a qu'un
seul appel système \fBstat\fP() et le noyau s'occupe de la structure \fIstat\fP
qui contient des champs d'une taille suffisante.
.PP
.\" strace(1) shows the name "newfstatat" on x86-64
L'appel système sous\-jacent employé par la fonction d'enveloppe \fBfstatat()\fP
de la glibc s'appelle en fait \fBfstatat64\fP() ou, sur certaines
architectures, \fBnewfstatat\fP().
.SH EXEMPLES
Le programme suivant appelle \fBlstat\fP() et affiche certains champs
sélectionnés dans la structure \fIstat\fP renvoyée.
.PP
.EX
#include <sys/types.h>
#include <sys/stat.h>
#include <stdint.h>
#include <time.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/sysmacros.h>

int
main(int argc, char *argv[])
{
    struct stat sb;

    if (argc != 2) {
        fprintf(stderr, "Usage: %s <pathname>\en", argv[0]);
        exit(EXIT_FAILURE);
    }

    if (lstat(argv[1], &sb) == \-1) {
        perror("lstat");
        exit(EXIT_FAILURE);
    }

    printf("ID du périphérique contenant :  [%jx,%jx]\en",
            (uintmax_t) major(sb.st_dev),
            (uintmax_t) minor(sb.st_dev));

    printf("Type de fichier\ :                  ");

    switch (sb.st_mode & S_IFMT) {
    case S_IFBLK:  printf("périphérique bloc\en");       break;
    case S_IFCHR:  printf("périphérique caractère\en");  break;
    case S_IFDIR:  printf("répertoire\en");              break;
    case S_IFIFO:  printf("FIFO/tube\en");               break;
    case S_IFLNK:  printf("lien symbolique\en");         break;
    case S_IFREG:  printf("fichier ordinaire\en");       break;
    case S_IFSOCK: printf("socket\en");                  break;
    default:       printf("inconnu\ ?\en");               break;
    }

    printf("Numéro d'inœud\ :            %ju\en", (uintmax_t) sb.st_ino);

    printf("Mode:                     %jo (octal)\en",
            (uintmax_t) sb.st_mode);

    printf("Nombre de liens\ :        %ju\en", (uintmax_t) sb.st_nlink);
    printf("Propriétaire\ :           UID=%ju   GID=%ju\en",
            (uintmax_t) sb.st_uid, (uintmax_t) sb.st_gid);

    printf("Taille de bloc d'E/S\ :     %jd octets\en",
            (intmax_t) sb.st_blksize);
    printf("Taille du fichier\ :        %jd octets\en",
            (intmax_t) sb.st_size);
    printf("Blocs alloués\ :            %jd\en",
            (intmax_t) sb.st_blocks);

    printf("Dernier changement d'état\ :        %s", ctime(&sb.st_ctime));
    printf("Dernier accès au fichier\ :         %s", ctime(&sb.st_atime));
    printf("Dernière modification du fichier\ : %s", ctime(&sb.st_mtime));

    exit(EXIT_SUCCESS);
}
.EE
.SH "VOIR AUSSI"
\fBls\fP(1), \fBstat\fP(1), \fBaccess\fP(2), \fBchmod\fP(2), \fBchown\fP(2),
\fBreadlink\fP(2), \fBstatx\fP(2), \fButime\fP(2), \fBcapabilities\fP(7), \fBinode\fP(7),
\fBsymlink\fP(7)
.SH COLOPHON
Cette page fait partie de la publication\ 5.10 du projet \fIman\-pages\fP
Linux. Une description du projet et des instructions pour signaler des
anomalies et la dernière version de cette page peuvent être trouvées à
l'adresse \%https://www.kernel.org/doc/man\-pages/.
.PP
.SH TRADUCTION
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>
.
.PP
Cette traduction est une documentation libre ; veuillez vous reporter à la
.UR https://www.gnu.org/licenses/gpl-3.0.html
GNU General Public License version 3
.UE
concernant les conditions de copie et 
de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.
.PP
Si vous découvrez un bogue dans la traduction de cette page de manuel, 
veuillez envoyer un message à
.MT debian-l10n-french@lists.debian.org
.ME .