diff options
author | Nicholas Marriott <nicholas.marriott@gmail.com> | 2012-09-24 14:05:38 +0100 |
---|---|---|
committer | Nicholas Marriott <nicholas.marriott@gmail.com> | 2012-09-24 14:05:38 +0100 |
commit | 5d60bc7f7c43c20fcf65531b5a5fb1fc7dcbb338 (patch) | |
tree | fd7cdea8dd53657a1545db7df6f2baa1e1c2f574 | |
parent | 5b85efeb93d44e504e36ae06a91c2e1b8b82c50e (diff) | |
download | rtmux-5d60bc7f7c43c20fcf65531b5a5fb1fc7dcbb338.tar.gz rtmux-5d60bc7f7c43c20fcf65531b5a5fb1fc7dcbb338.tar.bz2 rtmux-5d60bc7f7c43c20fcf65531b5a5fb1fc7dcbb338.zip |
Use pgrp of pty fd not pid of immediate child when recovering current working
directory (like current process). From Marcel Partap.
-rw-r--r-- | cmd.c | 2 | ||||
-rw-r--r-- | format.c | 2 | ||||
-rw-r--r-- | osdep-aix.c | 2 | ||||
-rw-r--r-- | osdep-darwin.c | 10 | ||||
-rw-r--r-- | osdep-dragonfly.c | 4 | ||||
-rw-r--r-- | osdep-freebsd.c | 10 | ||||
-rw-r--r-- | osdep-hpux.c | 2 | ||||
-rw-r--r-- | osdep-linux.c | 8 | ||||
-rw-r--r-- | osdep-netbsd.c | 4 | ||||
-rw-r--r-- | osdep-openbsd.c | 8 | ||||
-rw-r--r-- | osdep-sunos.c | 8 | ||||
-rw-r--r-- | osdep-unknown.c | 2 | ||||
-rw-r--r-- | tmux.h | 2 |
13 files changed, 41 insertions, 23 deletions
@@ -1297,7 +1297,7 @@ cmd_get_default_path(struct cmd_ctx *ctx, const char *cwd) if (ctx->cmdclient != NULL && ctx->cmdclient->cwd != NULL) root = ctx->cmdclient->cwd; else if (ctx->curclient != NULL && s->curw != NULL) - root = osdep_get_cwd(s->curw->window->active->pid); + root = osdep_get_cwd(s->curw->window->active->fd); else return (s->cwd); skip = 0; @@ -391,7 +391,7 @@ format_window_pane(struct format_tree *ft, struct window_pane *wp) format_add(ft, "pane_start_command", "%s", wp->cmd); if (wp->cwd != NULL) format_add(ft, "pane_start_path", "%s", wp->cwd); - format_add(ft, "pane_current_path", "%s", osdep_get_cwd(wp->pid)); + format_add(ft, "pane_current_path", "%s", osdep_get_cwd(wp->fd)); format_add(ft, "pane_pid", "%ld", (long) wp->pid); format_add(ft, "pane_tty", "%s", wp->tty); } diff --git a/osdep-aix.c b/osdep-aix.c index 2a291655..8d590816 100644 --- a/osdep-aix.c +++ b/osdep-aix.c @@ -29,7 +29,7 @@ osdep_get_name(unused int fd, unused char *tty) } char * -osdep_get_cwd(pid_t pid) +osdep_get_cwd(unused int fd) { return (NULL); } 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); diff --git a/osdep-dragonfly.c b/osdep-dragonfly.c index 22045c37..ad417d98 100644 --- a/osdep-dragonfly.c +++ b/osdep-dragonfly.c @@ -31,7 +31,7 @@ struct kinfo_proc *cmp_procs(struct kinfo_proc *, struct kinfo_proc *); char *osdep_get_name(int, char *); -char *osdep_get_cwd(pid_t); +char *osdep_get_cwd(int); struct event_base *osdep_event_init(void); #ifndef nitems @@ -121,7 +121,7 @@ error: } char * -osdep_get_cwd(pid_t pid) +osdep_get_cwd(int fd) { return (NULL); } diff --git a/osdep-freebsd.c b/osdep-freebsd.c index 1027a648..d596eab4 100644 --- a/osdep-freebsd.c +++ b/osdep-freebsd.c @@ -33,7 +33,7 @@ struct kinfo_proc *cmp_procs(struct kinfo_proc *, struct kinfo_proc *); char *osdep_get_name(int, char *); -char *osdep_get_cwd(pid_t); +char *osdep_get_cwd(int); struct event_base *osdep_event_init(void); #ifndef nitems @@ -133,13 +133,17 @@ error: } char * -osdep_get_cwd(pid_t pid) +osdep_get_cwd(int fd) { static char wd[PATH_MAX]; struct kinfo_file *info = NULL; + pid_t pgrp; int nrecords, i; - if ((info = kinfo_getfile(pid, &nrecords)) == NULL) + if ((pgrp = tcgetpgrp(fd)) == -1) + return (NULL); + + if ((info = kinfo_getfile(pgrp, &nrecords)) == NULL) return (NULL); for (i = 0; i < nrecords; i++) { diff --git a/osdep-hpux.c b/osdep-hpux.c index c962a1f7..352e375b 100644 --- a/osdep-hpux.c +++ b/osdep-hpux.c @@ -29,7 +29,7 @@ osdep_get_name(unused int fd, unused char *tty) } char * -osdep_get_cwd(pid_t pid) +osdep_get_cwd(unused int fd) { return (NULL); } diff --git a/osdep-linux.c b/osdep-linux.c index 8adf202b..b65acffc 100644 --- a/osdep-linux.c +++ b/osdep-linux.c @@ -61,13 +61,17 @@ osdep_get_name(int fd, unused char *tty) } char * -osdep_get_cwd(pid_t pid) +osdep_get_cwd(int fd) { static char target[MAXPATHLEN + 1]; char *path; + pid_t pgrp; ssize_t n; - xasprintf(&path, "/proc/%d/cwd", pid); + if ((pgrp = tcgetpgrp(fd)) == -1) + return (NULL); + + xasprintf(&path, "/proc/%lld/cwd", (long long) pgrp); n = readlink(path, target, MAXPATHLEN); free(path); if (n > 0) { diff --git a/osdep-netbsd.c b/osdep-netbsd.c index bb2676cc..f16d0dc8 100644 --- a/osdep-netbsd.c +++ b/osdep-netbsd.c @@ -34,7 +34,7 @@ struct kinfo_proc2 *cmp_procs(struct kinfo_proc2 *, struct kinfo_proc2 *); char *osdep_get_name(int, char *); -char *osdep_get_cwd(pid_t); +char *osdep_get_cwd(int); struct event_base *osdep_event_init(void); struct kinfo_proc2 * @@ -125,7 +125,7 @@ error: } char * -osdep_get_cwd(pid_t pid) +osdep_get_cwd(int fd) { return (NULL); } diff --git a/osdep-openbsd.c b/osdep-openbsd.c index 4fb75bff..9eee984f 100644 --- a/osdep-openbsd.c +++ b/osdep-openbsd.c @@ -37,7 +37,7 @@ struct kinfo_proc *cmp_procs(struct kinfo_proc *, struct kinfo_proc *); char *osdep_get_name(int, char *); -char *osdep_get_cwd(pid_t); +char *osdep_get_cwd(int); struct event_base *osdep_event_init(void); struct kinfo_proc * @@ -135,12 +135,14 @@ error: } char* -osdep_get_cwd(pid_t pid) +osdep_get_cwd(int fd) { - int name[] = { CTL_KERN, KERN_PROC_CWD, (int)pid }; + int name[] = { CTL_KERN, KERN_PROC_CWD, 0 }; static char path[MAXPATHLEN]; size_t pathlen = sizeof path; + if ((name[2] = tcgetpgrp(fd)) == -1) + return (NULL); if (sysctl(name, 3, path, &pathlen, NULL, 0) != 0) return (NULL); return (path); diff --git a/osdep-sunos.c b/osdep-sunos.c index bb67412c..fd644f5d 100644 --- a/osdep-sunos.c +++ b/osdep-sunos.c @@ -65,13 +65,17 @@ osdep_get_name(int fd, char *tty) } char * -osdep_get_cwd(pid_t pid) +osdep_get_cwd(int fd) { static char target[MAXPATHLEN + 1]; char *path; ssize_t n; + pid_t pgrp; + + if ((pgrp = tcgetpgrp(fd)) == -1) + return (NULL); - xasprintf(&path, "/proc/%u/path/cwd", (u_int) pid); + xasprintf(&path, "/proc/%u/path/cwd", (u_int) pgrp); n = readlink(path, target, MAXPATHLEN); free(path); if (n > 0) { diff --git a/osdep-unknown.c b/osdep-unknown.c index c962a1f7..41f435bc 100644 --- a/osdep-unknown.c +++ b/osdep-unknown.c @@ -29,7 +29,7 @@ osdep_get_name(unused int fd, unused char *tty) } char * -osdep_get_cwd(pid_t pid) +osdep_get_cwd(int fd) { return (NULL); } @@ -2273,7 +2273,7 @@ u_int utf8_split2(u_int, u_char *); /* osdep-*.c */ char *osdep_get_name(int, char *); -char *osdep_get_cwd(pid_t); +char *osdep_get_cwd(int); struct event_base *osdep_event_init(void); /* log.c */ |