mirror of
https://github.com/tmux/tmux.git
synced 2025-01-14 20:58:53 +00:00
Sync OpenBSD patchset 729:
New option, detach-on-destroy, to set what happens to a client when the session it is attached to is destroyed. If on (the default), it is detached; if off, it is switched to the most recently active session.
This commit is contained in:
parent
985cd3a4de
commit
fa34c76275
@ -1,4 +1,4 @@
|
|||||||
/* $Id: cmd-set-option.c,v 1.97 2010-06-05 23:56:29 tcunha Exp $ */
|
/* $Id: cmd-set-option.c,v 1.98 2010-07-02 02:45:52 tcunha Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -87,6 +87,7 @@ const struct set_option_entry set_session_option_table[] = {
|
|||||||
{ "default-path", SET_OPTION_STRING, 0, 0, NULL },
|
{ "default-path", SET_OPTION_STRING, 0, 0, NULL },
|
||||||
{ "default-shell", SET_OPTION_STRING, 0, 0, NULL },
|
{ "default-shell", SET_OPTION_STRING, 0, 0, NULL },
|
||||||
{ "default-terminal", SET_OPTION_STRING, 0, 0, NULL },
|
{ "default-terminal", SET_OPTION_STRING, 0, 0, NULL },
|
||||||
|
{ "detach-on-destroy", SET_OPTION_FLAG, 0, 0, NULL },
|
||||||
{ "display-panes-colour", SET_OPTION_COLOUR, 0, 0, NULL },
|
{ "display-panes-colour", SET_OPTION_COLOUR, 0, 0, NULL },
|
||||||
{ "display-panes-active-colour", SET_OPTION_COLOUR, 0, 0, NULL },
|
{ "display-panes-active-colour", SET_OPTION_COLOUR, 0, 0, NULL },
|
||||||
{ "display-panes-time", SET_OPTION_NUMBER, 1, INT_MAX, NULL },
|
{ "display-panes-time", SET_OPTION_NUMBER, 1, INT_MAX, NULL },
|
||||||
|
38
server-fn.c
38
server-fn.c
@ -1,4 +1,4 @@
|
|||||||
/* $Id: server-fn.c,v 1.107 2010-07-02 02:43:50 tcunha Exp $ */
|
/* $Id: server-fn.c,v 1.108 2010-07-02 02:45:52 tcunha Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -24,7 +24,8 @@
|
|||||||
|
|
||||||
#include "tmux.h"
|
#include "tmux.h"
|
||||||
|
|
||||||
void server_callback_identify(int, short, void *);
|
struct session *server_next_session(struct session *);
|
||||||
|
void server_callback_identify(int, short, void *);
|
||||||
|
|
||||||
void
|
void
|
||||||
server_fill_environ(struct session *s, struct environ *env)
|
server_fill_environ(struct session *s, struct environ *env)
|
||||||
@ -358,18 +359,47 @@ server_destroy_session_group(struct session *s)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct session *
|
||||||
|
server_next_session(struct session *s)
|
||||||
|
{
|
||||||
|
struct session *s_loop, *s_out;
|
||||||
|
u_int i;
|
||||||
|
|
||||||
|
s_out = NULL;
|
||||||
|
for (i = 0; i < ARRAY_LENGTH(&sessions); i++) {
|
||||||
|
s_loop = ARRAY_ITEM(&sessions, i);
|
||||||
|
if (s_loop == s)
|
||||||
|
continue;
|
||||||
|
if (s_out == NULL ||
|
||||||
|
timercmp(&s_loop->activity_time, &s_out->activity_time, <))
|
||||||
|
s_out = s_loop;
|
||||||
|
}
|
||||||
|
return (s_out);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
server_destroy_session(struct session *s)
|
server_destroy_session(struct session *s)
|
||||||
{
|
{
|
||||||
struct client *c;
|
struct client *c;
|
||||||
|
struct session *s_new;
|
||||||
u_int i;
|
u_int i;
|
||||||
|
|
||||||
|
if (!options_get_number(&s->options, "detach-on-destroy"))
|
||||||
|
s_new = server_next_session(s);
|
||||||
|
else
|
||||||
|
s_new = NULL;
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_LENGTH(&clients); i++) {
|
for (i = 0; i < ARRAY_LENGTH(&clients); i++) {
|
||||||
c = ARRAY_ITEM(&clients, i);
|
c = ARRAY_ITEM(&clients, i);
|
||||||
if (c == NULL || c->session != s)
|
if (c == NULL || c->session != s)
|
||||||
continue;
|
continue;
|
||||||
c->session = NULL;
|
if (s_new == NULL) {
|
||||||
server_write_client(c, MSG_EXIT, NULL, 0);
|
c->session = NULL;
|
||||||
|
server_write_client(c, MSG_EXIT, NULL, 0);
|
||||||
|
} else {
|
||||||
|
c->session = s_new;
|
||||||
|
server_redraw_client(c);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
recalculate_sizes();
|
recalculate_sizes();
|
||||||
}
|
}
|
||||||
|
9
tmux.1
9
tmux.1
@ -1,4 +1,4 @@
|
|||||||
.\" $Id: tmux.1,v 1.260 2010-06-22 23:35:20 tcunha Exp $
|
.\" $Id: tmux.1,v 1.261 2010-07-02 02:45:52 tcunha Exp $
|
||||||
.\"
|
.\"
|
||||||
.\" Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
.\" Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
.\"
|
.\"
|
||||||
@ -14,7 +14,7 @@
|
|||||||
.\" IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
|
.\" IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
|
||||||
.\" OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
.\" OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
.\"
|
.\"
|
||||||
.Dd $Mdocdate: June 21 2010 $
|
.Dd $Mdocdate: June 27 2010 $
|
||||||
.Dt TMUX 1
|
.Dt TMUX 1
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
@ -1557,6 +1557,11 @@ Available window options are listed under
|
|||||||
.Pp
|
.Pp
|
||||||
Available server options are:
|
Available server options are:
|
||||||
.Bl -tag -width Ds
|
.Bl -tag -width Ds
|
||||||
|
.It Ic detach-on-destroy
|
||||||
|
If on (the default), the client is detached when the session it is attached to
|
||||||
|
is destroyed.
|
||||||
|
If off, the client is switched to the most recently active of the remaining
|
||||||
|
sessions.
|
||||||
.It Ic escape-time
|
.It Ic escape-time
|
||||||
Set the time in milliseconds for which
|
Set the time in milliseconds for which
|
||||||
.Nm
|
.Nm
|
||||||
|
5
tmux.c
5
tmux.c
@ -1,4 +1,4 @@
|
|||||||
/* $Id: tmux.c,v 1.210 2010-07-02 02:43:01 tcunha Exp $ */
|
/* $Id: tmux.c,v 1.211 2010-07-02 02:45:52 tcunha Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -344,8 +344,9 @@ main(int argc, char **argv)
|
|||||||
options_set_string(so, "default-command", "%s", "");
|
options_set_string(so, "default-command", "%s", "");
|
||||||
options_set_string(so, "default-shell", "%s", getshell());
|
options_set_string(so, "default-shell", "%s", getshell());
|
||||||
options_set_string(so, "default-terminal", "screen");
|
options_set_string(so, "default-terminal", "screen");
|
||||||
options_set_number(so, "display-panes-colour", 4);
|
options_set_number(so, "detach-on-destroy", 1);
|
||||||
options_set_number(so, "display-panes-active-colour", 1);
|
options_set_number(so, "display-panes-active-colour", 1);
|
||||||
|
options_set_number(so, "display-panes-colour", 4);
|
||||||
options_set_number(so, "display-panes-time", 1000);
|
options_set_number(so, "display-panes-time", 1000);
|
||||||
options_set_number(so, "display-time", 750);
|
options_set_number(so, "display-time", 750);
|
||||||
options_set_number(so, "history-limit", 2000);
|
options_set_number(so, "history-limit", 2000);
|
||||||
|
Loading…
Reference in New Issue
Block a user