summaryrefslogtreecommitdiff
path: root/sys/src/ape/lib/ap/stdio/tmpfile.c
diff options
context:
space:
mode:
authorTaru Karttunen <taruti@taruti.net>2011-03-30 15:46:40 +0300
committerTaru Karttunen <taruti@taruti.net>2011-03-30 15:46:40 +0300
commite5888a1ffdae813d7575f5fb02275c6bb07e5199 (patch)
treed8d51eac403f07814b9e936eed0c9a79195e2450 /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-xsys/src/ape/lib/ap/stdio/tmpfile.c32
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;
+}