I think this makes sense, will look at it more closely tomorrow though.

On Sat, Sep 15, 2012 at 03:22:37PM +0200, Marcel Partap wrote:
> by picking up the process group leader from the terminal fd
> via tcgetpgrp() instead of using the direct pane child process.
> 
> (works on linux, other platforms untested)
> ---
>  trunk/cmd.c             |    2 +-
>  trunk/format.c          |    2 +-
>  trunk/osdep-aix.c       |    2 +-
>  trunk/osdep-darwin.c    |   10 +++++++---
>  trunk/osdep-dragonfly.c |    4 ++--
>  trunk/osdep-freebsd.c   |   10 +++++++---
>  trunk/osdep-hpux.c      |    2 +-
>  trunk/osdep-linux.c     |    8 ++++++--
>  trunk/osdep-netbsd.c    |    4 ++--
>  trunk/osdep-openbsd.c   |    8 +++++---
>  trunk/osdep-sunos.c     |    8 ++++++--
>  trunk/osdep-unknown.c   |    2 +-
>  trunk/tmux.h            |    2 +-
>  13 files changed, 41 insertions(+), 23 deletions(-)
> 
> diff --git a/trunk/cmd.c b/trunk/cmd.c
> index 2413642..17d182c 100644
> --- a/trunk/cmd.c
> +++ b/trunk/cmd.c
> @@ -1296,7 +1296,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;
> diff --git a/trunk/format.c b/trunk/format.c
> index 55d51df..19f322a 100644
> --- a/trunk/format.c
> +++ b/trunk/format.c
> @@ -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/trunk/osdep-aix.c b/trunk/osdep-aix.c
> index 2a29165..8d59081 100644
> --- a/trunk/osdep-aix.c
> +++ b/trunk/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/trunk/osdep-darwin.c b/trunk/osdep-darwin.c
> index 9cac131..b112fa7 100644
> --- a/trunk/osdep-darwin.c
> +++ b/trunk/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/trunk/osdep-dragonfly.c b/trunk/osdep-dragonfly.c
> index 22045c3..ad417d9 100644
> --- a/trunk/osdep-dragonfly.c
> +++ b/trunk/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/trunk/osdep-freebsd.c b/trunk/osdep-freebsd.c
> index 1027a64..d596eab 100644
> --- a/trunk/osdep-freebsd.c
> +++ b/trunk/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/trunk/osdep-hpux.c b/trunk/osdep-hpux.c
> index c962a1f..352e375 100644
> --- a/trunk/osdep-hpux.c
> +++ b/trunk/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/trunk/osdep-linux.c b/trunk/osdep-linux.c
> index 8adf202..b65acff 100644
> --- a/trunk/osdep-linux.c
> +++ b/trunk/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/trunk/osdep-netbsd.c b/trunk/osdep-netbsd.c
> index bb2676c..f16d0dc 100644
> --- a/trunk/osdep-netbsd.c
> +++ b/trunk/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/trunk/osdep-openbsd.c b/trunk/osdep-openbsd.c
> index 4fb75bf..9eee984 100644
> --- a/trunk/osdep-openbsd.c
> +++ b/trunk/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/trunk/osdep-sunos.c b/trunk/osdep-sunos.c
> index bb67412..fd644f5 100644
> --- a/trunk/osdep-sunos.c
> +++ b/trunk/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/trunk/osdep-unknown.c b/trunk/osdep-unknown.c
> index c962a1f..41f435b 100644
> --- a/trunk/osdep-unknown.c
> +++ b/trunk/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);
>  }
> diff --git a/trunk/tmux.h b/trunk/tmux.h
> index a3d64de..ce44011 100644
> --- a/trunk/tmux.h
> +++ b/trunk/tmux.h
> @@ -2257,7 +2257,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 */
> -- 
> 1.7.10.4
> 
> 
> ------------------------------------------------------------------------------
> How fast is your code?
> 3 out of 4 devs don\\\'t know how their code performs in production.
> Find out how slow your code is with AppDynamics Lite.
> http://ad.doubleclick.net/clk;262219672;13503038;z?
> http://info.appdynamics.com/FreeJavaPerformanceDownload.html
> _______________________________________________
> tmux-users mailing list
> tmux-users@lists.sourceforge.net
> https://lists.sourceforge.net/lists/listinfo/tmux-users

------------------------------------------------------------------------------
Everyone hates slow websites. So do we.
Make your web apps faster with AppDynamics
Download AppDynamics Lite for free today:
http://ad.doubleclick.net/clk;258768047;13503038;j?
http://info.appdynamics.com/FreeJavaPerformanceDownload.html
_______________________________________________
tmux-users mailing list
tmux-users@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/tmux-users

Reply via email to