mirror of
git://gcc.gnu.org/git/gcc.git
synced 2024-12-16 10:20:21 +08:00
make-temp-file.c (<windows.h>): Include on Windows.
* make-temp-file.c (<windows.h>): Include on Windows. (choose_tmpdir): On Windows, use GetTempPath. From-SVN: r144375
This commit is contained in:
parent
1f20025aa2
commit
8c9abf1f38
@ -1,3 +1,8 @@
|
|||||||
|
2009-02-21 Mark Mitchell <mark@codesourcery.com>
|
||||||
|
|
||||||
|
* make-temp-file.c (<windows.h>): Include on Windows.
|
||||||
|
(choose_tmpdir): On Windows, use GetTempPath.
|
||||||
|
|
||||||
2009-01-18 Dave Korn <dave.korn.cygwin@gmail.com>
|
2009-01-18 Dave Korn <dave.korn.cygwin@gmail.com>
|
||||||
|
|
||||||
* configure.ac (funcs, vars, checkfuncs): Don't munge on Cygwin,
|
* configure.ac (funcs, vars, checkfuncs): Don't munge on Cygwin,
|
||||||
|
@ -36,6 +36,9 @@ Boston, MA 02110-1301, USA. */
|
|||||||
#ifdef HAVE_SYS_FILE_H
|
#ifdef HAVE_SYS_FILE_H
|
||||||
#include <sys/file.h> /* May get R_OK, etc. on some systems. */
|
#include <sys/file.h> /* May get R_OK, etc. on some systems. */
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(_WIN32) && !defined(__CYGWIN__)
|
||||||
|
#include <windows.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef R_OK
|
#ifndef R_OK
|
||||||
#define R_OK 4
|
#define R_OK 4
|
||||||
@ -56,6 +59,8 @@ extern int mkstemps (char *, int);
|
|||||||
#define TEMP_FILE "ccXXXXXX"
|
#define TEMP_FILE "ccXXXXXX"
|
||||||
#define TEMP_FILE_LEN (sizeof(TEMP_FILE) - 1)
|
#define TEMP_FILE_LEN (sizeof(TEMP_FILE) - 1)
|
||||||
|
|
||||||
|
#if !defined(_WIN32) || defined(__CYGWIN__)
|
||||||
|
|
||||||
/* Subroutine of choose_tmpdir.
|
/* Subroutine of choose_tmpdir.
|
||||||
If BASE is non-NULL, return it.
|
If BASE is non-NULL, return it.
|
||||||
Otherwise it checks if DIR is a usable directory.
|
Otherwise it checks if DIR is a usable directory.
|
||||||
@ -81,6 +86,8 @@ static const char usrtmp[] =
|
|||||||
static const char vartmp[] =
|
static const char vartmp[] =
|
||||||
{ DIR_SEPARATOR, 'v', 'a', 'r', DIR_SEPARATOR, 't', 'm', 'p', 0 };
|
{ DIR_SEPARATOR, 'v', 'a', 'r', DIR_SEPARATOR, 't', 'm', 'p', 0 };
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
static char *memoized_tmpdir;
|
static char *memoized_tmpdir;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -97,13 +104,13 @@ files in.
|
|||||||
char *
|
char *
|
||||||
choose_tmpdir (void)
|
choose_tmpdir (void)
|
||||||
{
|
{
|
||||||
|
if (!memoized_tmpdir)
|
||||||
|
{
|
||||||
|
#if !defined(_WIN32) || defined(__CYGWIN__)
|
||||||
const char *base = 0;
|
const char *base = 0;
|
||||||
char *tmpdir;
|
char *tmpdir;
|
||||||
unsigned int len;
|
unsigned int len;
|
||||||
|
|
||||||
if (memoized_tmpdir)
|
|
||||||
return memoized_tmpdir;
|
|
||||||
|
|
||||||
base = try_dir (getenv ("TMPDIR"), base);
|
base = try_dir (getenv ("TMPDIR"), base);
|
||||||
base = try_dir (getenv ("TMP"), base);
|
base = try_dir (getenv ("TMP"), base);
|
||||||
base = try_dir (getenv ("TEMP"), base);
|
base = try_dir (getenv ("TEMP"), base);
|
||||||
@ -120,7 +127,6 @@ choose_tmpdir (void)
|
|||||||
/* If all else fails, use the current directory! */
|
/* If all else fails, use the current directory! */
|
||||||
if (base == 0)
|
if (base == 0)
|
||||||
base = ".";
|
base = ".";
|
||||||
|
|
||||||
/* Append DIR_SEPARATOR to the directory we've chosen
|
/* Append DIR_SEPARATOR to the directory we've chosen
|
||||||
and return it. */
|
and return it. */
|
||||||
len = strlen (base);
|
len = strlen (base);
|
||||||
@ -128,9 +134,28 @@ choose_tmpdir (void)
|
|||||||
strcpy (tmpdir, base);
|
strcpy (tmpdir, base);
|
||||||
tmpdir[len] = DIR_SEPARATOR;
|
tmpdir[len] = DIR_SEPARATOR;
|
||||||
tmpdir[len+1] = '\0';
|
tmpdir[len+1] = '\0';
|
||||||
|
|
||||||
memoized_tmpdir = tmpdir;
|
memoized_tmpdir = tmpdir;
|
||||||
return tmpdir;
|
#else /* defined(_WIN32) && !defined(__CYGWIN__) */
|
||||||
|
DWORD len;
|
||||||
|
|
||||||
|
/* Figure out how much space we need. */
|
||||||
|
len = GetTempPath(0, NULL);
|
||||||
|
if (len)
|
||||||
|
{
|
||||||
|
memoized_tmpdir = XNEWVEC (char, len);
|
||||||
|
if (!GetTempPath(len, memoized_tmpdir))
|
||||||
|
{
|
||||||
|
XDELETEVEC (memoized_tmpdir);
|
||||||
|
memoized_tmpdir = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!memoized_tmpdir)
|
||||||
|
/* If all else fails, use the current directory. */
|
||||||
|
memoized_tmpdir = xstrdup (".\\");
|
||||||
|
#endif /* defined(_WIN32) && !defined(__CYGWIN__) */
|
||||||
|
}
|
||||||
|
|
||||||
|
return memoized_tmpdir;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user