1 /* getpwd.c - get the working directory */
5 @deftypefn Supplemental char* getpwd (void)
7 Returns the current working directory. This implementation caches the
8 result on the assumption that the process will not call @code{chdir}
9 between calls to @code{getpwd}.
19 #include <sys/types.h>
32 #ifdef HAVE_SYS_PARAM_H
33 #include <sys/param.h>
42 #include "libiberty.h"
44 /* Virtually every UN*X system now in common use (except for pre-4.3-tahoe
45 BSD systems) now provides getcwd as called for by POSIX. Allow for
46 the few exceptions to the general rule here. */
48 #if !defined(HAVE_GETCWD) && defined(HAVE_GETWD)
49 /* Prototype in case the system headers doesn't provide it. */
50 extern char *getwd ();
51 #define getcwd(buf,len) getwd(buf)
55 #define GUESSPATHLEN (MAXPATHLEN + 1)
57 #define GUESSPATHLEN 100
60 #if !(defined (VMS) || (defined(_WIN32) && !defined(__CYGWIN__)))
64 #define getcwd _getcwd
67 /* Get the working directory. Use the PWD environment variable if it's
68 set correctly, since this is faster and gives more uniform answers
69 to the user. Yield the working directory if successful; otherwise,
70 yield 0 and set errno. */
76 static int failure_errno
;
80 struct stat dotstat
, pwdstat
;
82 if (!p
&& !(errno
= failure_errno
))
84 if (! ((p
= getenv ("PWD")) != 0
86 && stat (p
, &pwdstat
) == 0
87 && stat (".", &dotstat
) == 0
88 && dotstat
.st_ino
== pwdstat
.st_ino
89 && dotstat
.st_dev
== pwdstat
.st_dev
))
91 /* The shortcut didn't work. Try the slow, ``sure'' way. */
92 for (s
= GUESSPATHLEN
; !getcwd (p
= XNEWVEC (char, s
), s
); s
*= 2)
100 errno
= failure_errno
= e
;
106 /* Cache the result. This assumes that the program does
107 not invoke chdir between calls to getpwd. */
113 #else /* VMS || _WIN32 && !__CYGWIN__ */
116 #define MAXPATHLEN 255
122 static char *pwd
= 0;
125 pwd
= getcwd (XNEWVEC (char, MAXPATHLEN
+ 1), MAXPATHLEN
+ 1
133 #endif /* VMS || _WIN32 && !__CYGWIN__ */