openbsd-ports/lang/ocaml/patches/patch-yacc_main_c
2006-05-28 15:28:53 +00:00

115 lines
3.1 KiB
Plaintext

--- yacc/main.c.orig Mon Jan 23 17:38:43 2006
+++ yacc/main.c Tue May 2 11:34:56 2006
@@ -55,6 +55,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
+
FILE *action_file; /* a temp file, used to save actions associated */
/* with rules until the parser is written */
FILE *entry_file;
@@ -93,16 +101,29 @@ char *rassoc;
short **derives;
char *nullable;
+#if !defined(HAVE_MKSTEMP)
extern char *mktemp(char *);
+#endif
extern char *getenv(const char *);
void done(int k)
{
+#ifdef HAVE_MKSTEMP
+ if (action_fd != -1)
+ unlink(action_file_name);
+ if (entry_fd != -1)
+ unlink(entry_file_name);
+ if (text_fd != -1)
+ unlink(text_file_name);
+ if (union_fd != -1)
+ 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);
}
@@ -302,11 +323,26 @@ void create_file_names(void)
union_file_name[len + 5] = 'u';
#ifndef NO_UNIX
+#ifdef HAVE_MKSTEMP
+ action_fd = mkstemp(action_file_name);
+ if (action_fd == -1)
+ open_error(action_file_name);
+ entry_fd = mkstemp(entry_file_name);
+ if (entry_fd == -1)
+ open_error(entry_file_name);
+ text_fd = mkstemp(text_file_name);
+ if (text_fd == -1)
+ open_error(text_file_name);
+ union_fd = mkstemp(union_file_name);
+ if (union_fd == -1)
+ open_error(union_file_name);
+#else
mktemp(action_file_name);
mktemp(entry_file_name);
mktemp(text_file_name);
mktemp(union_file_name);
#endif
+#endif
len = strlen(file_prefix);
@@ -347,15 +383,27 @@ void open_files(void)
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)
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)
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)
open_error(text_file_name);
@@ -371,7 +419,11 @@ void open_files(void)
defines_file = fopen(defines_file_name, "w");
if (defines_file == 0)
open_error(defines_file_name);
+#ifdef HAVE_MKSTEMP
+ union_file = fdopen(union_fd, "w");
+#else
union_file = fopen(union_file_name, "w");
+#endif
if (union_file == 0)
open_error(union_file_name);
}