aboutsummaryrefslogtreecommitdiff
path: root/server.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicholas.marriott@gmail.com>2008-06-06 17:55:27 +0000
committerNicholas Marriott <nicholas.marriott@gmail.com>2008-06-06 17:55:27 +0000
commit3cd4a08ffb4bcba0cfbb8a29574ff40d134dc186 (patch)
tree321523836e1c269edaab4a07caa1a41546501a84 /server.c
parent6a187bb8d379b6f3b77adcd3550ab31dc8058030 (diff)
downloadrtmux-3cd4a08ffb4bcba0cfbb8a29574ff40d134dc186.tar.gz
rtmux-3cd4a08ffb4bcba0cfbb8a29574ff40d134dc186.tar.bz2
rtmux-3cd4a08ffb4bcba0cfbb8a29574ff40d134dc186.zip
Make server exit when last session dies. Also fix window check for status activity redraw.
Diffstat (limited to 'server.c')
-rw-r--r--server.c24
1 files changed, 20 insertions, 4 deletions
diff --git a/server.c b/server.c
index cda95dde..0d20b298 100644
--- a/server.c
+++ b/server.c
@@ -1,4 +1,4 @@
-/* $Id: server.c,v 1.54 2008-06-06 17:20:29 nicm Exp $ */
+/* $Id: server.c,v 1.55 2008-06-06 17:55:27 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -142,7 +142,7 @@ server_main(const char *srv_path, int srv_fd)
{
struct pollfd *pfds, *pfd;
int nfds;
- u_int i;
+ u_int i, n;
siginit();
@@ -188,6 +188,22 @@ server_main(const char *srv_path, int srv_fd)
*/
server_handle_windows(&pfd);
server_handle_clients(&pfd);
+
+ /*
+ * If we have no sessions and clients left, let's get out
+ * of here...
+ */
+ n = 0;
+ for (i = 0; i < ARRAY_LENGTH(&sessions); i++) {
+ if (ARRAY_ITEM(&sessions, i) != NULL)
+ n++;
+ }
+ for (i = 0; i < ARRAY_LENGTH(&clients); i++) {
+ if (ARRAY_ITEM(&clients, i) != NULL)
+ n++;
+ }
+ if (n == 0)
+ break;
}
if (pfds != NULL)
xfree(pfds);
@@ -430,7 +446,7 @@ server_handle_window(struct window *w)
continue;
if (w->flags & WINDOW_BELL &&
- !session_alert_has(s, w, WINDOW_BELL)) {
+ !session_alert_has_window(s, w, WINDOW_BELL)) {
session_alert_add(s, w, WINDOW_BELL);
action = options_get_number(&s->options, "bell-action");
@@ -449,7 +465,7 @@ server_handle_window(struct window *w)
if ((w->flags & WINDOW_MONITOR) &&
(w->flags & WINDOW_ACTIVITY) &&
- !session_alert_has(s, w, WINDOW_ACTIVITY)) {
+ !session_alert_has_window(s, w, WINDOW_ACTIVITY)) {
session_alert_add(s, w, WINDOW_ACTIVITY);
update = 1;
}