ensure standard functions mk[sd]temp don't depend on removed function mktemp
authorRich Felker <dalias@aerifal.cx>
Tue, 15 Feb 2011 00:18:06 +0000 (19:18 -0500)
committerRich Felker <dalias@aerifal.cx>
Tue, 15 Feb 2011 00:18:06 +0000 (19:18 -0500)
src/temp/mkdtemp.c
src/temp/mkstemp.c
src/temp/mktemp.c

index cb030ee..162d98b 100644 (file)
@@ -1,4 +1,3 @@
-#define _GNU_SOURCE
 #include <string.h>
 #include <stdio.h>
 #include <stdlib.h>
@@ -9,10 +8,12 @@
 #include <sys/stat.h>
 #include "libc.h"
 
+char *__mktemp(char *);
+
 char *mkdtemp(char *template)
 {
        for (;;) {
-               if (!mktemp(template)) return 0;
+               if (!__mktemp(template)) return 0;
                if (!mkdir(template, 0700)) return template;
                if (errno != EEXIST) return 0;
                /* this is safe because mktemp verified
index 32c6be5..5e8bb93 100644 (file)
@@ -1,4 +1,3 @@
-#define _GNU_SOURCE
 #include <string.h>
 #include <stdio.h>
 #include <stdlib.h>
@@ -8,11 +7,13 @@
 #include <errno.h>
 #include "libc.h"
 
+char *__mktemp(char *);
+
 int mkstemp(char *template)
 {
        int fd;
 retry:
-       if (!mktemp(template)) return -1;
+       if (!__mktemp(template)) return -1;
        fd = open(template, O_RDWR | O_CREAT | O_EXCL, 0600);
        if (fd >= 0) return fd;
        if (errno == EEXIST) {
index 8638e08..1078b9d 100644 (file)
@@ -6,7 +6,7 @@
 #include <errno.h>
 #include "libc.h"
 
-char *mktemp(char *template)
+char *__mktemp(char *template)
 {
        static int lock;
        static int index;
@@ -27,3 +27,5 @@ char *mktemp(char *template)
        UNLOCK(&lock);
        return NULL;    
 }
+
+weak_alias(__mktemp, mktemp);