summaryrefslogtreecommitdiff
path: root/usr.bin/tmux/tmux.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.bin/tmux/tmux.c')
-rw-r--r--usr.bin/tmux/tmux.c50
1 files changed, 32 insertions, 18 deletions
diff --git a/usr.bin/tmux/tmux.c b/usr.bin/tmux/tmux.c
index 2e56eab2d7f..7918c8ae5f7 100644
--- a/usr.bin/tmux/tmux.c
+++ b/usr.bin/tmux/tmux.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: tmux.c,v 1.69 2010/02/06 17:15:33 nicm Exp $ */
+/* $OpenBSD: tmux.c,v 1.70 2010/02/06 18:29:15 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -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;
- ptr1++;
- ptr2++;
+ if ((pid_idx == path_pid + 1 || pid_idx[1] == '\0'))
+ return;
+
+ /* path */
+ len = path_pid - env;
+ data->path = xmalloc (len + 1);
+ memcpy(data->path, env, len);
+ data->path[len] = '\0';
- len = ptr2 - ptr1 - 1;
+ /* 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(