FCHMODAT
Section : Manuel du programmeur Linux (
2)
Mise à jour de la version anglaise : 5 mai 2006
Index
Menu principal
NOM
fchmodat - Modifier les permissions d'un fichier relativement à un descripteur de fichier de répertoire
SYNOPSIS
#define _ATFILE_SOURCE
#include <fcntl.h> /* Définition des constantes AT_* */
#include <sys/stat.h>
int fchmodat(int dirfd, const char *pathname, mode_t mode, int flags);
DESCRIPTION
L'appel système
fchmodat()
opère de la même manière que
chmod(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é par rapport au répertoire référencé
par le descripteur de fichier
dirfd
(plutôt que par rapport au répertoire de travail courant du processus
appelant, comme cela est fait par
chmod(2)
pour un chemin relatif).
Si le chemin fourni dans
pathname
est relatif et si
dirfd
est la valeur spéciale
AT_FDCWD,
pathname
est interprété relativement au répertoire de travail courant
du processus appelant (comme avec
chmod(2)).
Si le chemin fourni dans
pathname
est absolu,
dirfd
est ignoré.
flags
peut être soit 0, soit inclure l'attribut suivant :
- AT_SYMLINK_NOFOLLOW
-
Si
pathname
est un lien symbolique, ne pas le déréférencer :
à la place, opérer sur le lien lui-même.
Cet attribut n'est actuellement pas implémenté.
VALEUR RENVOYÉE
S'il réussit,
fchmodat()
renvoie 0.
S'il échoue, il renvoie -1 et renseigne
errno
en conséquence.
ERREURS
Les mêmes erreurs qui apparaissent pour
chmod(2)
peuvent se produire pour
fchmodat().
Les erreurs supplémentaires suivantes peuvent également apparaître pour
fchmodat() :
- 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.
- ENOTSUP
-
flags
spécifiait
AT_SYMLINK_NOFOLLOW
qui n'est pas pris en charge.
VERSIONS
fchmodat()
a été ajouté au noyau Linux dans sa version 2.6.16.
CONFORMITÉ
Cet appel système n'est pas standard mais est proposé pour une inclusion
dans une prochaine révision de POSIX.1.
NOTES
Voir
openat(2)
pour des explications sur la nécessité de
fchmodat().
VOIR AUSSI
chmod(2),
openat(2),
path_resolution(7)
symlink(7)
TRADUCTION
Ce document est une traduction réalisée par Alain Portal
<aportal AT univ-montp2 DOT fr> le 8 août 2006
et révisée le 4 juillet 2008.
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 fchmodat ».
N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute
erreur dans cette page de manuel.
Index
- NOM
-
- SYNOPSIS
-
- DESCRIPTION
-
- VALEUR RENVOYÉE
-
- ERREURS
-
- VERSIONS
-
- CONFORMITÉ
-
- NOTES
-
- VOIR AUSSI
-
- TRADUCTION
-
Dernière mise à jour : 4 juillet 2008