From 4a5017d1d8a7a42b47433826747e01ba6867ba46 Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Sat, 6 Feb 2010 18:29:15 +0000 Subject: [PATCH] Clean up $TMUX parsing, from Micah Cowan, tweaked by me. --- tmux.c | 48 +++++++++++++++++++++++++++++++----------------- 1 file changed, 31 insertions(+), 17 deletions(-) diff --git a/tmux.c b/tmux.c index b59dd176..c6e4f830 100644 --- a/tmux.c +++ b/tmux.c @@ -46,8 +46,14 @@ time_t start_time; char *socket_path; int login_shell; +struct env_data { + char *path; + pid_t pid; + u_int idx; +}; + __dead void usage(void); -void fill_session(struct msg_command_data *); +void parse_env(struct env_data *); char *makesockpath(const char *); __dead void shell_exec(const char *, const char *); @@ -129,9 +135,9 @@ areshell(const char *shell) } void -fill_session(struct msg_command_data *data) +parse_env(struct env_data *data) { - char *env, *ptr1, *ptr2, buf[256]; + char *env, *path_pid, *pid_idx, buf[256]; size_t len; const char *errstr; long long ll; @@ -140,19 +146,24 @@ fill_session(struct msg_command_data *data) if ((env = getenv("TMUX")) == NULL) return; - if ((ptr2 = strrchr(env, ',')) == NULL || ptr2 == env) + if ((path_pid = strchr(env, ',')) == NULL || path_pid == env) return; - for (ptr1 = ptr2 - 1; ptr1 > env && *ptr1 != ','; ptr1--) - ; - if (*ptr1 != ',') + if ((pid_idx = strchr(path_pid + 1, ',')) == NULL) + return; + if ((pid_idx == path_pid + 1 || pid_idx[1] == '\0')) return; - ptr1++; - ptr2++; - len = ptr2 - ptr1 - 1; + /* path */ + len = path_pid - env; + data->path = xmalloc (len + 1); + memcpy(data->path, env, len); + data->path[len] = '\0'; + + /* pid */ + len = pid_idx - path_pid - 1; if (len > (sizeof buf) - 1) return; - memcpy(buf, ptr1, len); + memcpy(buf, path_pid + 1, len); buf[len] = '\0'; ll = strtonum(buf, 0, LONG_MAX, &errstr); @@ -160,7 +171,8 @@ fill_session(struct msg_command_data *data) return; data->pid = ll; - ll = strtonum(ptr2, 0, UINT_MAX, &errstr); + /* idx */ + ll = strtonum(pid_idx+1, 0, UINT_MAX, &errstr); if (errstr != NULL) return; data->idx = ll; @@ -224,6 +236,7 @@ main(int argc, char **argv) struct passwd *pw; struct options *oo, *so, *wo; struct keylist *keylist; + struct env_data envdata; struct msg_command_data cmddata; char *s, *shellcmd, *path, *label, *home, *cause; char cwd[MAXPATHLEN], **var; @@ -238,6 +251,7 @@ main(int argc, char **argv) flags = 0; shellcmd = label = path = NULL; + envdata.path = NULL; login_shell = (**argv == '-'); while ((opt = getopt(argc, argv, "28c:df:lL:qS:uUv")) != -1) { switch (opt) { @@ -442,13 +456,12 @@ main(int argc, char **argv) * Figure out the socket path. If specified on the command-line with * -S or -L, use it, otherwise try $TMUX or assume -L default. */ + parse_env(&envdata); if (path == NULL) { /* No -L. Try $TMUX, or default. */ if (label == NULL) { - if ((path = getenv("TMUX")) != NULL) { - path = xstrdup(path); - path[strcspn(path, ",")] = '\0'; - } else + path = envdata.path; + if (path == NULL) label = xstrdup("default"); } @@ -468,7 +481,8 @@ main(int argc, char **argv) buf = NULL; len = 0; } else { - fill_session(&cmddata); + cmddata.pid = envdata.pid; + cmddata.idx = envdata.idx; cmddata.argc = argc; if (cmd_pack_argv(