From ffdb1c7765a565e491fab9fdfa7cc59d46bea393 Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Wed, 4 Nov 2009 23:54:58 +0000 Subject: Change window name change to use a timer event rather than a gettimeofday() check every loop. --- usr.bin/tmux/names.c | 99 +++++++++++++++++++++----------------------- usr.bin/tmux/server-window.c | 4 +- usr.bin/tmux/tmux.h | 6 +-- usr.bin/tmux/window.c | 15 +++---- 4 files changed, 58 insertions(+), 66 deletions(-) (limited to 'usr.bin/tmux') diff --git a/usr.bin/tmux/names.c b/usr.bin/tmux/names.c index e21d7f3cad6..edc2f86f1d5 100644 --- a/usr.bin/tmux/names.c +++ b/usr.bin/tmux/names.c @@ -1,4 +1,4 @@ -/* $OpenBSD: names.c,v 1.8 2009/10/10 15:23:13 nicm Exp $ */ +/* $OpenBSD: names.c,v 1.9 2009/11/04 23:54:57 nicm Exp $ */ /* * Copyright (c) 2009 Nicholas Marriott @@ -25,67 +25,64 @@ #include "tmux.h" +void window_name_callback(unused int, unused short, void *); char *parse_window_name(const char *); void -set_window_names(void) +queue_window_name(struct window *w) { - struct window *w; - u_int i; - char *name, *wname; - struct timeval tv, tv2; + struct timeval tv; - if (gettimeofday(&tv, NULL) != 0) - fatal("gettimeofday failed"); + tv.tv_sec = 0; + tv.tv_usec = NAME_INTERVAL * 1000L; - for (i = 0; i < ARRAY_LENGTH(&windows); i++) { - w = ARRAY_ITEM(&windows, i); - if (w == NULL || w->active == NULL) - continue; + evtimer_del(&w->name_timer); + evtimer_set(&w->name_timer, window_name_callback, w); + evtimer_add(&w->name_timer, &tv); +} - if (timercmp(&tv, &w->name_timer, <)) - continue; - memcpy(&w->name_timer, &tv, sizeof w->name_timer); - tv2.tv_sec = 0; - tv2.tv_usec = NAME_INTERVAL * 1000L; - timeradd(&w->name_timer, &tv2, &w->name_timer); +void +window_name_callback(unused int fd, unused short events, void *data) +{ + struct window *w = data; + char *name, *wname; - if (!options_get_number(&w->options, "automatic-rename")) - continue; + queue_window_name(w); /* XXX even if the option is off? */ + if (!options_get_number(&w->options, "automatic-rename")) + return; - if (w->active->screen != &w->active->base) - name = NULL; + if (w->active->screen != &w->active->base) + name = NULL; + else + name = get_proc_name(w->active->fd, w->active->tty); + if (name == NULL) + wname = default_window_name(w); + else { + /* + * If tmux is using the default command, it will be a login + * shell and argv[0] may have a - prefix. Remove this if it is + * present. Ick. + */ + if (w->active->cmd != NULL && *w->active->cmd == '\0' && + name != NULL && name[0] == '-' && name[1] != '\0') + wname = parse_window_name(name + 1); else - name = get_proc_name(w->active->fd, w->active->tty); - if (name == NULL) - wname = default_window_name(w); - else { - /* - * If tmux is using the default command, it will be a - * login shell and argv[0] may have a - prefix. Remove - * this if it is present. Ick. - */ - if (w->active->cmd != NULL && *w->active->cmd == '\0' && - name != NULL && name[0] == '-' && name[1] != '\0') - wname = parse_window_name(name + 1); - else wname = parse_window_name(name); - xfree(name); - } - - if (w->active->fd == -1) { - xasprintf(&name, "%s[dead]", wname); - xfree(wname); - wname = name; - } - - if (strcmp(wname, w->name) == 0) - xfree(wname); - else { - xfree(w->name); - w->name = wname; - server_status_window(w); - } + xfree(name); + } + + if (w->active->fd == -1) { + xasprintf(&name, "%s[dead]", wname); + xfree(wname); + wname = name; + } + + if (strcmp(wname, w->name) == 0) + xfree(wname); + else { + xfree(w->name); + w->name = wname; + server_status_window(w); } } diff --git a/usr.bin/tmux/server-window.c b/usr.bin/tmux/server-window.c index f618fa2f6ab..f4fafb8244a 100644 --- a/usr.bin/tmux/server-window.c +++ b/usr.bin/tmux/server-window.c @@ -1,4 +1,4 @@ -/* $OpenBSD: server-window.c,v 1.9 2009/11/04 22:43:11 nicm Exp $ */ +/* $OpenBSD: server-window.c,v 1.10 2009/11/04 23:54:57 nicm Exp $ */ /* * Copyright (c) 2009 Nicholas Marriott @@ -91,8 +91,6 @@ server_window_loop(void) server_window_check_alive(w); } - - set_window_names(); } /* Check for bell in window. */ diff --git a/usr.bin/tmux/tmux.h b/usr.bin/tmux/tmux.h index 2250bd6251a..289cae8d18a 100644 --- a/usr.bin/tmux/tmux.h +++ b/usr.bin/tmux/tmux.h @@ -1,4 +1,4 @@ -/* $OpenBSD: tmux.h,v 1.167 2009/11/04 23:42:51 nicm Exp $ */ +/* $OpenBSD: tmux.h,v 1.168 2009/11/04 23:54:57 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott @@ -810,7 +810,7 @@ TAILQ_HEAD(window_panes, window_pane); /* Window structure. */ struct window { char *name; - struct timeval name_timer; + struct event name_timer; struct window_pane *active; struct window_panes panes; @@ -1851,7 +1851,7 @@ void window_choose_ready(struct window_pane *, u_int, void (*)(void *, int), void (*)(void *), void *); /* names.c */ -void set_window_names(void); +void queue_window_name(struct window *); char *default_window_name(struct window *); /* session.c */ diff --git a/usr.bin/tmux/window.c b/usr.bin/tmux/window.c index ac388eba8be..0aba1e99940 100644 --- a/usr.bin/tmux/window.c +++ b/usr.bin/tmux/window.c @@ -1,4 +1,4 @@ -/* $OpenBSD: window.c,v 1.37 2009/11/04 22:43:11 nicm Exp $ */ +/* $OpenBSD: window.c,v 1.38 2009/11/04 23:54:57 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott @@ -212,7 +212,7 @@ window_create1(u_int sx, u_int sy) struct window *w; u_int i; - w = xmalloc(sizeof *w); + w = xcalloc(1, sizeof *w); w->name = NULL; w->flags = 0; @@ -225,6 +225,8 @@ window_create1(u_int sx, u_int sy) w->sx = sx; w->sy = sy; + queue_window_name(w); + options_init(&w->options, &global_w_options); for (i = 0; i < ARRAY_LENGTH(&windows); i++) { @@ -278,6 +280,8 @@ window_destroy(struct window *w) if (w->layout_root != NULL) layout_free(w); + evtimer_del(&w->name_timer); + options_free(&w->options); window_destroy_panes(w); @@ -480,7 +484,6 @@ window_pane_spawn(struct window_pane *wp, const char *cmd, const char *shell, ARRAY_DECL(, char *) varlist; struct environ_entry *envent; const char *ptr; - struct timeval tv; struct termios tio2; u_int i; @@ -508,12 +511,6 @@ window_pane_spawn(struct window_pane *wp, const char *cmd, const char *shell, ws.ws_col = screen_size_x(&wp->base); ws.ws_row = screen_size_y(&wp->base); - if (gettimeofday(&wp->window->name_timer, NULL) != 0) - fatal("gettimeofday failed"); - tv.tv_sec = 0; - tv.tv_usec = NAME_INTERVAL * 1000L; - timeradd(&wp->window->name_timer, &tv, &wp->window->name_timer); - switch (wp->pid = forkpty(&wp->fd, wp->tty, NULL, &ws)) { case -1: wp->fd = -1; -- cgit v1.2.3