Linux

CentOS 5.3

listxattr(2)


LISTXATTR

NOM

listxattr, llistxattr, flistxattr − Lister les noms des attributs étendus.

SYNOPSIS

#include <sys/types.h>
#include <attr/xattr.h>

ssize_t listxattr (const char *chemin, char *liste, size_t taille);
ssize_t llistxattr (const char *chemin, char *liste, size_t taille);
ssize_t flistxattr (int descripteur, char *liste, size_t taille);

DESCRIPTION

Les attributs étendus sont des paires nom:valeur associées aux i−noeuds (fichiers, répertoires, liens symboliques, etc). Ce sont des extensions des attributs normaux qui sont associés avec tous les i−noeuds du système (les informations renvoyées par stat(2)). Une description complète des concepts d’attributs étendus est disponible dans attr(5).

listxattr() récupère la liste des attributs étendus associé avec le chemin indiqué du système de fichier. La liste est l’ensemble des noms (terminés par NULL), l’un après l’autre. Les noms des attributs étendus auxquels le processus appelant n’a pas accès peuvent être omis dans la liste. La longueur de la liste de noms d’attributs est renvoyée.

llistxattr() est identique à listxattr(), sauf dans le cas d’un lien symbolique, où il renvoie la liste des noms des attributs associés au lien lui-même et non au fichier auquel il se réfère.

flistxattr() est identique à listxattr(), sauf que le fichier ouvert associé au descripteur (fourni par open(2)) est interrogé à la place du chemin.

Le nom d’un attribut étendu est une simple chaîne terminée par un octet nul. Le nom inclut un préfixe d’espace de noms − il peut y avoir plusieurs espaces de noms disjoints associés avec un i−noeud donné.

Un tampon vide, de taille nulle, peut être transmis à ses appels, pour qu’ils renvoient la taille actuelle de la liste des noms d’attributs étendus, pour estimer la taille de tampon nécessaire pour contenir la liste des noms.

EXEMPLE

La liste est noms est renvoyée sous forme de table de chaînes de caractères terminées par un octet nul, sans ordre particuler, les noms des attributs étant séparés par un caractère nul, ainsi :

user.name1\0system.name1\0user.name2\0

Les systèmes comme ext2, ext3, et XFS qui implémentent les ACLs POSIX en utilisant les attributs étendus peuvent renvoyer une liste comme celle-ci :

system.posix_acl_access\0system.posix_acl_default\0

VALEUR RENVOYÃE

S’ils réussissent, ces appels renvoient un nombre positif correspondant à la taille de la liste de noms d’attributs. En cas d’échec, ils renvoient −1 et remplissent errno avec un code d’erreur.

Si la taille du tampon pour la liste est trop petite pour contenir le résultat, errno sera rempli avec ERANGE.

Si les attributs étendus ne sont pas suportés par le système de fichiers ou le noyau errno contient ENOTSUP.

Les erreurs documentées pour l’appel système stat(2) sont également applicables ici.

CONFORMITÃ

Ces appels sont spécifiques à Linux.

AUTEURS

Andreas Gruenbacher, <a.gruenbacher@computer.org> et l’équipe de développement SGI XFS, <linux-xfs@oss.sgi.com>. Envoyez les rapports de bogues et les commentaires (en anglais) à ces adresses. getfattr(1), setfattr(1), getxattr(2), open(2), removexattr(2), setxattr(2), stat(2), attr(5)

TRADUCTION

Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 25 juillet 2003 et révisée le 14 août 2006.

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


listxattr(2)