From 91e119a77e09a11acab401846c557f0b8ac708a8 Mon Sep 17 00:00:00 2001 From: Junegunn Choi Date: Thu, 2 Oct 2025 23:58:32 +0900 Subject: [PATCH] Fix non-matching items not refreshing after clearing query --- src/terminal.go | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/terminal.go b/src/terminal.go index b715c458..b91687cb 100644 --- a/src/terminal.go +++ b/src/terminal.go @@ -180,6 +180,7 @@ type itemLine struct { result Result empty bool other bool + hidden bool } func (t *Terminal) inListWindow() bool { @@ -3282,7 +3283,7 @@ func (t *Terminal) printItem(result Result, line int, maxLine int, index int, cu // Avoid unnecessary redraw numLines, _ := t.numItemLines(item, maxLine-line+1) newLine := itemLine{valid: true, firstLine: line, numLines: numLines, cy: index + t.offset, current: current, selected: selected, label: label, - result: result, queryLen: len(t.input), width: 0, hasBar: line >= barRange[0] && line < barRange[1]} + result: result, queryLen: len(t.input), width: 0, hasBar: line >= barRange[0] && line < barRange[1], hidden: !matched} prevLine := t.prevLines[line] forceRedraw := !prevLine.valid || prevLine.other || prevLine.firstLine != newLine.firstLine printBar := func(lineNum int, forceRedraw bool) bool { @@ -3290,6 +3291,7 @@ func (t *Terminal) printItem(result Result, line int, maxLine int, index int, cu } if !forceRedraw && + prevLine.hidden == newLine.hidden && prevLine.numLines == newLine.numLines && prevLine.current == newLine.current && prevLine.selected == newLine.selected &&