use memcmp instead of str[n]cmp for temp function XXXXXX checking
[musl] / src / temp / mktemp.c
index c0e06f5..24c858b 100644 (file)
@@ -1,30 +1,23 @@
 #include <string.h>
 #include <string.h>
-#include <stdio.h>
-#include <stdlib.h>
 #include <fcntl.h>
 #include <unistd.h>
 #include <errno.h>
 #include <fcntl.h>
 #include <unistd.h>
 #include <errno.h>
-#include <time.h>
-#include <stdint.h>
 #include "libc.h"
 
 #include "libc.h"
 
+char *__randname(char *);
+
 char *__mktemp(char *template)
 {
 char *__mktemp(char *template)
 {
-       struct timespec ts;
-       size_t i, l = strlen(template);
+       size_t l = strlen(template);
        int retries = 10000;
        int retries = 10000;
-       unsigned long r;
 
 
-       if (l < 6 || strcmp(template+l-6, "XXXXXX")) {
+       if (l < 6 || memcmp(template+l-6, "XXXXXX", 6)) {
                errno = EINVAL;
                *template = 0;
                return template;
        }
        while (retries--) {
                errno = EINVAL;
                *template = 0;
                return template;
        }
        while (retries--) {
-               clock_gettime(CLOCK_REALTIME, &ts);
-               r = ts.tv_nsec + (uintptr_t)&ts / 16 + (uintptr_t)template;
-               for (i=1; i<=6; i++, r>>=4)
-                       template[l-i] = 'A'+(r&15);
+               __randname(template+l-6);
                if (access(template, F_OK) < 0) return template;
        }
        *template = 0;
                if (access(template, F_OK) < 0) return template;
        }
        *template = 0;