summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>1996-06-25 01:54:56 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>1996-06-25 01:54:56 +0000
commitc524ca74aa2b84e836b3f5b406f06eed2a0c3725 (patch)
treeb34f4caeae667de1644180888ff3efcbdd102c45
parentff995f47e5630c58d219fabad07b16418f89e161 (diff)
mktemp open+fdopen
-rw-r--r--usr.bin/yacc/main.c34
1 files changed, 27 insertions, 7 deletions
diff --git a/usr.bin/yacc/main.c b/usr.bin/yacc/main.c
index e225915c2a8..13749a7f2ac 100644
--- a/usr.bin/yacc/main.c
+++ b/usr.bin/yacc/main.c
@@ -50,6 +50,9 @@ static char rcsid[] = "$NetBSD: main.c,v 1.5 1996/03/19 03:21:38 jtc Exp $";
#endif
#endif /* not lint */
+#include <sys/types.h>
+#include <sys/file.h>
+#include <stdlib.h>
#include <signal.h>
#include "defs.h"
@@ -111,10 +114,6 @@ char *rassoc;
short **derives;
char *nullable;
-extern char *mktemp();
-extern char *getenv();
-
-
done(k)
int k;
{
@@ -386,8 +385,29 @@ create_file_names()
}
+FILE *
+fsopen(name, mode)
+ char *name;
+ char *mode;
+{
+ FILE *fp = NULL;
+ int fd, mod = O_RDONLY;
+
+ if (strchr(mode, 'w'))
+ mod = O_RDWR;
+ if ((fd = open(name, mod | O_EXCL|O_CREAT, 0666)) == -1 ||
+ (fp = fdopen(fd, mode)) == NULL) {
+ if (fd != -1)
+ close(fd);
+ }
+ return (fp);
+}
+
+
open_files()
{
+ int fd;
+
create_file_names();
if (input_file == 0)
@@ -397,11 +417,11 @@ open_files()
open_error(input_file_name);
}
- action_file = fopen(action_file_name, "w");
+ action_file = fsopen(action_file_name, "w");
if (action_file == 0)
open_error(action_file_name);
- text_file = fopen(text_file_name, "w");
+ text_file = fsopen(text_file_name, "w");
if (text_file == 0)
open_error(text_file_name);
@@ -417,7 +437,7 @@ open_files()
defines_file = fopen(defines_file_name, "w");
if (defines_file == 0)
open_error(defines_file_name);
- union_file = fopen(union_file_name, "w");
+ union_file = fsopen(union_file_name, "w");
if (union_file == 0)
open_error(union_file_name);
}