From df534c3042572fb958586facd02841e10186707c Mon Sep 17 00:00:00 2001 From: James Trew <66286082+jamestrew@users.noreply.github.com> Date: Thu, 10 Oct 2024 00:08:12 +0000 Subject: [PATCH] fix(git_status): correctly count result on_complete (#3321) The previous implementation with `self.manager:num_results()` could return 0 despite having results due to suspected async/event loop issues (#3316). This change counts valid entries manually to ensure accurate result count. --- lua/telescope/builtin/__git.lua | 13 +++++++++++-- lua/telescope/make_entry.lua | 2 +- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/lua/telescope/builtin/__git.lua b/lua/telescope/builtin/__git.lua index 1b6e9ed2dd..b24267067d 100644 --- a/lua/telescope/builtin/__git.lua +++ b/lua/telescope/builtin/__git.lua @@ -393,9 +393,18 @@ git.status = function(opts) sorter = conf.file_sorter(opts), on_complete = { function(self) - local lines = self.manager:num_results() local prompt = action_state.get_current_line() - if lines == 0 and prompt == "" then + + -- HACK: self.manager:num_results() can return 0 despite having results + -- due to some async/event loop shenanigans (#3316) + local count = 0 + for _, entry in pairs(self.finder.results) do + if entry and entry.valid ~= false then + count = count + 1 + end + end + + if count == 0 and prompt == "" then utils.notify("builtin.git_status", { msg = "No changes found", level = "ERROR", diff --git a/lua/telescope/make_entry.lua b/lua/telescope/make_entry.lua index 3920e2623d..e629eeaecc 100644 --- a/lua/telescope/make_entry.lua +++ b/lua/telescope/make_entry.lua @@ -1387,7 +1387,7 @@ function make_entry.gen_from_git_status(opts) return nil end - return setmetatable({ + return make_entry.set_default_entry_mt({ value = file, status = mod, ordinal = entry,