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