head	1.1;
access;
symbols
	RELEASE_8_3_0:1.1
	RELEASE_9_0_0:1.1
	RELEASE_7_4_0:1.1
	RELEASE_8_2_0:1.1
	RELEASE_6_EOL:1.1
	RELEASE_8_1_0:1.1
	RELEASE_7_3_0:1.1
	RELEASE_8_0_0:1.1
	RELEASE_7_2_0:1.1
	RELEASE_7_1_0:1.1
	RELEASE_6_4_0:1.1
	RELEASE_5_EOL:1.1
	RELEASE_7_0_0:1.1
	RELEASE_6_3_0:1.1
	PRE_XORG_7:1.1
	RELEASE_4_EOL:1.1
	RELEASE_6_2_0:1.1
	RELEASE_6_1_0:1.1
	RELEASE_5_5_0:1.1
	RELEASE_6_0_0:1.1
	RELEASE_5_4_0:1.1
	RELEASE_4_11_0:1.1
	RELEASE_5_3_0:1.1
	RELEASE_4_10_0:1.1
	RELEASE_5_2_1:1.1
	RELEASE_5_2_0:1.1
	RELEASE_4_9_0:1.1
	RELEASE_5_1_0:1.1
	RELEASE_4_8_0:1.1
	RELEASE_5_0_0:1.1
	RELEASE_4_7_0:1.1
	RELEASE_4_6_2:1.1
	RELEASE_4_6_1:1.1
	RELEASE_4_6_0:1.1
	RELEASE_5_0_DP1:1.1
	RELEASE_4_5_0:1.1
	RELEASE_4_4_0:1.1
	RELEASE_4_3_0:1.1
	RELEASE_4_2_0:1.1
	RELEASE_4_1_1:1.1;
locks; strict;
comment	@# @;


1.1
date	2000.07.31.10.20.23;	author kevlo;	state Exp;
branches;
next	;


desc
@@


1.1
log
@Update to version 1.14g

PR: 20262
Submitted by: Port Fury
@
text
@--- src/lhadd.c.orig	Mon Jul 31 18:09:53 2000
+++ src/lhadd.c	Mon Jul 31 18:14:20 2000
@@@@ -270,13 +270,35 @@@@
 {
 	int             old_umask;
 	FILE           *afp;
+        int             tempfd;
+
+    #ifdef TMP_FILENAME_TEMPLATE
+          if (extract_directory == NULL) {
+                  strcpy(temporary_name, TMP_FILENAME_TEMPLATE);
+          }
+          else {
+                  sprintf(temporary_name, "%s/lhXXXXXX", extract_directory);
+          }
+          tempfd = mkstemp(temporary_name);
+    #else
+    char           *p, *s;
+   
+          strcpy(temporary_name, archive_name);
+          for (p = temporary_name, s = (char *) 0; *p; p++)
+                  if (*p == '/')
+                          s = p;
+	  strcpy((s ? s + 1 : temporary_name), "lhXXXXXX");
+          tempfd = mkstemp(temporary_name);
+    #endif
+        if (tempfd == -1)
+          return NULL;
 
-	build_temporary_name();
 	signal(SIGINT, interrupt);
 	signal(SIGHUP, interrupt);
 
 	old_umask = umask(077);
-	afp = xfopen(temporary_name, WRITE_BINARY);
+	/*afp = xfopen(temporary_name, WRITE_BINARY);*/
+	afp = fdopen(tempfd, "w+");
 	remove_temporary_at_error = TRUE;
 	temporary_fp = afp;
 	umask(old_umask);
@
