Index général des pages de man   Index Section man 3   Table des Matières de mkstemp   Imprime la page de man mkstemp en mode Texte   Recherche dans les pages de man   Page de man en français      Fonctions des bibliothèques (section 3)

mkstemp

 
  

Nom

mkstemp - Créér un fichier temporaire unique.

Synopsis


#include <stdlib.h>
int mkstemp (char *template);

Description

La fonction mkstemp() engendre un nom de fichier temporaire unique, à partir du motif template. Les six derniers caractères de template doivent être XXXXXX et ils seront alors remplacés par une chaîne rendant ce nom de fichier unique.

Comme il sera modifié, template ne doit pas être une chaîne constante, mais comme un tableau de caractères.

Le fichier est ouvert en mode lecture/écriture et est créé avec les permissions d'accès 0666 (glibc 2.0.6 et précédentes) ou 0600 (glibc 2.0.7 et ultérieures).

Le fichier est ouvert avec l'attribut O_EXCL, garantissant que nous soyons le seul propriétaire du fichier.

Valeur Renvoyée

La fonction mkstemp() renvoie le descripteur du fichier temporaire créé ou -1 en cas d'erreur.

Erreurs

EINVAL
Les 6 derniers caractères de template ne sont pas XXXXXX. Dans ce cas, template n'est pas modifié.
EEXIST
Impossible de créer un nom de fichier unique. Le contenu du fichier est imprévisible.

Bogues

L'ancien comportement (créer les fichiers avec le mode 0666) est un trou de sécurité potentiel, surtout depuis que les autres dérivés Unix utilisent le mode 0600 et que quelqu'un risque d'oublier ce détail en effectuant un portage de programme.

Conformité

BSD 4.3

Note

Le prototype se trouve dans <unistd.h> pour libc4, libc5; glibc1. Glibc2 suit les spécifications Single Unix et place le prototype dans <stdlib.h>.

Voir Aussi

mktemp(3) , tmpnam(3) , tempnam(3) , tmpfile(3)

Traduction

Christophe Blaess, 1997.


Table des matières


Haut de page

© 1996-2000 Adaptation française "Christophe Blaess"