From ac2ba0961babe8307b6474a73ea11b097b42f759 Mon Sep 17 00:00:00 2001 From: nicm Date: Wed, 9 Aug 2017 13:44:36 +0000 Subject: [PATCH] Fix filtering so it works after the change to only show windows if they have multiple panes. --- options.c | 1 - window-tree.c | 49 +++++++++++++++++++++++++++++++++---------------- 2 files changed, 33 insertions(+), 17 deletions(-) diff --git a/options.c b/options.c index c13696f4..a607dab7 100644 --- a/options.c +++ b/options.c @@ -478,7 +478,6 @@ options_match_get(struct options *oo, const char *s, int *idx, int only, return (o); } - const char * options_get_string(struct options *oo, const char *name) { diff --git a/window-tree.c b/window-tree.c index ecb7fb8c..a0aed955 100644 --- a/window-tree.c +++ b/window-tree.c @@ -240,6 +240,23 @@ window_tree_build_pane(struct session *s, struct winlink *wl, free(name); } +static int +window_tree_filter_pane(struct session *s, struct winlink *wl, + struct window_pane *wp, const char *filter) +{ + char *cp; + int result; + + if (filter == NULL) + return (1); + + cp = format_single(NULL, filter, NULL, s, wl, wp); + result = format_true(cp); + free(cp); + + return (result); +} + static int window_tree_build_window(struct session *s, struct winlink *wl, void* modedata, u_int sort_type, struct mode_tree_item *parent, const char *filter) @@ -247,7 +264,7 @@ window_tree_build_window(struct session *s, struct winlink *wl, void* modedata, struct window_tree_modedata *data = modedata; struct window_tree_itemdata *item; struct mode_tree_item *mti; - char *name, *text, *cp; + char *name, *text; struct window_pane *wp, **l; u_int n, i; int expanded; @@ -271,30 +288,24 @@ window_tree_build_window(struct session *s, struct winlink *wl, void* modedata, free(text); free(name); - if (window_count_panes(wl->window) == 1) + wp = TAILQ_FIRST(&wl->window->panes); + if (TAILQ_NEXT(wp, entry) == NULL) { + if (!window_tree_filter_pane(s, wl, wp, filter)) + goto empty; return (1); + } l = NULL; n = 0; TAILQ_FOREACH(wp, &wl->window->panes, entry) { - if (filter != NULL) { - cp = format_single(NULL, filter, NULL, s, wl, wp); - if (!format_true(cp)) { - free(cp); - continue; - } - free(cp); - } + if (!window_tree_filter_pane(s, wl, wp, filter)) + continue; l = xreallocarray(l, n + 1, sizeof *l); l[n++] = wp; } - if (n == 0) { - window_tree_free_item(item); - data->item_size--; - mode_tree_remove(data->data, mti); - return (0); - } + if (n == 0) + goto empty; switch (sort_type) { case WINDOW_TREE_BY_INDEX: @@ -311,6 +322,12 @@ window_tree_build_window(struct session *s, struct winlink *wl, void* modedata, window_tree_build_pane(s, wl, l[i], modedata, mti); free(l); return (1); + +empty: + window_tree_free_item(item); + data->item_size--; + mode_tree_remove(data->data, mti); + return (0); } static void