diff options
author | Nicholas Marriott <nicm@cvs.openbsd.org> | 2019-03-08 10:34:21 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@cvs.openbsd.org> | 2019-03-08 10:34:21 +0000 |
commit | f70bfd248e2b991bcfb01c7cc241ec2579d1735a (patch) | |
tree | 60784a988d2167dca3999d18a11233837191d8ea /usr.bin/tmux | |
parent | 08fcb5243af030539f5557e00a9886a2fc0c2236 (diff) |
Make the mode used to view command output (a variant of copy mode) use
its own mode definition struct with a different init function rather
than calling special setup functions.
Diffstat (limited to 'usr.bin/tmux')
-rw-r--r-- | usr.bin/tmux/cfg.c | 7 | ||||
-rw-r--r-- | usr.bin/tmux/cmd-copy-mode.c | 5 | ||||
-rw-r--r-- | usr.bin/tmux/cmd-queue.c | 19 | ||||
-rw-r--r-- | usr.bin/tmux/cmd-run-shell.c | 7 | ||||
-rw-r--r-- | usr.bin/tmux/tmux.h | 5 | ||||
-rw-r--r-- | usr.bin/tmux/window-copy.c | 86 |
6 files changed, 72 insertions, 57 deletions
diff --git a/usr.bin/tmux/cfg.c b/usr.bin/tmux/cfg.c index 4e7811092ac..2535a464066 100644 --- a/usr.bin/tmux/cfg.c +++ b/usr.bin/tmux/cfg.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cfg.c,v 1.64 2019/03/07 19:34:22 nicm Exp $ */ +/* $OpenBSD: cfg.c,v 1.65 2019/03/08 10:34:20 nicm Exp $ */ /* * Copyright (c) 2008 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -348,7 +348,10 @@ cfg_show_causes(struct session *s) return; wp = s->curw->window->active; - window_copy_init_for_output(wp); + if (wp->mode == NULL || wp->mode->mode != &window_view_mode) { + window_pane_reset_mode(wp); + window_pane_set_mode(wp, &window_view_mode, NULL, NULL); + } for (i = 0; i < cfg_ncauses; i++) { window_copy_add(wp, "%s", cfg_causes[i]); free(cfg_causes[i]); diff --git a/usr.bin/tmux/cmd-copy-mode.c b/usr.bin/tmux/cmd-copy-mode.c index f0e41213ba7..77e03fc43f2 100644 --- a/usr.bin/tmux/cmd-copy-mode.c +++ b/usr.bin/tmux/cmd-copy-mode.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd-copy-mode.c,v 1.35 2019/03/07 20:24:21 nicm Exp $ */ +/* $OpenBSD: cmd-copy-mode.c,v 1.36 2019/03/08 10:34:20 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -75,10 +75,9 @@ cmd_copy_mode_exec(struct cmd *self, struct cmdq_item *item) } if (wp->mode == NULL || wp->mode->mode != &window_copy_mode) { - flag = window_pane_set_mode(wp, &window_copy_mode, NULL, NULL); + flag = window_pane_set_mode(wp, &window_copy_mode, NULL, args); if (flag != 0) return (CMD_RETURN_NORMAL); - window_copy_init_from_pane(wp, args_has(self->args, 'e')); } if (args_has(args, 'M')) { if (wp->mode != NULL && wp->mode->mode != &window_copy_mode) diff --git a/usr.bin/tmux/cmd-queue.c b/usr.bin/tmux/cmd-queue.c index 1d49333c60d..633f0f1433b 100644 --- a/usr.bin/tmux/cmd-queue.c +++ b/usr.bin/tmux/cmd-queue.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd-queue.c,v 1.59 2019/03/07 19:34:22 nicm Exp $ */ +/* $OpenBSD: cmd-queue.c,v 1.60 2019/03/08 10:34:20 nicm Exp $ */ /* * Copyright (c) 2013 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -404,10 +404,10 @@ cmdq_guard(struct cmdq_item *item, const char *guard, int flags) void cmdq_print(struct cmdq_item *item, const char *fmt, ...) { - struct client *c = item->client; - struct window *w; - va_list ap; - char *tmp, *msg; + struct client *c = item->client; + struct window_pane *wp; + va_list ap; + char *tmp, *msg; va_start(ap, fmt); @@ -425,9 +425,12 @@ cmdq_print(struct cmdq_item *item, const char *fmt, ...) evbuffer_add(c->stdout_data, "\n", 1); server_client_push_stdout(c); } else { - w = c->session->curw->window; - window_copy_init_for_output(w->active); - window_copy_vadd(w->active, fmt, ap); + wp = c->session->curw->window->active; + if (wp->mode == NULL || wp->mode->mode != &window_view_mode) { + window_pane_reset_mode(wp); + window_pane_set_mode(wp, &window_view_mode, NULL, NULL); + } + window_copy_vadd(wp, fmt, ap); } va_end(ap); diff --git a/usr.bin/tmux/cmd-run-shell.c b/usr.bin/tmux/cmd-run-shell.c index 29ffcb440b8..a639197f886 100644 --- a/usr.bin/tmux/cmd-run-shell.c +++ b/usr.bin/tmux/cmd-run-shell.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd-run-shell.c,v 1.56 2019/03/07 19:34:22 nicm Exp $ */ +/* $OpenBSD: cmd-run-shell.c,v 1.57 2019/03/08 10:34:20 nicm Exp $ */ /* * Copyright (c) 2009 Tiago Cunha <me@tiagocunha.org> @@ -75,7 +75,10 @@ cmd_run_shell_print(struct job *job, const char *msg) return; } - window_copy_init_for_output(wp); + if (wp->mode == NULL || wp->mode->mode != &window_view_mode) { + window_pane_reset_mode(wp); + window_pane_set_mode(wp, &window_view_mode, NULL, NULL); + } window_copy_add(wp, "%s", msg); } diff --git a/usr.bin/tmux/tmux.h b/usr.bin/tmux/tmux.h index dfd2e6ba75f..c0e6787095f 100644 --- a/usr.bin/tmux/tmux.h +++ b/usr.bin/tmux/tmux.h @@ -1,4 +1,4 @@ -/* $OpenBSD: tmux.h,v 1.855 2019/03/07 20:24:21 nicm Exp $ */ +/* $OpenBSD: tmux.h,v 1.856 2019/03/08 10:34:20 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -2310,8 +2310,7 @@ extern const struct window_mode window_client_mode; /* window-copy.c */ extern const struct window_mode window_copy_mode; -void window_copy_init_from_pane(struct window_pane *, int); -void window_copy_init_for_output(struct window_pane *); +extern const struct window_mode window_view_mode; void printflike(2, 3) window_copy_add(struct window_pane *, const char *, ...); void window_copy_vadd(struct window_pane *, const char *, va_list); void window_copy_pageup(struct window_pane *, int); diff --git a/usr.bin/tmux/window-copy.c b/usr.bin/tmux/window-copy.c index 4776638897d..c9368e92b60 100644 --- a/usr.bin/tmux/window-copy.c +++ b/usr.bin/tmux/window-copy.c @@ -1,4 +1,4 @@ -/* $OpenBSD: window-copy.c,v 1.209 2019/03/08 10:29:25 nicm Exp $ */ +/* $OpenBSD: window-copy.c,v 1.210 2019/03/08 10:34:20 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -30,6 +30,8 @@ static void window_copy_command(struct window_mode_entry *, struct client *, struct mouse_event *); static struct screen *window_copy_init(struct window_mode_entry *, struct cmd_find_state *, struct args *); +static struct screen *window_copy_view_init(struct window_mode_entry *, + struct cmd_find_state *, struct args *); static void window_copy_free(struct window_mode_entry *); static void window_copy_resize(struct window_mode_entry *, u_int, u_int); static void window_copy_formats(struct window_mode_entry *, @@ -125,6 +127,17 @@ const struct window_mode window_copy_mode = { .formats = window_copy_formats, }; +const struct window_mode window_view_mode = { + .name = "view-mode", + + .init = window_copy_view_init, + .free = window_copy_free, + .resize = window_copy_resize, + .key_table = window_copy_key_table, + .command = window_copy_command, + .formats = window_copy_formats, +}; + enum { WINDOW_COPY_OFF, WINDOW_COPY_SEARCHUP, @@ -203,13 +216,12 @@ struct window_copy_mode_data { char jumpchar; }; -static struct screen * -window_copy_init(struct window_mode_entry *wme, - __unused struct cmd_find_state *fs, __unused struct args *args) +static struct window_copy_mode_data * +window_copy_common_init(struct window_mode_entry *wme) { struct window_pane *wp = wme->wp; struct window_copy_mode_data *data; - struct screen *s; + struct screen *base = &wp->base; wme->data = data = xcalloc(1, sizeof *data); @@ -226,66 +238,62 @@ window_copy_init(struct window_mode_entry *wme, data->searchmark = NULL; data->searchx = data->searchy = data->searcho = -1; - if (wp->fd != -1) - bufferevent_disable(wp->event, EV_READ|EV_WRITE); - data->jumptype = WINDOW_COPY_OFF; data->jumpchar = '\0'; - s = &data->screen; - screen_init(s, screen_size_x(&wp->base), screen_size_y(&wp->base), 0); + screen_init(&data->screen, screen_size_x(base), screen_size_y(base), 0); data->modekeys = options_get_number(wp->window->options, "mode-keys"); - data->backing = NULL; - - return (s); + return (data); } -void -window_copy_init_from_pane(struct window_pane *wp, int scroll_exit) +static struct screen * +window_copy_init(struct window_mode_entry *wme, + __unused struct cmd_find_state *fs, struct args *args) { - struct window_mode_entry *wme = wp->mode; - struct window_copy_mode_data *data = wme->data; - struct screen *s = &data->screen; - struct screen_write_ctx ctx; + struct window_pane *wp = wme->wp; + struct window_copy_mode_data *data; + struct screen_write_ctx ctx; u_int i; - if (wme == NULL || wme->mode != &window_copy_mode) - fatalx("not in copy mode"); + data = window_copy_common_init(wme); + + if (wp->fd != -1) + bufferevent_disable(wp->event, EV_READ|EV_WRITE); data->backing = &wp->base; data->cx = data->backing->cx; data->cy = data->backing->cy; - data->scroll_exit = scroll_exit; - s->cx = data->cx; - s->cy = data->cy; + data->scroll_exit = args_has(args, 'e'); - screen_write_start(&ctx, NULL, s); - for (i = 0; i < screen_size_y(s); i++) + data->screen.cx = data->cx; + data->screen.cy = data->cy; + + screen_write_start(&ctx, NULL, &data->screen); + for (i = 0; i < screen_size_y(&data->screen); i++) window_copy_write_line(wme, &ctx, i); screen_write_cursormove(&ctx, data->cx, data->cy); screen_write_stop(&ctx); + + return (&data->screen); } -void -window_copy_init_for_output(struct window_pane *wp) +static struct screen * +window_copy_view_init(struct window_mode_entry *wme, + __unused struct cmd_find_state *fs, __unused struct args *args) { + struct window_pane *wp = wme->wp; struct window_copy_mode_data *data; + struct screen *base = &wp->base; + struct screen *s; - if (wp->mode != NULL && wp->mode->mode == &window_copy_mode) { - data = wp->mode->data; - if (data->backing != &wp->base) - return; - } - window_pane_reset_mode(wp); + data = window_copy_common_init(wme); - window_pane_set_mode(wp, &window_copy_mode, NULL, NULL); - data = wp->mode->data; + data->backing = s = xmalloc(sizeof *data->backing); + screen_init(s, screen_size_x(base), screen_size_y(base), UINT_MAX); - data->backing = xmalloc(sizeof *data->backing); - screen_init(data->backing, screen_size_x(&wp->base), - screen_size_y(&wp->base), UINT_MAX); + return (&data->screen); } static void |