#define _ATFILE_SOURCE #include <fcntl.h> /* Définition des constantes AT_* */ #include <unistd.h> int linkat(int olddirfd, const char *oldpath, int newdirfd, const char *newpath, int flags);
Si le chemin fourni dans oldpath est relatif, il est interprété par rapport au répertoire référencé par le descripteur de fichier olddirfd (plutôt que par rapport au répertoire de travail courant du processus appelant, comme cela est fait par link(2) pour un chemin relatif).
Si oldpath est relatif et si olddirfd a la valeur spéciale AT_FDCWD, oldpath est interprété relativement au répertoire de travail courant du processus appelant (comme avec link(2)).
Si oldpath est un chemin absolu, olddirfd est ignoré.
L'interprétation de newpath est identique à celle de oldpath, excepté que ce nom de chemin relatif est interprété par rapport au répertoire référencé par le descripteur de fichier newdirfd.
Par défaut, linkat() ne déréférence pas oldpath s'il s'agit d'un lien symbolique (comme avec link(2)). Depuis Linux 2.6.18, l'attribut AT_SYMLINK_FOLLOW peut être spécifié dans flags de sorte que oldpath puisse être déréférencé s'il s'agit d'un lien symbolique. Avant le noyau 2.6.18, l'argument flags n'était pas utilisé et devait être spécifié à 0.
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 2 juillet 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 linkat ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.
Dernière mise à jour : 2 juillet 2008