[tor-commits] [arm/master] Adding OSX support for the getPwd utility
atagar at torproject.org
atagar at torproject.org
Sat Oct 15 21:08:51 UTC 2011
commit 92ac1930143e51689396563877087d1070a246bd
Author: Damian Johnson <atagar at torproject.org>
Date: Sat Oct 15 14:03:32 2011 -0700
Adding OSX support for the getPwd utility
BSD platforms lack either pwdx or proc contents with this information. However,
this is available via lsof. Using this for BSD platforms. This was tested by
running sysTools.getPwd() on OSX - hopefully it should work on Free/OpenBSD
too. Fix is thanks to Sebastian.
https://trac.torproject.org/projects/tor/ticket/4236
---
src/util/sysTools.py | 17 +++++++++++++++++
1 files changed, 17 insertions(+), 0 deletions(-)
diff --git a/src/util/sysTools.py b/src/util/sysTools.py
index 98361e5..4bb0667 100644
--- a/src/util/sysTools.py
+++ b/src/util/sysTools.py
@@ -174,6 +174,23 @@ def getPwd(pid):
PWD_CACHE[pid] = pwd
return pwd
except IOError: pass # fall back to pwdx
+ elif os.uname()[0] in ("Darwin", "FreeBSD", "OpenBSD"):
+ # BSD neither useres the above proc info nor does it have pwdx. Use lsof to
+ # determine this instead:
+ # https://trac.torproject.org/projects/tor/ticket/4236
+ #
+ # ~$ lsof -a -p 75717 -d cwd -Fn
+ # p75717
+ # n/Users/atagar/tor/src/or
+
+ try:
+ results = call("lsof -a -p %s -d cwd -Fn" % pid)
+
+ if results and len(results) == 2 and results[1].startswith("n/"):
+ pwd = results[1][1:].strip()
+ PWD_CACHE[pid] = pwd
+ return pwd
+ except IOError, exc: pass
try:
# pwdx results are of the form:
More information about the tor-commits
mailing list