UNLINKAT
Section : Manuel du programmeur Linux (
2)
Mise à jour de la version anglaise : 10 avril 2006
Index
Menu principal
NOM
unlinkat - Supprimer une entrée de répertoire relativement à un descripteur de fichier de répertoire
SYNOPSIS
#define _ATFILE_SOURCE
#include <fcntl.h>
int unlinkat(int dirfd, const char *pathname, int flags);
DESCRIPTION
L'appel système
unlinkat()
opère de la même manière que
unlink(2)
ou
rmdir(2)
(suivant que
flags
inclus ou non l'attribut
AT_REMOVEDIR)
excepté les différences décrites dans cette page de manuel.
Si
pathname
est un chemin 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
unlink(2)
et
rmdir(2)
pour un chemin relatif).
Si
pathname
est relatif et que
dirfd
est la valeur spéciale
AT_FDCWD,
pathname
est interprété par rapport au répertoire de travail courant
du processus appelant (comme avec
unlink(2)
et
rmdir(2)).
Si
pathname
est absolu,
dirfd
est ignoré.
flags
est un masque de bits qui peut valoir soit 0, soit le résultat
d'un OU binaire avec d'autres attributs qui contrôlent l'action de
unlinkat().
Actuellement, il n'existe qu'un seul attribut :
- AT_REMOVEDIR
-
Par défaut,
unlinkat()
effectue l'équivalent de
unlink(2)
sur
pathname.
Si l'attribut
AT_REMOVEDIR
est spécifié, il effectue l'équivalent de
rmdir(2)
sur
pathname.
VALEUR RENVOYÉE
Cet appel système renvoie 0 s'il réussit et -1 s'il échoue, auquel cas
errno
contient le code d'erreur.
ERREURS
Les erreurs qui apparaissent pour
unlink(2)
et
rmdir(2)
peuvent se produire pour
unlinkat().
Les erreurs supplémentaires suivantes peuvent également se produire pour
unlinkat() :
- EBADF
-
dirfd
n'est pas un descripteur de fichier valide.
- EINVAL
-
Une valeur d'attribut invalide a été spécifiée dans
flags.
- ENOTDIR
-
pathname
est relatif et
dirfd
est un descripteur de fichier se référant à un fichier
autre qu'un répertoire.
VERSIONS
unlinkat()
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.
Un appel système similaire existe sous Solaris.
NOTES
Voir
openat(2)
pour des explications sur la nécessité de
unlinkat().
VOIR AUSSI
openat(2),
rmdir(2),
unlink(2),
path_resolution(7)
TRADUCTION
Ce document est une traduction réalisée par Alain Portal
<aportal AT univ-montp2 DOT fr> le 31 juillet 2006
et révisée le 23 juin 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 unlinkat ».
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 : 23 juin 2008