diff options
author | Taru Karttunen <taruti@taruti.net> | 2011-03-30 15:46:40 +0300 |
---|---|---|
committer | Taru Karttunen <taruti@taruti.net> | 2011-03-30 15:46:40 +0300 |
commit | e5888a1ffdae813d7575f5fb02275c6bb07e5199 (patch) | |
tree | d8d51eac403f07814b9e936eed0c9a79195e2450 /sys/src/ape/lib/ap/stdio/tmpfile.c |
Import sources from 2011-03-30 iso image
Diffstat (limited to 'sys/src/ape/lib/ap/stdio/tmpfile.c')
-rwxr-xr-x | sys/src/ape/lib/ap/stdio/tmpfile.c | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/sys/src/ape/lib/ap/stdio/tmpfile.c b/sys/src/ape/lib/ap/stdio/tmpfile.c new file mode 100755 index 000000000..751986c78 --- /dev/null +++ b/sys/src/ape/lib/ap/stdio/tmpfile.c @@ -0,0 +1,32 @@ +/* + * This file not used on plan9: see ../plan9/tmpfile.c + */ +/* + * pANS stdio -- tmpfile + * + * Bug: contains a critical section. Two executions by the same + * user could interleave as follows, both yielding the same file: + * access fails + * access fails + * fopen succeeds + * fopen succeeds + * unlink succeeds + * unlink fails + * As I read the pANS, this can't reasonably use tmpnam to generate + * the name, so that code is duplicated. + */ +#include "iolib.h" +FILE *tmpfile(void){ + FILE *f; + static char name[]="/tmp/tf000000000000"; + char *p; + while(access(name, 0)==0){ + p=name+7; + while(*p=='9') *p++='0'; + if(*p=='\0') return NULL; + ++*p; + } + f=fopen(name, "wb+"); + unlink(name); + return f; +} |