summaryrefslogtreecommitdiff
path: root/src/temp/mkstemp.c
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2013-02-20 22:43:23 -0500
committerRich Felker <dalias@aerifal.cx>2013-02-20 22:43:23 -0500
commit2cc63358cdb0309ca996ffe56ccf402c2f2f16d5 (patch)
tree067001fb5f1a5a09de6d8417c5d1d80249e382ce /src/temp/mkstemp.c
parentf78cdbe8993d072bf60a65754544199016a1fe29 (diff)
downloadmusl-2cc63358cdb0309ca996ffe56ccf402c2f2f16d5.tar.gz
musl-2cc63358cdb0309ca996ffe56ccf402c2f2f16d5.tar.bz2
musl-2cc63358cdb0309ca996ffe56ccf402c2f2f16d5.tar.xz
musl-2cc63358cdb0309ca996ffe56ccf402c2f2f16d5.zip
add mkostemp, mkstemps, and mkostemps functions and reorganize temp internals
based on patch contributed by Anthony G. Basile (blueness) some issues remain with the filename generation algorithm and other small bugs, but this patch has been sitting around long enough that I feel it's best to get it committed and then work out any remaining issues.
Diffstat (limited to 'src/temp/mkstemp.c')
-rw-r--r--src/temp/mkstemp.c21
1 files changed, 2 insertions, 19 deletions
diff --git a/src/temp/mkstemp.c b/src/temp/mkstemp.c
index a390d427..85764af7 100644
--- a/src/temp/mkstemp.c
+++ b/src/temp/mkstemp.c
@@ -1,28 +1,11 @@
-#include <string.h>
-#include <stdio.h>
#include <stdlib.h>
-#include <fcntl.h>
-#include <unistd.h>
-#include <limits.h>
-#include <errno.h>
#include "libc.h"
-char *__mktemp(char *);
+int __mkostemps(char *, int, int);
int mkstemp(char *template)
{
- int fd, retries = 100, t0 = *template;
- while (retries--) {
- if (!*__mktemp(template)) return -1;
- if ((fd = open(template, O_RDWR | O_CREAT | O_EXCL, 0600))>=0)
- return fd;
- if (errno != EEXIST) return -1;
- /* this is safe because mktemp verified
- * that we have a valid template string */
- template[0] = t0;
- strcpy(template+strlen(template)-6, "XXXXXX");
- }
- return -1;
+ return __mkostemps(template, 0, 0);
}
LFS64(mkstemp);