summaryrefslogtreecommitdiffstats
path: root/osdep-darwin.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicholas.marriott@gmail.com>2012-09-24 14:05:38 +0100
committerNicholas Marriott <nicholas.marriott@gmail.com>2012-09-24 14:05:38 +0100
commit5d60bc7f7c43c20fcf65531b5a5fb1fc7dcbb338 (patch)
treefd7cdea8dd53657a1545db7df6f2baa1e1c2f574 /osdep-darwin.c
parent5b85efeb93d44e504e36ae06a91c2e1b8b82c50e (diff)
Use pgrp of pty fd not pid of immediate child when recovering current working
directory (like current process). From Marcel Partap.
Diffstat (limited to 'osdep-darwin.c')
-rw-r--r--osdep-darwin.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/osdep-darwin.c b/osdep-darwin.c
index 9cac1311..b112fa7c 100644
--- a/osdep-darwin.c
+++ b/osdep-darwin.c
@@ -26,7 +26,7 @@
#include <unistd.h>
char *osdep_get_name(int, char *);
-char *osdep_get_cwd(pid_t);
+char *osdep_get_cwd(int);
struct event_base *osdep_event_init(void);
#define unused __attribute__ ((unused))
@@ -51,14 +51,18 @@ osdep_get_name(int fd, unused char *tty)
}
char *
-osdep_get_cwd(pid_t pid)
+osdep_get_cwd(int fd)
{
static char wd[PATH_MAX];
struct proc_vnodepathinfo pathinfo;
+ pid_t pgrp;
int ret;
+ if ((pgrp = tcgetpgrp(fd)) == -1)
+ return (NULL);
+
ret = proc_pidinfo(
- pid, PROC_PIDVNODEPATHINFO, 0, &pathinfo, sizeof pathinfo);
+ pgrp, PROC_PIDVNODEPATHINFO, 0, &pathinfo, sizeof pathinfo);
if (ret == sizeof pathinfo) {
strlcpy(wd, pathinfo.pvi_cdir.vip_path, sizeof wd);
return (wd);