Linux

CentOS 5.3

linkat(2)


LINKAT

NOM

linkat − Créer un lien vers un fichier relativement à des descripteurs de fichier de répertoire.

SYNOPSIS

#include <unistd.h>

int linkat(int olddirfd, const char *oldpath,
           int newdirfd, const char *newpath, int flags);

DESCRIPTION

L’appel système linkat() opère de la même manière que link(2), excepté les différences décrites dans cette page de manuel.

Si le nom de chemin fourni dans oldpath est relatif, il est interprété relativement au répertoire référencé par le descripteur de fichier olddirfd (plutôt que relativement au répertoire de travail courant du processus appelant, comme cela est fait par link(2) pour un chemin relatif).

Si le chemin fourni dans oldpath est relatif et que olddirfd est 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 le chemin fourni dans oldpath est absolu, olddirfd est ignoré.

L’interprétation de newpath est la même que oldpath, excepté que ce nom de chemin relatif est interprété relativement au répertoire référencé par le descripteur de fichier newdirfd.

L’argument flags n’est actuellement pas utilisé et doit être spécifié à 0.

VALEUR RENVOYÃE

S’il réussit, linkat() renvoie 0. S’il échoue, il renvoie −1 et écrit errno en conséquence.

ERREURS

Les mêmes erreurs qui apparaissent pour link(2) peuvent apparaître pour linkat(). Les erreurs supplémentaires suivantes peuvent également apparaître pour linkat() :

EBADF

olddirfd ou newdirfd n’est pas un descripteur de fichier valide.

ENOTDIR

oldpath est un chemin relatif et olddirfd est un descripteur de fichier se référant à un fichier autre qu’un répertoire ; il en est de même pour newpath et newdirfd.

NOTES

Voir openat(2) pour des explications sur la nécessité de linkat().

CONFORMITÃ

Cet appel système n’est pas standard mais est proposé pour une inclusion dans une future révision de POSIX.1.

VERSIONS

linkat() a été ajouté à Linux dans le noyau 2.6.16.

VOIR AUSSI

link(2), openat(2), path_resolution(2)

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


linkat(2)