diff options
author | Nicholas Marriott <nicm@openbsd.org> | 2012-09-24 13:05:10 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@openbsd.org> | 2012-09-24 13:05:10 +0000 |
commit | 42272dfbd5058724fc094eb3ea438ec6b7eb6cff (patch) | |
tree | 03d77032589c1c7fca5ddcb1d2e137f44366b988 | |
parent | eb0ad181e909c83fad8c1fd2a4a37271b6980ea2 (diff) | |
download | rtmux-42272dfbd5058724fc094eb3ea438ec6b7eb6cff.tar.gz rtmux-42272dfbd5058724fc094eb3ea438ec6b7eb6cff.tar.bz2 rtmux-42272dfbd5058724fc094eb3ea438ec6b7eb6cff.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-- | procname.c | 8 | ||||
-rw-r--r-- | tmux.h | 2 |
4 files changed, 8 insertions, 6 deletions
@@ -1298,7 +1298,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 = get_proc_cwd(s->curw->window->active->pid); + root = get_proc_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", get_proc_cwd(wp->pid)); + format_add(ft, "pane_current_path", "%s", get_proc_cwd(wp->fd)); format_add(ft, "pane_pid", "%ld", (long) wp->pid); format_add(ft, "pane_tty", "%s", wp->tty); } @@ -36,7 +36,7 @@ struct kinfo_proc *cmp_procs(struct kinfo_proc *, struct kinfo_proc *); char *get_proc_name(int, char *); -char *get_proc_cwd(pid_t); +char *get_proc_cwd(int); struct kinfo_proc * cmp_procs(struct kinfo_proc *p1, struct kinfo_proc *p2) @@ -133,12 +133,14 @@ error: } char* -get_proc_cwd(pid_t pid) +get_proc_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); @@ -2277,7 +2277,7 @@ u_int utf8_split2(u_int, u_char *); /* procname.c */ char *get_proc_name(int, char *); -char *get_proc_cwd(pid_t); +char *get_proc_cwd(int); /* log.c */ void log_open(int, const char *); |