diff options
author | Tiago Cunha <tcunha@gmx.com> | 2009-07-23 13:19:12 +0000 |
---|---|---|
committer | Tiago Cunha <tcunha@gmx.com> | 2009-07-23 13:19:12 +0000 |
commit | a551ff2b1befc91e17bc73b478da52342a56815e (patch) | |
tree | 6e9951fbbd7e1990d08e2ba5f953db776f3a1274 /cmd-new-session.c | |
parent | 7174c76bf0fadc220e04de2f8ab92ebae117b510 (diff) | |
download | rtmux-a551ff2b1befc91e17bc73b478da52342a56815e.tar.gz rtmux-a551ff2b1befc91e17bc73b478da52342a56815e.tar.bz2 rtmux-a551ff2b1befc91e17bc73b478da52342a56815e.zip |
Sync OpenBSD patchset 167:
If there is a current session, use its default path and working directory for
the initial window when creating a new session.
Diffstat (limited to 'cmd-new-session.c')
-rw-r--r-- | cmd-new-session.c | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/cmd-new-session.c b/cmd-new-session.c index 70e5dbf5..4b8e252a 100644 --- a/cmd-new-session.c +++ b/cmd-new-session.c @@ -1,4 +1,4 @@ -/* $Id: cmd-new-session.c,v 1.45 2009-07-18 11:06:09 nicm Exp $ */ +/* $Id: cmd-new-session.c,v 1.46 2009-07-23 13:19:12 tcunha Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> @@ -112,6 +112,7 @@ cmd_new_session_exec(struct cmd *self, struct cmd_ctx *ctx) { struct cmd_new_session_data *data = self->data; struct session *s; + struct options *oo; char *cmd, *cwd, *cause; u_int sx, sy; @@ -149,6 +150,14 @@ cmd_new_session_exec(struct cmd *self, struct cmd_ctx *ctx) } } + /* + * If the called from inside, use the source session for the default + * path and command. + */ + oo = &global_s_options; + if (ctx->cmdclient == NULL) + oo = &ctx->curclient->session->options; + /* Find new session size and options. */ if (data->flag_detached) { sx = 80; @@ -162,7 +171,7 @@ cmd_new_session_exec(struct cmd *self, struct cmd_ctx *ctx) sy = ctx->curclient->tty.sy; } } - if (sy > 0 && options_get_number(&global_s_options, "status")) + if (sy > 0 && options_get_number(oo, "status")) sy--; if (sx == 0) sx = 1; @@ -171,11 +180,11 @@ cmd_new_session_exec(struct cmd *self, struct cmd_ctx *ctx) if (ctx->cmdclient != NULL && ctx->cmdclient->cwd != NULL) cwd = ctx->cmdclient->cwd; else - cwd = options_get_string(&global_s_options, "default-path"); + cwd = options_get_string(oo, "default-path"); if (data->cmd != NULL) cmd = data->cmd; else - cmd = options_get_string(&global_s_options, "default-command"); + cmd = options_get_string(oo, "default-command"); /* Create the new session. */ s = session_create(data->newname, cmd, cwd, sx, sy, &cause); |