|Skip Navigation Links|
|Exit Print View|
|man pages section 3: Basic Library Functions Oracle Solaris 10 1/13 Information Library|
- make a unique file name from a template and open the file
#include <stdlib.h> int mkstemp(char *template);
char *mkdtemp(char *template);
The mkstemp() function replaces the contents of the string pointed to by template by a unique file name, and returns a file descriptor for the file open for reading and writing. The function thus prevents any possible race condition between testing whether the file exists and opening it for use. The string in template should look like a file name with six trailing 'X's; mkstemp() replaces each 'X' with a character from the portable file name character set. The characters are chosen such that the resulting name does not duplicate the name of an existing file.
Upon successful completion, mkstemp() returns an open file descriptor. Otherwise -1 is returned if no suitable file could be created.
The mkstemp() and mkdtemp() functions can set errno to any of the values that can be returned by lstat(2).
The mkstemp() function can set errno to any of the values that can be returned by open(2).
The mkdtemp() function can set errno to any of the values that can be returned by mkdir(2).
It is possible to run out of letters.
The mkstemp() function does not check to determine whether the file name part of template exceeds the maximum allowable file name length.
The tmpfile(3C) function is preferred over this function.
The mkstemp() function is frequently used to create a temporary file that will be removed by the application before the application terminates.
The mkstemp() function has a transitional interface for 64-bit file offsets. See lf64(5).
See attributes(5) for descriptions of the following attributes: