openbsd-ports/lang/ocaml/patches/patch-yacc_main_c

115 lines
3.1 KiB
Plaintext
Raw Normal View History

--- yacc/main.c.orig Thu Jul 12 14:54:23 2001
+++ yacc/main.c Mon Aug 12 21:33:04 2002
@@ -51,6 +51,14 @@ char *text_file_name;
char *union_file_name;
char *verbose_file_name;
+#if defined(__OpenBSD__)
+#define HAVE_MKSTEMP
+#endif
+
+#ifdef HAVE_MKSTEMP
+int action_fd = -1, entry_fd = -1, text_fd = -1, union_fd = -1;
+#endif
+
2001-08-21 20:32:00 -04:00
FILE *action_file; /* a temp file, used to save actions associated */
/* with rules until the parser is written */
FILE *entry_file;
@@ -89,16 +97,29 @@ char *rassoc;
1999-07-08 22:51:11 -04:00
short **derives;
char *nullable;
+#if !defined(HAVE_MKSTEMP)
1999-07-08 22:51:11 -04:00
extern char *mktemp(char *);
+#endif
extern char *getenv(const char *);
void done(int k)
{
+#ifdef HAVE_MKSTEMP
+ if (action_fd != -1)
2001-08-21 20:32:00 -04:00
+ unlink(action_file_name);
+ if (entry_fd != -1)
2001-08-21 20:32:00 -04:00
+ unlink(entry_file_name);
+ if (text_fd != -1)
2001-08-21 20:32:00 -04:00
+ unlink(text_file_name);
+ if (union_fd != -1)
2001-08-21 20:32:00 -04:00
+ unlink(union_file_name);
+#else
if (action_file) { fclose(action_file); unlink(action_file_name); }
if (entry_file) { fclose(entry_file); unlink(entry_file_name); }
if (text_file) { fclose(text_file); unlink(text_file_name); }
if (union_file) { fclose(union_file); unlink(union_file_name); }
+#endif
if (output_file && k > 0) {
fclose(output_file); unlink(output_file_name);
}
@@ -283,11 +304,26 @@ void create_file_names(void)
1999-07-08 22:51:11 -04:00
union_file_name[len + 5] = 'u';
#ifndef NO_UNIX
+#ifdef HAVE_MKSTEMP
+ action_fd = mkstemp(action_file_name);
+ if (action_fd == -1)
2001-08-21 20:32:00 -04:00
+ open_error(action_file_name);
+ entry_fd = mkstemp(entry_file_name);
2001-08-21 20:32:00 -04:00
+ if (entry_fd == -1)
+ open_error(entry_file_name);
+ text_fd = mkstemp(text_file_name);
+ if (text_fd == -1)
2001-08-21 20:32:00 -04:00
+ open_error(text_file_name);
+ union_fd = mkstemp(union_file_name);
+ if (union_fd == -1)
2001-08-21 20:32:00 -04:00
+ open_error(union_file_name);
1999-07-08 22:51:11 -04:00
+#else
mktemp(action_file_name);
mktemp(entry_file_name);
mktemp(text_file_name);
mktemp(union_file_name);
#endif
+#endif
1999-07-08 22:51:11 -04:00
len = strlen(file_prefix);
@@ -328,15 +364,27 @@ void open_files(void)
2001-08-21 20:32:00 -04:00
open_error(input_file_name);
}
+#ifdef HAVE_MKSTEMP
+ action_file = fdopen(action_fd, "w");
+#else
action_file = fopen(action_file_name, "w");
+#endif
if (action_file == 0)
2001-08-21 20:32:00 -04:00
open_error(action_file_name);
+#ifdef HAVE_MKSTEMP
+ entry_file = fdopen(entry_fd, "w");
+#else
entry_file = fopen(entry_file_name, "w");
+#endif
if (entry_file == 0)
2001-08-21 20:32:00 -04:00
open_error(entry_file_name);
+#ifdef HAVE_MKSTEMP
+ text_file = fdopen(text_fd, "w");
+#else
text_file = fopen(text_file_name, "w");
+#endif
if (text_file == 0)
2001-08-21 20:32:00 -04:00
open_error(text_file_name);
@@ -352,7 +400,11 @@ void open_files(void)
2001-08-21 20:32:00 -04:00
defines_file = fopen(defines_file_name, "w");
if (defines_file == 0)
open_error(defines_file_name);
+#ifdef HAVE_MKSTEMP
2001-08-21 20:32:00 -04:00
+ union_file = fdopen(union_fd, "w");
+#else
2001-08-21 20:32:00 -04:00
union_file = fopen(union_file_name, "w");
+#endif
2001-08-21 20:32:00 -04:00
if (union_file == 0)
open_error(union_file_name);
}