summaryrefslogtreecommitdiff
path: root/src/lib9
diff options
context:
space:
mode:
authorRuss Cox <rsc@golang.org>2011-07-22 21:21:17 -0400
committerRuss Cox <rsc@golang.org>2011-07-22 21:21:17 -0400
commita667e44e7592fd6c40815d9f774a64a18edf1f17 (patch)
treed8441c74abd7c531ac4482bc4134f7440ca0118e /src/lib9
parent4e5e12e305d2847a95a986d0e32b036b29ecd6ba (diff)
downloadgo-git-a667e44e7592fd6c40815d9f774a64a18edf1f17.tar.gz
lib9: use $PWD in getwd
This makes the full file paths recorded by 6g prefer $PWD over the actual directory name (relevant when $PWD gets to the current directory via symlinks). It's what everyone else does, and what people expect. R=iant, r, mattn.jp CC=golang-dev https://golang.org/cl/4824041
Diffstat (limited to 'src/lib9')
-rw-r--r--src/lib9/getwd.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/lib9/getwd.c b/src/lib9/getwd.c
index c3dd2b560e..3c8cafb3a0 100644
--- a/src/lib9/getwd.c
+++ b/src/lib9/getwd.c
@@ -3,6 +3,7 @@ Plan 9 from User Space src/lib9/getwd.c
http://code.swtch.com/plan9port/src/tip/src/lib9/getwd.c
Copyright 2001-2007 Russ Cox. All Rights Reserved.
+Portions Copyright 2011 The Go Authors. All Rights Reserved.
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
@@ -23,6 +24,8 @@ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
*/
#include <u.h>
+#include <errno.h>
+#include <sys/stat.h>
#include <libc.h>
#undef getwd
@@ -30,5 +33,23 @@ THE SOFTWARE.
char*
p9getwd(char *s, int ns)
{
+ char *pwd;
+ struct stat st1, st2;
+
+ // Clumsy but widespread kludge:
+ // if $PWD is set and matches ".", use it.
+ // Matches glibc's get_current_dir_name and Go's os.Getwd.
+ pwd = getenv("PWD"); // note: getenv, not p9getenv, so no free
+ if(pwd != nil && pwd[0] &&
+ stat(pwd, &st1) >= 0 && stat(".", &st2) >= 0 &&
+ st1.st_dev == st2.st_dev && st1.st_ino == st2.st_ino) {
+ if(strlen(pwd) >= ns) {
+ errno = ERANGE;
+ return nil;
+ }
+ strcpy(s, pwd);
+ return s;
+ }
+
return getcwd(s, ns);
}