Add three new session options: visual-activity, visual-bell, visual-content. If

these are enabled (and the monitor-activity, bell-actio and monitor-content
options are configurated appropriately), when activity, a bell, or content is
detected, a message is shown.

Also tidy up the bell/activity/content code in server.c slightly and fix a
couple of errors.
This commit is contained in:
Nicholas Marriott 2009-07-18 14:59:25 +00:00
parent 0ca6f667e3
commit fc6a65c620
5 changed files with 104 additions and 18 deletions

View File

@ -75,6 +75,9 @@ const struct set_option_entry set_option_table[] = {
{ "status-right", SET_OPTION_STRING, 0, 0, NULL }, { "status-right", SET_OPTION_STRING, 0, 0, NULL },
{ "status-right-length", SET_OPTION_NUMBER, 0, SHRT_MAX, NULL }, { "status-right-length", SET_OPTION_NUMBER, 0, SHRT_MAX, NULL },
{ "status-utf8", SET_OPTION_FLAG, 0, 0, NULL }, { "status-utf8", SET_OPTION_FLAG, 0, 0, NULL },
{ "visual-activity", SET_OPTION_FLAG, 0, 0, NULL },
{ "visual-bell", SET_OPTION_FLAG, 0, 0, NULL },
{ "visual-content", SET_OPTION_FLAG, 0, 0, NULL },
{ NULL, 0, 0, 0, NULL } { NULL, 0, 0, 0, NULL }
}; };

View File

@ -55,8 +55,7 @@ void server_handle_clients(struct pollfd **);
struct client *server_accept_client(int); struct client *server_accept_client(int);
void server_handle_client(struct client *); void server_handle_client(struct client *);
void server_handle_window(struct window *, struct window_pane *); void server_handle_window(struct window *, struct window_pane *);
int server_check_window_bell(struct session *, struct window *, int server_check_window_bell(struct session *, struct window *);
struct window_pane *);
int server_check_window_activity(struct session *, int server_check_window_activity(struct session *,
struct window *); struct window *);
int server_check_window_content(struct session *, struct window *, int server_check_window_content(struct session *, struct window *,
@ -909,7 +908,7 @@ server_handle_window(struct window *w, struct window_pane *wp)
if (s == NULL || !session_has(s, w)) if (s == NULL || !session_has(s, w))
continue; continue;
update += server_check_window_bell(s, w, wp); update += server_check_window_bell(s, w);
update += server_check_window_activity(s, w); update += server_check_window_activity(s, w);
update += server_check_window_content(s, w, wp); update += server_check_window_content(s, w, wp);
} }
@ -920,12 +919,11 @@ server_handle_window(struct window *w, struct window_pane *wp)
} }
int int
server_check_window_bell( server_check_window_bell(struct session *s, struct window *w)
struct session *s, struct window *w, struct window_pane *wp)
{ {
struct client *c; struct client *c;
u_int i; u_int i;
int action; int action, visual;
if (!(w->flags & WINDOW_BELL)) if (!(w->flags & WINDOW_BELL))
return (0); return (0);
@ -938,19 +936,38 @@ server_check_window_bell(
case BELL_ANY: case BELL_ANY:
if (s->flags & SESSION_UNATTACHED) if (s->flags & SESSION_UNATTACHED)
break; break;
visual = options_get_number(&s->options, "visual-bell");
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;
if (!visual) {
tty_putcode(&c->tty, TTYC_BEL); tty_putcode(&c->tty, TTYC_BEL);
continue;
}
if (c->session->curw->window == w) {
status_message_set(c, "Bell in current window");
continue;
}
status_message_set(c, "Bell in window %u",
winlink_find_by_window(&s->windows, w)->idx);
} }
break; break;
case BELL_CURRENT: case BELL_CURRENT:
if (w->active != wp) if (s->flags & SESSION_UNATTACHED)
break; break;
visual = options_get_number(&s->options, "visual-bell");
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;
if (c->session->curw->window != w)
continue;
if (!visual) {
tty_putcode(&c->tty, TTYC_BEL); tty_putcode(&c->tty, TTYC_BEL);
continue;
}
status_message_set(c, "Bell in current window");
} }
break; break;
} }
@ -960,13 +977,33 @@ server_check_window_bell(
int int
server_check_window_activity(struct session *s, struct window *w) server_check_window_activity(struct session *s, struct window *w)
{ {
struct client *c;
u_int i;
if (!(w->flags & WINDOW_ACTIVITY)) if (!(w->flags & WINDOW_ACTIVITY))
return (0); return (0);
if (!options_get_number(&w->options, "monitor-activity")) if (!options_get_number(&w->options, "monitor-activity"))
return (0); return (0);
if (session_alert_has_window(s, w, WINDOW_ACTIVITY)) if (session_alert_has_window(s, w, WINDOW_ACTIVITY))
return (0); return (0);
if (s->curw->window == w)
return (0);
session_alert_add(s, w, WINDOW_ACTIVITY); session_alert_add(s, w, WINDOW_ACTIVITY);
if (s->flags & SESSION_UNATTACHED)
return (0);
if (options_get_number(&s->options, "visual-activity")) {
for (i = 0; i < ARRAY_LENGTH(&clients); i++) {
c = ARRAY_ITEM(&clients, i);
if (c == NULL || c->session != s)
continue;
status_message_set(c, "Activity in window %u",
winlink_find_by_window(&s->windows, w)->idx);
}
}
return (1); return (1);
} }
@ -974,20 +1011,39 @@ int
server_check_window_content( server_check_window_content(
struct session *s, struct window *w, struct window_pane *wp) struct session *s, struct window *w, struct window_pane *wp)
{ {
char *found, *ptr; struct client *c;
u_int i;
char *found, *ptr;
if (!(w->flags & WINDOW_ACTIVITY)) /* activity for new content */
return (0);
if (!(w->flags & WINDOW_CONTENT)) ptr = options_get_string(&w->options, "monitor-content");
return (0); if (ptr == NULL || *ptr == '\0')
if ((ptr = options_get_string(&w->options, "monitor-content")) == NULL)
return (0);
if (*ptr == '\0')
return (0); return (0);
if (session_alert_has_window(s, w, WINDOW_CONTENT)) if (session_alert_has_window(s, w, WINDOW_CONTENT))
return (0); return (0);
if (s->curw->window == w)
return (0);
if ((found = window_pane_search(wp, ptr, NULL)) == NULL) if ((found = window_pane_search(wp, ptr, NULL)) == NULL)
return (0); return (0);
session_alert_add(s, w, WINDOW_CONTENT);
xfree(found); xfree(found);
session_alert_add(s, w, WINDOW_CONTENT);
if (s->flags & SESSION_UNATTACHED)
return (0);
if (options_get_number(&s->options, "visual-content")) {
for (i = 0; i < ARRAY_LENGTH(&clients); i++) {
c = ARRAY_ITEM(&clients, i);
if (c == NULL || c->session != s)
continue;
status_message_set(c, "Content in window %u",
winlink_find_by_window(&s->windows, w)->idx);
}
}
return (1); return (1);
} }

24
tmux.1
View File

@ -1324,6 +1324,30 @@ and
.Ic status-right .Ic status-right
strings as UTF-8; notably, this is important for wide characters. strings as UTF-8; notably, this is important for wide characters.
This option defaults to off. This option defaults to off.
.It Xo Ic visual-activity
.Op Ic on | Ic off
.Xc
If on, display a status line message when activity occurs in a window
for with the
.Ic monitor-activity
window option is enabled.
.It Xo Ic visual-bell
.Op Ic on | Ic off
.Xc
If this option is on, a message is shown on a bell instead of it being passed
through to the terminal (which normally makes a sound).
Also see the
.Ic bell-action
option.
.It Xo Ic visual-content
.Op Ic on | Ic off
.Xc
Like
.Ic visual-activity ,
display a message when content is present in a window
for with the
.Ic monitor-content
window option is enabled.
.El .El
.It Xo Ic set-password .It Xo Ic set-password
.Op Fl c .Op Fl c

3
tmux.c
View File

@ -312,6 +312,9 @@ main(int argc, char **argv)
options_set_number(&global_s_options, "status-utf8", 1); options_set_number(&global_s_options, "status-utf8", 1);
else else
options_set_number(&global_s_options, "status-utf8", 0); options_set_number(&global_s_options, "status-utf8", 0);
options_set_number(&global_s_options, "visual-activity", 0);
options_set_number(&global_s_options, "visual-bell", 0);
options_set_number(&global_s_options, "visual-content", 0);
options_init(&global_w_options, NULL); options_init(&global_w_options, NULL);
options_set_number(&global_w_options, "aggressive-resize", 0); options_set_number(&global_w_options, "aggressive-resize", 0);

4
tmux.h
View File

@ -644,8 +644,8 @@ struct window {
#define WINDOW_BELL 0x1 #define WINDOW_BELL 0x1
#define WINDOW_HIDDEN 0x2 #define WINDOW_HIDDEN 0x2
#define WINDOW_ACTIVITY 0x4 #define WINDOW_ACTIVITY 0x4
#define WINDOW_CONTENT 0x6 #define WINDOW_CONTENT 0x8
#define WINDOW_REDRAW 0x8 #define WINDOW_REDRAW 0x10
struct options options; struct options options;