RENAMEAT

Section : Manuel du programmeur Linux (2)
Mise à jour de la version anglaise : 10 avril 2006
Index Menu principal  

NOM

renameat - Renommer un fichier relativement à des descripteurs de fichier de répertoire  

SYNOPSIS

#define _ATFILE_SOURCE
#include <fcntl.h>           /* Définition des constantes AT_* */
#include <stdio.h>

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

DESCRIPTION

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

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 rename(2) pour un chemin relatif).

Si oldpath est relatif et si olddirfd a la valeur spéciale AT_FDCWD, oldpath est interprété par rapport au répertoire de travail courant du processus appelant (comme avec rename(2)).

Si 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é par rapport au répertoire référencé par le descripteur de fichier newdirfd.  

VALEUR RENVOYÉE

S'il réussit, renameat() renvoie 0. S'il échoue, il renvoie -1 et errno contient le code de l'erreur.  

ERREURS

Les mêmes erreurs qui apparaissent pour rename(2) peuvent se produire pour renameat(). Les erreurs supplémentaires suivantes peuvent également se produire pour renameat() :
EBADF
olddirfd ou newdirfd n'est pas un descripteur de fichier valide.
ENOTDIR
oldpath est 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.
 

VERSIONS

renameat() a été ajouté au noyau Linux dans sa version 2.6.16.  

CONFORMITÉ

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

NOTES

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

VOIR AUSSI

openat(2), rename(2), path_resolution(7)  

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

 

Index

NOM
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ERREURS
VERSIONS
CONFORMITÉ
NOTES
VOIR AUSSI
TRADUCTION

Dernière mise à jour : 23 juin 2008