94 lines
2.0 KiB
Diff
94 lines
2.0 KiB
Diff
--- util/texindex.c
|
||
+++ util/texindex.c 2005-10-06 15:47:13.000000000 +0200
|
||
@@ -20,6 +20,7 @@
|
||
|
||
#include "system.h"
|
||
#include <getopt.h>
|
||
+#include <stdlib.h>
|
||
|
||
static char *program_name = "texindex";
|
||
|
||
@@ -37,8 +38,6 @@
|
||
#define memset(ptr, ignore, count) bzero (ptr, count)
|
||
#endif
|
||
|
||
-char *mktemp (char *);
|
||
-
|
||
#if !defined (SEEK_SET)
|
||
# define SEEK_SET 0
|
||
# define SEEK_CUR 1
|
||
@@ -99,6 +98,10 @@
|
||
/* Directory to use for temporary files. On Unix, it ends with a slash. */
|
||
char *tempdir;
|
||
|
||
+/* The base directory for the temporary files located in tempdir */
|
||
+
|
||
+static char *tempbase = NULL;
|
||
+
|
||
/* Number of last temporary file. */
|
||
int tempcount;
|
||
|
||
@@ -146,6 +149,7 @@
|
||
void *xmalloc (), *xrealloc ();
|
||
char *concat (char *s1, char *s2);
|
||
void flush_tempfiles (int to_count);
|
||
+void flush_tempfiles_atexit ();
|
||
|
||
#define MAX_IN_CORE_SORT 500000
|
||
|
||
@@ -321,6 +325,7 @@
|
||
tempdir = concat (tempdir, "/");
|
||
|
||
keep_tempfiles = 0;
|
||
+ atexit(flush_tempfiles_atexit);
|
||
|
||
/* Allocate ARGC input files, which must be enough. */
|
||
|
||
@@ -384,25 +389,25 @@
|
||
usage (1);
|
||
}
|
||
|
||
+
|
||
/* Return a name for temporary file COUNT. */
|
||
|
||
static char *
|
||
maketempname (int count)
|
||
{
|
||
- static char *tempbase = NULL;
|
||
- char tempsuffix[10];
|
||
+ char tempsuffix[20];
|
||
|
||
if (!tempbase)
|
||
{
|
||
- int fd;
|
||
- tempbase = concat (tempdir, "txidxXXXXXX");
|
||
+ char *td;
|
||
+ tempbase = concat (tempdir, "txdirXXXXXX");
|
||
|
||
- fd = mkstemp (tempbase);
|
||
- if (fd == -1)
|
||
+ td = mkdtemp (tempbase);
|
||
+ if (td == (char*)0)
|
||
pfatal_with_name (tempbase);
|
||
}
|
||
|
||
- sprintf (tempsuffix, ".%d", count);
|
||
+ sprintf (tempsuffix, "/txidx.%d", count);
|
||
return concat (tempbase, tempsuffix);
|
||
}
|
||
|
||
@@ -418,6 +423,13 @@
|
||
unlink (maketempname (++last_deleted_tempcount));
|
||
}
|
||
|
||
+void
|
||
+flush_tempfiles_atexit (void)
|
||
+{
|
||
+ flush_tempfiles (tempcount);
|
||
+ if (tempbase && !keep_tempfiles)
|
||
+ (void)rmdir(tempbase);
|
||
+}
|
||
|
||
/* Compare LINE1 and LINE2 according to the specified set of keyfields. */
|
||
|