#include <stdlib.h> char *mktemp(char *template);
char *mkdtemp(char *template);
The mktemp() function replaces the contents of the string pointed to by template with a unique file name, and returns template. The string in template should look like a file name with six trailing 'X's. The mktemp() function will replace the 'X's with a character string that can be used to create a unique file name.
The mkdtemp() function makes the same replacement to the template as in mktemp() and creates the template directory using mkdir(2) , passing a mode argument of 0700.
The mktemp() function returns the pointer template. If a unique name cannot be created, template points to a null string.
Upon successful completion, mkdtemp() returns the pointer template. If a unique directory cannot be created, mkdtemp() returns a null pointer.
The mkdtemp() function can set errno to the same values as lstat(2) and mkdir(2).
The following example replaces the contents of the “template” string with a 10-character filename beginning with the characters “file” and returns a pointer to the “template” string that contains the new filename.
#include <stdlib.h> ... char *template = "/tmp/fileXXXXXX"; char *ptr; ptr = mktemp(template);
Between the time a pathname is created and the file opened, it is possible for some other process to create a file with the same name. The tmpfile(3C) and mkstemp(3C) functions avoid this problem and are preferred over this function.
See attributes(5) for descriptions of the following attributes:
|
lstat(2), mkdir(2), mkstemp(3C), tmpfile(3C), tmpnam(3C), attributes(5), standards(5)