From b6b7486423fe5f1f3b1971308393088b03dc4dc8 Mon Sep 17 00:00:00 2001 From: nicm Date: Mon, 9 Sep 2019 11:47:25 +0000 Subject: [PATCH 1/3] Clarify server options slightly. --- tmux.1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tmux.1 b/tmux.1 index bd96564f..c4c5698e 100644 --- a/tmux.1 +++ b/tmux.1 @@ -2743,7 +2743,7 @@ and .Pp The .Nm -server has a set of global options which do not apply to any particular +server has a set of global server options which do not apply to any particular window or session or pane. These are altered with the .Ic set-option From 4b7e97ba533161e6130b957b91c9bb6aa3da7afa Mon Sep 17 00:00:00 2001 From: nicm Date: Tue, 10 Sep 2019 07:50:33 +0000 Subject: [PATCH 2/3] Set up format tree for %if, GitHub issue 1896. --- cmd-parse.y | 16 ++++++++-------- cmd-queue.c | 1 - format.c | 1 - key-bindings.c | 1 - window-copy.c | 1 - 5 files changed, 8 insertions(+), 12 deletions(-) diff --git a/cmd-parse.y b/cmd-parse.y index 6d2b970c..b0a42f7c 100644 --- a/cmd-parse.y +++ b/cmd-parse.y @@ -176,18 +176,18 @@ expanded : format struct cmd_parse_input *pi = ps->input; struct format_tree *ft; struct client *c = pi->c; - struct cmd_find_state *fs; + struct cmd_find_state *fsp; + struct cmd_find_state fs; int flags = FORMAT_NOJOBS; if (cmd_find_valid_state(&pi->fs)) - fs = &pi->fs; - else - fs = NULL; + fsp = &pi->fs; + else { + cmd_find_from_client(&fs, c, 0); + fsp = &fs; + } ft = format_create(NULL, pi->item, FORMAT_NONE, flags); - if (fs != NULL) - format_defaults(ft, c, fs->s, fs->wl, fs->wp); - else - format_defaults(ft, c, NULL, NULL, NULL); + format_defaults(ft, c, fsp->s, fsp->wl, fsp->wp); $$ = format_expand(ft, $1); format_free(ft); diff --git a/cmd-queue.c b/cmd-queue.c index ef68d5d5..fa6999e8 100644 --- a/cmd-queue.c +++ b/cmd-queue.c @@ -102,7 +102,6 @@ cmdq_insert_after(struct cmdq_item *after, struct cmdq_item *item) } while (item != NULL); } - /* Insert a hook. */ void cmdq_insert_hook(struct session *s, struct cmdq_item *item, diff --git a/format.c b/format.c index df569bc2..6dfec4b7 100644 --- a/format.c +++ b/format.c @@ -946,7 +946,6 @@ format_each(struct format_tree *ft, void (*cb)(const char *, const char *, } } - /* Add a key-value pair. */ void format_add(struct format_tree *ft, const char *key, const char *fmt, ...) diff --git a/key-bindings.c b/key-bindings.c index 0c9ba67b..df2dcf46 100644 --- a/key-bindings.c +++ b/key-bindings.c @@ -69,7 +69,6 @@ " '#{?pane_marked,Unmark,Mark}' 'm' {select-pane -m}" \ " '#{?window_zoomed_flag,Unzoom,Zoom}' 'z' {resize-pane -Z}" - static int key_bindings_cmp(struct key_binding *, struct key_binding *); RB_GENERATE_STATIC(key_bindings, key_binding, entry, key_bindings_cmp); static int key_table_cmp(struct key_table *, struct key_table *); diff --git a/window-copy.c b/window-copy.c index b90130c7..76736ab2 100644 --- a/window-copy.c +++ b/window-copy.c @@ -1108,7 +1108,6 @@ window_copy_cmd_previous_matching_bracket(struct window_copy_cmd_state *cs) return (WINDOW_COPY_CMD_NOTHING); } - static enum window_copy_cmd_action window_copy_cmd_next_matching_bracket(struct window_copy_cmd_state *cs) { From 0feae4d8ae4190b89f486fddab10a691cc7a8fd3 Mon Sep 17 00:00:00 2001 From: nicm Date: Tue, 10 Sep 2019 19:35:34 +0000 Subject: [PATCH 3/3] Make client exit if pane where input is going is closed. --- window.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/window.c b/window.c index 0b691197..e3b20a3e 100644 --- a/window.c +++ b/window.c @@ -1572,6 +1572,10 @@ window_pane_input_callback(struct client *c, int closed, void *data) wp = window_pane_find_by_id(cdata->wp); if (wp == NULL || closed || c->flags & CLIENT_DEAD) { + if (wp == NULL) + c->flags |= CLIENT_EXIT; + evbuffer_drain(evb, len); + c->stdin_callback = NULL; server_client_unref(c);