diff options
author | Heiko Schlittermann (HS12-RIPE) <hs@schlittermann.de> | 2016-03-23 22:53:27 +0100 |
---|---|---|
committer | Heiko Schlittermann (HS12-RIPE) <hs@schlittermann.de> | 2016-03-24 19:37:19 +0100 |
commit | 3ae121c94f0dfaeba5938de26931c49e29677d0a (patch) | |
tree | ccf36265d092b587b7e20a631db4a09b37143774 /src | |
parent | 374dc1947cd80ee0532fabcbecc8c906a2d56ab9 (diff) |
Provide getcwd(NULL, 0) for Solaris (SunOS5)
Diffstat (limited to 'src')
-rw-r--r-- | src/OS/os.h-SunOS5 | 6 | ||||
-rw-r--r-- | src/src/exim.c | 2 | ||||
-rw-r--r-- | src/src/os.c | 32 | ||||
-rw-r--r-- | src/src/osfunctions.h | 3 |
4 files changed, 42 insertions, 1 deletions
diff --git a/src/OS/os.h-SunOS5 b/src/OS/os.h-SunOS5 index 45a1171c8..807212b85 100644 --- a/src/OS/os.h-SunOS5 +++ b/src/OS/os.h-SunOS5 @@ -37,4 +37,10 @@ it seems. */ #endif +/* SunOS5 doesn't accept getcwd(NULL, 0) to auto-allocate +a buffer */ + +#define OS_GETCWD + + /* End */ diff --git a/src/src/exim.c b/src/src/exim.c index 9cafc9a73..6a4fb5af3 100644 --- a/src/src/exim.c +++ b/src/src/exim.c @@ -3748,7 +3748,7 @@ directory to "/"! Later we change to $spool_directory. We do it there, because during readconf_main() some expansion takes place already. */ /* Store the initial cwd before we change directories */ -if ((initial_cwd = getcwd(NULL, 0)) == NULL) +if ((initial_cwd = os_getcwd(NULL, 0)) == NULL) { perror("exim: can't get the current working directory"); exit(EXIT_FAILURE); diff --git a/src/src/os.c b/src/src/os.c index d9ca589ee..d40fb606d 100644 --- a/src/src/os.c +++ b/src/src/os.c @@ -850,6 +850,38 @@ os_unsetenv(const char *name) } #endif +/* ----------------------------------------------------------------------- */ + +/*********************************************************** +* getcwd() * +***********************************************************/ + +/* Glibc allows getcwd(NULL, 0) to do auto-allocation. Some systems +do auto-allocation, but need the size of the buffer, and others +may not even do this. If the OS supports getcwd(NULL, 0) we'll use +this, for all other systems we provide our own getcwd() */ + +#if !defined(OS_GETCWD) +char * +os_getcwd(char *buffer, size_t size) +{ +return getcwd(buffer, size); +} +#else +#ifndef PATH_MAX +# define PATH_MAX 4096 +#endif +char * +os_getcwd(char *buffer, size_t size) +{ +void *rc; + +if (!size) size = PATH_MAX; +if (!buffer && !(buffer = (char*) malloc(size))) return NULL; +if (!(buffer = getcwd(buffer, size))) return NULL; +return realloc(buffer, strlen(buffer) + 1); +} +#endif /* ----------------------------------------------------------------------- */ diff --git a/src/src/osfunctions.h b/src/src/osfunctions.h index 3d1914acb..0e429fc8c 100644 --- a/src/src/osfunctions.h +++ b/src/src/osfunctions.h @@ -35,5 +35,8 @@ extern const char *os_strsignal(int); /* char to match strsignal in some OS #ifndef os_unsetenv extern int os_unsetenv(const char *); #endif +#ifndef os_getcwd +extern char* os_getcwd(char *, size_t); +#endif /* End of osfunctions.h */ |