--- ray/src/common/paths.h 2003/06/26 00:58:09 2.14 +++ ray/src/common/paths.h 2003/07/14 20:02:29 2.18 @@ -1,4 +1,4 @@ -/* RCSid $Id: paths.h,v 2.14 2003/06/26 00:58:09 schorsch Exp $ */ +/* RCSid $Id: paths.h,v 2.18 2003/07/14 20:02:29 schorsch Exp $ */ /* * Definitions for paths on different machines */ @@ -8,19 +8,17 @@ extern "C" { #endif -#include "copyright.h" - +#include #include #include +#include +#include +#include + #ifdef _WIN32 #include -#else /* _WIN32 */ - #include - #include -#endif /* _WIN32 */ + #include /* getcwd(), chdir(), etc. */ -#ifdef _WIN32 - #define access _access #define PATH_MAX _MAX_PATH #define DIRSEP '/' @@ -34,7 +32,6 @@ extern "C" { #define CASEDIRSEP case '/': case '\\' #define PATHSEP ';' #define CURDIR '.' - #define MAXPATH 512 /* XXX obsoleted by posix PATH_MAX */ #define DEFAULT_TEMPDIRS {"C:/TMP", "C:/TEMP", ".", NULL} #define TEMPLATE "rtXXXXXX" #define TEMPLEN 8 @@ -49,11 +46,23 @@ extern "C" { #define W_OK 02 #define R_OK 04 #endif + /* to make the permissions user specific we'd need to use CreateFile() */ + #ifndef S_IRUSR + #define S_IRUSR _S_IREAD + #define S_IWUSR _S_IWRITE + #endif extern char *fixargv0(); -#else - #ifndef PATH_MAX /* doesn't implement posix? */ - #define PATH_MAX 512 /* quite conservative (I think...) */ +#else /* everything but Windows */ + #include + #include + + #define RMAX_PATH_MAX 4096 /* our own maximum */ + #ifndef PATH_MAX + #define PATH_MAX 512 + #elif PATH_MAX > RMAX_PATH_MAX /* the OS is exaggerating */ + #undef PATH_MAX + #define PATH_MAX RMAX_PATH_MAX #endif #ifdef AMIGA @@ -62,7 +71,6 @@ extern char *fixargv0(); #define ISABS(s) ((s)!=NULL && (ISDIRSEP(s[0]))) #define PATHSEP ';' #define CURDIR '.' - #define MAXPATH 128 #define DEFAULT_TEMPDIRS {"/var/tmp", "/usr/tmp", "/tmp", ".", NULL} #define TEMPLATE "/tmp/rtXXXXXX" #define TEMPLEN 13 @@ -74,11 +82,14 @@ extern char *fixargv0(); #else + /* posix */ + + /* this is defined as _PATH_DEVNULL in /usr/include/paths.h on Linux */ + #define NULL_DEVICE "/dev/null" #define DIRSEP '/' #define ISABS(s) ((s)!=NULL && (ISDIRSEP(s[0]))) #define PATHSEP ':' #define CURDIR '.' - #define MAXPATH 256 #define DEFAULT_TEMPDIRS {"/var/tmp", "/usr/tmp", "/tmp", ".", NULL} #define TEMPLATE "/usr/tmp/rtXXXXXX" #define TEMPLEN 17 @@ -98,16 +109,7 @@ extern char *fixargv0(); #define CASEDIRSEP case DIRSEP #endif -extern char *mktemp(), *getenv(); -#ifdef BSD -extern char *getwd(); -#else -extern char *getcwd(); -#define getwd(p) getcwd(p, sizeof(p)) -#endif - - /* Find a writeable directory for temporary files */ /* If s is NULL, we return a static string */ extern char *temp_directory(char *s, size_t len); @@ -122,7 +124,10 @@ extern char *temp_filename(char *s, size_t len, char * /* Same as above, but also open the file and return the descriptor */ /* This one is supposed to protect against race conditions on unix */ /* WARNING: On Windows, there's no protection against race conditions */ -extern int temp_file(char *s, size_t len, char *templ); +extern int temp_fd(char *s, size_t len, char *templ); + +/* Same as above, but return a file pointer instead of a descriptor */ +extern FILE *temp_fp(char *s, size_t len, char *templ); /* Concatenate two strings, leaving exactly one DIRSEP in between */ extern char *append_filepath(char *s1, char *s2, size_t len);