zion - mktemp
Nom
mktemp - Créer un nom de fichier temporaire unique.
Résumé
.nf #include <stdlib.h> char *mktemp (char * template ); .fi
Description
La fonction mktemp() crée un nom de fichier temporaire unique, en utilisant le motif template. Les 6 derniers caractères de template doivent être XXXXXX, ils seront remplacés par une chaîne rendant le nom de fichier unique. Comme il sera modifié, template ne doit pas être une chaîne constante, mais un tableau de caractères.
Valeur renvoyée
La fonction mktemp() renvoie NULL en cas d'erreur ou un pointeur sur template sinon. En cas d'échec template est une chaîne vide.
Erreurs
EINVAL
Les 6 derniers caractères de template ne sont pas XXXXXX. |
Conformité
BSD 4.3. POSIX recommande tmpnam ().
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> .
Bugs
Evitez d'utiliser mktemp(). Certaines implémentations suivent BSD 4.3, et remplacent XXXXXX par le numéro de processus et une lettre, ce qui donne 26 noms différents possibles. Comme d'une part ces noms sont faciles à deviner, et d'autre part il existe une condition de concurrence entre le test d'existence du nom et l'ouverture du fichier, chaque invocation de mktemp() est un trou de sécurité. Les conditions de concurrences sont évitées par mkstemp (3).
Voir aussi
mkstemp (3), tempnam (3), tmpfile (3). tmpnam (3),
Traduction
Christophe Blaess, 1996-2003.
Poster un commentaire