fstatat

Autres langues

Langue: fr

Version: 30 avril 2006 (mandriva - 01/05/08)

Section: 2 (Appels système)

NOM

fstatat - Obtenir l'état d'un fichier relativement à un descripteur de fichier de répertoire

SYNOPSIS

 #define _ATFILE_SOURCE
 #include <sys/stat.h>
 
 int fstatat(int dirfd, const char *pathname, struct stat *buf,
             int flags);
 

DESCRIPTION

L'appel système fstatat() opère de la même manière que stat(2), excepté les différences décrites dans cette page de manuel.

Si le nom de chemin fourni dans pathname est relatif, il est interprété relativement au répertoire référencé par le descripteur de fichier dirfd (plutôt que relativement au répertoire de travail courant du processus appelant, comme cela est fait par stat(2) pour un chemin relatif).

Si le chemin fourni dans pathname est relatif et que dirfd est la valeur spéciale AT_FDCWD, pathname est interprété relativement au répertoire de travail courant du processus appelant comme avec stat(2).

Si le chemin fourni dans pathname est absolu, dirfd est ignoré.

flags peut être soit 0, soit inclure les attributs suivants :

AT_SYMLINK_NOFOLLOW
Si pathname est un lien symbolique, ne pas le déréférencer : à la place, renvoyer l'information du lien lui-même, comme lstat(2). (Par défaut, fstatat() déréférence les liens symboliques, comme stat(2).)

VALEUR RENVOYÉE

S'il réussit, fstatat() renvoie 0. S'il échoue, il renvoie -1 et écrit errno en conséquence.

ERREURS

Les mêmes erreurs qui apparaissent pour stat(2) peuvent apparaître pour fstatat(). Les erreurs supplémentaires suivantes peuvent également apparaître pour fstatat() :
EBADF
dirfd n'est pas un descripteur de fichier valide.
EINVAL
Un attribut invalide a été spécifié dans flags.
ENOTDIR
pathname est un chemin relatif et dirfd est un descripteur de fichier se référant à un fichier autre qu'un répertoire.

VERSIONS

fstatat() a été ajouté à Linux dans le noyau 2.6.16.

CONFORMITÉ

Cet appel système n'est pas standard mais est proposé pour une inclusion dans une future révision de POSIX.1. Un appel système similaire existe sur Solaris.

NOTES

Voir openat(2) pour des explications sur la nécessité de fstatat().

VOIR AUSSI

openat(2), stat(2), path_resolution(7)

TRADUCTION

Ce document est une traduction réalisée par Alain Portal <aportal AT univ-montp2 DOT fr> le 4 août 2006 et révisée le 26 novembre 2007.

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 fstatat ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.