realpath(3) Library Functions Manual realpath(3) NOM realpath - Renvoyer le chemin d'accs absolu BIBLIOTHEQUE Bibliotheque C standard (libc, -lc) SYNOPSIS #include #include char *realpath(const char *restrict chemin, char *restrict chemin_rsolu); Exigences de macros de test de fonctionnalites pour la glibc (consulter feature_test_macros(7)) : realpath(): _XOPEN_SOURCE >= 500 || /* glibc >= 2.19 : */ _DEFAULT_SOURCE || /* glibc <= 2.19 : */ _BSD_SOURCE DESCRIPTION realpath dveloppe tous les liens symboliques, et rsout les rfrences /./ , /../ ainsi que les caractres / supplmentaires dans la chane, termine par un caractre NULL, pointe par chemin pour produire une forme canonique du chemin absolu. Le chemin rsultant est stock sous la forme d'une chane termine par un caractre NULL pouvant contenir jusqu' PATH_MAX octets, dans le tampon point par chemin_rsolu. Le chemin rsultant ne traversera plus de liens symboliques et ne contiendra plus d'lments /./ ou /../ . Si chemin_rsolu est NULL, alors realpath() utilise malloc(3) pour allouer un tampon allant jusqu' PATH_MAX octets pour contenir le chemin trouv, et retourne un pointeur sur ce tampon. L'appelant doit librer ce tampon avec free(3). VALEUR RENVOYEE S'il n'y a pas d'erreur, realpath() renvoie un pointeur sur chemin_rsolu. Sinon elle renvoie NULL, le contenu de chemin_rsolu n'est pas dfini et errno prend la valeur du code d'erreur. ERREURS EACCES La permission de recherche ou de lecture n'est pas accorde pour un composant du chemin d'accs. EINVAL chemin est NULL (avant la glibc2.3, cette erreur est aussi renvoye si chemin_rsolu est NULL). EIO Une erreur d'entre-sortie est survenue lors de la lecture sur le systme de fichiers. ELOOP Trop de liens symboliques ont ete rencontres en parcourant le chemin. ENAMETOOLONG Un lment du chemin d'accs dpasse NAME_MAX caractres de long ou le chemin d'accs complet dpasse PATH_MAX caractres. ENOENT Le fichier indique n'existe pas. ENOMEM Plus assez de memoire. ENOTDIR Un element du chemin d'acces n'est pas un repertoire. ATTRIBUTS Pour une explication des termes utilises dans cette section, consulter attributes(7). +---------------------------------+--------------------------+---------+ |Interface | Attribut | Valeur | +---------------------------------+--------------------------+---------+ |realpath() | Securite des threads | MT-Safe | +---------------------------------+--------------------------+---------+ VERSIONS Extensions GNU Si l'appel choue avec EACCES ou ENOENT alors que chemin_rsolu n'est pas NULL, alors le prfixe de chemin qui n'est pas lisible ou qui n'existe pas est renvoy dans chemin_rsolu. STANDARDS POSIX.1-2008. HISTORIQUE 4.4BSD, POSIX.1-2001, Solaris. POSIX.1 indique que le comportement dans le cas o chemin_rsolu est NULL dpend de l'implmentation. POSIX.1-2008 spcifie le comportement dcrit dans cette page. Dans 4.4BSD et Solaris, la limite de longueur du chemin est MAXPATHLEN (dans ). SUSv2 conseille PATH_MAX et NAME_MAX, dans ou fournis par pathconf(3). Un fragment de code typique serait #ifdef PATH_MAX path_max = PATH_MAX; #else path_max = pathconf(path, _PC_PATH_MAX); if (path_max <= 0) path_max = 4096; #endif (Mais voir quand mme la section des BOGUES.) BOGUES La version du standard POSIX.1-2001 de cette fonctions est errone par construction, car elle ne permet pas de connatre la taille ncessaire pour le tampon de sortie chemin_rsolu. D'aprs POSIX.1-2001, un tampon de taille PATH_MAX suffit, mais PATH_MAX n'est pas ncessairement une constante dfinie et peut tre obtenue avec pathconf(3). En outre, interroger pathconf(3) n'aide pas vraiment, car d'une part POSIX prvient que les rsultats de pathconf(3) peuvent tre immenses et inappropris pour allouer de la mmoire et d'autre part pathconf(3) peut renvoyer -1 indiquant que PATH_MAX est illimit. La fonctionnalit chemin_rsolu == NULL, non standard dans POSIX.1-2008, permet d'viter ces problmes. VOIR AUSSI realpath(1), readlink(2), canonicalize_file_name(3), getcwd(3), pathconf(3), sysconf(3) TRADUCTION La traduction francaise de cette page de manuel a ete creee par #-#-#-#-# min-002-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Jean-Philippe MENGUAL , Jean-Pierre Giraud , #-#-#-#-# min-003-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Jean-Philippe MENGUAL , Jean-Pierre Giraud , #-#-#-#-# min-004-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Jean-Philippe MENGUAL , Jean-Pierre Giraud , #-#-#-#-# min-010-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Thomas Vincent , #-#-#-#-# min-020-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Jean-Philippe MENGUAL , Jean-Pierre Giraud , #-#-#-#-# min-100-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Jean-Philippe MENGUAL , Jean-Pierre Giraud et # Cette traduction est une documentation libre ; veuillez vous reporter a la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITE LEGALE. Si vous decouvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message a . Pages du manuel de Linux 6.06 31 octobre 2023 realpath(3)