diff options
author | Rich Felker <dalias@aerifal.cx> | 2011-02-18 16:32:33 -0500 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2011-02-18 16:32:33 -0500 |
commit | 3e9e30166f22f8fb0d5664500bb52a00d1a3c6a3 (patch) | |
tree | 2d755bf8c35efb02d87fad678f7089ffcf8028ea /src/temp | |
parent | d5ca067c7bb47081c169ff8b0213c73418f0525e (diff) | |
download | musl-3e9e30166f22f8fb0d5664500bb52a00d1a3c6a3.tar.gz musl-3e9e30166f22f8fb0d5664500bb52a00d1a3c6a3.tar.bz2 musl-3e9e30166f22f8fb0d5664500bb52a00d1a3c6a3.tar.xz musl-3e9e30166f22f8fb0d5664500bb52a00d1a3c6a3.zip |
reformat mkstemp like mkdtemp
this is cleaner and makes it easy to impose a limit on the number of
retries later if it seems desirable to do so.
Diffstat (limited to 'src/temp')
-rw-r--r-- | src/temp/mkstemp.c | 12 |
1 files changed, 5 insertions, 7 deletions
diff --git a/src/temp/mkstemp.c b/src/temp/mkstemp.c index 5e8bb934..34642569 100644 --- a/src/temp/mkstemp.c +++ b/src/temp/mkstemp.c @@ -12,17 +12,15 @@ char *__mktemp(char *); int mkstemp(char *template) { int fd; -retry: - if (!__mktemp(template)) return -1; - fd = open(template, O_RDWR | O_CREAT | O_EXCL, 0600); - if (fd >= 0) return fd; - if (errno == EEXIST) { + for (;;) { + if (!__mktemp(template)) return 0; + 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 */ strcpy(template+strlen(template)-6, "XXXXXX"); - goto retry; } - return -1; } LFS64(mkstemp); |