mirror of
https://github.com/tmux/tmux.git
synced 2025-01-05 23:38:48 +00:00
Run status update on a per-client timer at status-interval.
This commit is contained in:
parent
18d4802a7b
commit
75d10058a4
@ -133,6 +133,7 @@ cmd_attach_session(struct cmd_q *cmdq, const char *tflag, int dflag, int rflag,
|
||||
}
|
||||
|
||||
c->session = s;
|
||||
status_timer_start(c);
|
||||
notify_attached_session_changed(c);
|
||||
session_update_activity(s);
|
||||
server_redraw_client(c);
|
||||
@ -177,6 +178,7 @@ cmd_attach_session(struct cmd_q *cmdq, const char *tflag, int dflag, int rflag,
|
||||
}
|
||||
|
||||
c->session = s;
|
||||
status_timer_start(c);
|
||||
notify_attached_session_changed(c);
|
||||
session_update_activity(s);
|
||||
server_redraw_client(c);
|
||||
|
@ -275,6 +275,7 @@ cmd_new_session_exec(struct cmd *self, struct cmd_q *cmdq)
|
||||
else if (c->session != NULL)
|
||||
c->last_session = c->session;
|
||||
c->session = s;
|
||||
status_timer_start(c);
|
||||
notify_attached_session_changed(c);
|
||||
session_update_activity(s);
|
||||
server_redraw_client(c);
|
||||
|
@ -176,7 +176,7 @@ cmd_set_option_exec(struct cmd *self, struct cmd_q *cmdq)
|
||||
return (CMD_RETURN_ERROR);
|
||||
}
|
||||
|
||||
/* Start or stop timers when automatic-rename changed. */
|
||||
/* Start or stop timers when name or status options changed. */
|
||||
if (strcmp(oe->name, "automatic-rename") == 0) {
|
||||
RB_FOREACH(w, windows, &windows) {
|
||||
if (options_get_number(&w->options, "automatic-rename"))
|
||||
@ -185,6 +185,9 @@ cmd_set_option_exec(struct cmd *self, struct cmd_q *cmdq)
|
||||
evtimer_del(&w->name_timer);
|
||||
}
|
||||
}
|
||||
if (strcmp(oe->name, "status") == 0 ||
|
||||
strcmp(oe->name, "status-interval") == 0)
|
||||
status_timer_start_all();
|
||||
|
||||
/* Update sizes and redraw. May not need it but meh. */
|
||||
recalculate_sizes();
|
||||
|
@ -127,6 +127,7 @@ cmd_switch_client_exec(struct cmd *self, struct cmd_q *cmdq)
|
||||
if (c->session != NULL)
|
||||
c->last_session = c->session;
|
||||
c->session = s;
|
||||
status_timer_start(c);
|
||||
session_update_activity(s);
|
||||
|
||||
recalculate_sizes();
|
||||
|
2
format.c
2
format.c
@ -247,7 +247,7 @@ format_job_timer(unused int fd, unused short events, unused void *arg)
|
||||
if (fj->job != NULL)
|
||||
job_free(fj->job);
|
||||
|
||||
free((void*)fj->cmd);
|
||||
free((void *)fj->cmd);
|
||||
free(fj->out);
|
||||
|
||||
free(fj);
|
||||
|
@ -188,6 +188,8 @@ server_client_lost(struct client *c)
|
||||
if (c->stderr_data != c->stdout_data)
|
||||
evbuffer_free(c->stderr_data);
|
||||
|
||||
if (event_initialized(&c->status_timer))
|
||||
evtimer_del(&c->status_timer);
|
||||
screen_free(&c->status);
|
||||
|
||||
free(c->title);
|
||||
@ -289,42 +291,6 @@ client_lost:
|
||||
server_client_lost(c);
|
||||
}
|
||||
|
||||
/* Handle client status timer. */
|
||||
void
|
||||
server_client_status_timer(void)
|
||||
{
|
||||
struct client *c;
|
||||
struct session *s;
|
||||
struct timeval tv;
|
||||
int interval;
|
||||
time_t difference;
|
||||
|
||||
if (gettimeofday(&tv, NULL) != 0)
|
||||
fatal("gettimeofday failed");
|
||||
|
||||
TAILQ_FOREACH(c, &clients, entry) {
|
||||
if (c->session == NULL)
|
||||
continue;
|
||||
if (c->message_string != NULL || c->prompt_string != NULL) {
|
||||
/*
|
||||
* Don't need timed redraw for messages/prompts so bail
|
||||
* now. The status timer isn't reset when they are
|
||||
* redrawn anyway.
|
||||
*/
|
||||
continue;
|
||||
}
|
||||
s = c->session;
|
||||
|
||||
if (!options_get_number(&s->options, "status"))
|
||||
continue;
|
||||
interval = options_get_number(&s->options, "status-interval");
|
||||
|
||||
difference = tv.tv_sec - c->status_timer.tv_sec;
|
||||
if (interval != 0 && difference >= interval)
|
||||
c->flags |= CLIENT_STATUS;
|
||||
}
|
||||
}
|
||||
|
||||
/* Check for mouse keys. */
|
||||
int
|
||||
server_client_check_mouse(struct client *c)
|
||||
|
@ -419,6 +419,7 @@ server_destroy_session(struct session *s)
|
||||
} else {
|
||||
c->last_session = NULL;
|
||||
c->session = s_new;
|
||||
status_timer_start(c);
|
||||
notify_attached_session_changed(c);
|
||||
session_update_activity(s_new);
|
||||
server_redraw_client(c);
|
||||
|
2
server.c
2
server.c
@ -520,8 +520,6 @@ server_second_callback(unused int fd, unused short events, unused void *arg)
|
||||
}
|
||||
}
|
||||
|
||||
server_client_status_timer();
|
||||
|
||||
evtimer_del(&server_ev_second);
|
||||
memset(&tv, 0, sizeof tv);
|
||||
tv.tv_sec = 1;
|
||||
|
56
status.c
56
status.c
@ -37,6 +37,7 @@ char *status_print(struct client *, struct winlink *, time_t,
|
||||
struct grid_cell *);
|
||||
char *status_replace(struct client *, struct winlink *, const char *, time_t);
|
||||
void status_message_callback(int, short, void *);
|
||||
void status_timer_callback(int, short, void *);
|
||||
|
||||
const char *status_prompt_up_history(u_int *);
|
||||
const char *status_prompt_down_history(u_int *);
|
||||
@ -142,6 +143,55 @@ status_prompt_save_history(void)
|
||||
|
||||
}
|
||||
|
||||
/* Status timer callback. */
|
||||
void
|
||||
status_timer_callback(unused int fd, unused short events, void *arg)
|
||||
{
|
||||
struct client *c = arg;
|
||||
struct session *s = c->session;
|
||||
struct timeval tv;
|
||||
|
||||
evtimer_del(&c->status_timer);
|
||||
|
||||
if (s == NULL)
|
||||
return;
|
||||
|
||||
if (c->message_string == NULL && c->prompt_string == NULL)
|
||||
c->flags |= CLIENT_STATUS;
|
||||
|
||||
timerclear(&tv);
|
||||
tv.tv_sec = options_get_number(&s->options, "status-interval");
|
||||
|
||||
if (tv.tv_sec != 0)
|
||||
evtimer_add(&c->status_timer, &tv);
|
||||
log_debug("client %d, status interval %d", c->ibuf.fd, (int)tv.tv_sec);
|
||||
}
|
||||
|
||||
/* Start status timer for client. */
|
||||
void
|
||||
status_timer_start(struct client *c)
|
||||
{
|
||||
struct session *s = c->session;
|
||||
|
||||
if (event_initialized(&c->status_timer))
|
||||
evtimer_del(&c->status_timer);
|
||||
else
|
||||
evtimer_set(&c->status_timer, status_timer_callback, c);
|
||||
|
||||
if (s != NULL && options_get_number(&s->options, "status"))
|
||||
status_timer_callback(-1, 0, c);
|
||||
}
|
||||
|
||||
/* Start status timer for all clients. */
|
||||
void
|
||||
status_timer_start_all(void)
|
||||
{
|
||||
struct client *c;
|
||||
|
||||
TAILQ_FOREACH(c, &clients, entry)
|
||||
status_timer_start(c);
|
||||
}
|
||||
|
||||
/* Get screen line of status line. -1 means off. */
|
||||
int
|
||||
status_at_line(struct client *c)
|
||||
@ -244,10 +294,8 @@ status_redraw(struct client *c)
|
||||
left = right = NULL;
|
||||
larrow = rarrow = 0;
|
||||
|
||||
/* Update status timer. */
|
||||
if (gettimeofday(&c->status_timer, NULL) != 0)
|
||||
fatal("gettimeofday failed");
|
||||
t = c->status_timer.tv_sec;
|
||||
/* Store current time. */
|
||||
t = time(NULL);
|
||||
|
||||
/* Set up default colour. */
|
||||
style_apply(&stdgc, &s->options, "status-style");
|
||||
|
4
tmux.h
4
tmux.h
@ -1207,7 +1207,7 @@ struct client {
|
||||
|
||||
struct event repeat_timer;
|
||||
|
||||
struct timeval status_timer;
|
||||
struct event status_timer;
|
||||
struct screen status;
|
||||
|
||||
#define CLIENT_TERMINAL 0x1
|
||||
@ -1893,6 +1893,8 @@ int server_set_stdin_callback(struct client *, void (*)(struct client *,
|
||||
void server_unzoom_window(struct window *);
|
||||
|
||||
/* status.c */
|
||||
void status_timer_start(struct client *);
|
||||
void status_timer_start_all(void);
|
||||
int status_at_line(struct client *);
|
||||
struct window *status_get_window_at(struct client *, u_int);
|
||||
int status_redraw(struct client *);
|
||||
|
Loading…
Reference in New Issue
Block a user