summaryrefslogtreecommitdiff
path: root/usr.bin/tmux/server-fn.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@cvs.openbsd.org>2010-06-27 00:22:23 +0000
committerNicholas Marriott <nicm@cvs.openbsd.org>2010-06-27 00:22:23 +0000
commit1614421baddf7c0248e941128db3ea2e704e6c70 (patch)
tree3f374b65b71373d0f2dba67a55cd0699c9044926 /usr.bin/tmux/server-fn.c
parentfa5bd8327c7cdb17542e820cdd0162eb31df213a (diff)
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.
Diffstat (limited to 'usr.bin/tmux/server-fn.c')
-rw-r--r--usr.bin/tmux/server-fn.c38
1 files changed, 34 insertions, 4 deletions
diff --git a/usr.bin/tmux/server-fn.c b/usr.bin/tmux/server-fn.c
index 155bdfe380d..b4fc48f1a36 100644
--- a/usr.bin/tmux/server-fn.c
+++ b/usr.bin/tmux/server-fn.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: server-fn.c,v 1.38 2010/06/26 23:55:50 nicm Exp $ */
+/* $OpenBSD: server-fn.c,v 1.39 2010/06/27 00:22:22 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -24,7 +24,8 @@
#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
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
server_destroy_session(struct session *s)
{
struct client *c;
+ struct session *s_new;
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++) {
c = ARRAY_ITEM(&clients, i);
if (c == NULL || c->session != s)
continue;
- c->session = NULL;
- server_write_client(c, MSG_EXIT, NULL, 0);
+ if (s_new == NULL) {
+ c->session = NULL;
+ server_write_client(c, MSG_EXIT, NULL, 0);
+ } else {
+ c->session = s_new;
+ server_redraw_client(c);
+ }
}
recalculate_sizes();
}