Rechercher une page de manuel
link
Langue: fr
Version: 23 juin 2004 (mandriva - 01/05/08)
Section: 2 (Appels système)
NOM
link - Crée un nouveau nom pour un fichierSYNOPSIS
#include <unistd.h>int link (const char *oldpath, const char *newpath);
DESCRIPTION
link() crée un nouveau lien (aussi appelé lien matériel ou hard link) sur un fichier existant.Si newpath existe, il ne sera pas ecrasé.
Ce nouveau nom pourra être utilisé exactement comme l'ancien quelque soit l'opération. Les deux noms se réfèrent au même fichier (et ont donc les mêmes permissions et propriétaire) et il est impossible de déterminer quel nom était l'original.
VALEUR RENVOYÉE
En cas de réussite 0 est renvoyé, en cas d'échec -1 est renvoyé, et errno contient le code d'erreur.ERREURS
- EACCES
- L'écriture dans le répertoire contenant newpath n'est pas autorisé pour l'UID effectif du processus, ou l'un des répertoires de oldpath ou newpath ne permet pas le parcours (exécution).
- EEXIST
- newpath existe déjà.
- EFAULT
- oldpath ou newpath pointent en dehors de l'espace d'adressage accessible.
- EIO
- Une erreur d'entrée-sortie bas niveau s'est produite.
- ELOOP
- oldpath ou newpath contiennent une référence circulaire (à travers un lien symbolique).
- EMLINK
- Le fichier référencé par oldpath possède déjà le nombre maximal de liens.
- ENAMETOOLONG
- oldpath ou newpath sont trop longs.
- ENOENT
- Un répertoire contenu dans oldpath ou newpath n'existe pas, ou est un lien symbolique pointant nulle part.
- ENOMEM
- pas assez de mémoire pour le noyau.
- ENOSPC
- Le support du système de fichiers ne dispose pas d'assez de place pour un nouveau point d'entrée dans le répertoire.
- ENOTDIR
- Un élément du chemin d'accès oldpath ou newpath n'est pas réellement un répertoire.
- EPERM
- oldpath est un répertoire.
- EPERM
- Le système de fichiers contenant oldpath et newpath ne permet pas la création de liens matériels.
- EROFS
- Le fichier se trouve sur un système de fichiers en lecture seule.
- EXDEV
- oldpath et newpath ne résident pas sur le même système de fichiers monté. (Linux permet à un système de fichiers d'être monté en plusieurs endroits, mais link(2) ne traverse pas les différents points de montage, même si le même système de fichier est monté sur chacun d'eux.)
CONFORMITÉ
SVr4, BSD 4.3, POSIX.1-2001 (excepté ce qui est noté plus haut).NOTES
Les liens matériels créés par link(), ne peuvent pas s'étendre sur plusieurs systèmes de fichiers. On peut utiliser plutôt symlink(2) si ceci est nécessaire.POSIX.1-2001 dit que link() devrait déréférencer oldpath si c'est un lien symbolique. Toutefois, Linux ne le fait pas : si oldpath est un lien symbolique, newpath est créé comme un lien (matériel) vers le même fichier lien symbolique (c'est-à-dire, newpath devient un lien symbolique vers le même fichier auquel oldpath fait référence). Certaines autres implémentations se comportent de la même manière que Linux.
BOGUES
Sur les systèmes de fichiers NFS, le code de retour peut être faux si le serveur NFS a créé correctement le lien mais s'est arrêté avant de donner le code de retour. Utiliser dans ce cas stat(2) pour vérifier si le lien a été effectivement créé.VOIR AUSSI
ln(1), linkat(2), open(2), rename(2), stat(2), symlink(2), unlink(2), path_resolution(7)TRADUCTION
Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 10 octobre 1996 et révisée le 28 novembre 2007.
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 link ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.
Contenus ©2006-2024 Benjamin Poulain
Design ©2006-2024 Maxime Vantorre