From d51d93337e06c289ca1a0f31249b15e982170843 Mon Sep 17 00:00:00 2001 From: bhagwan Date: Wed, 18 Dec 2024 10:00:47 -0800 Subject: [PATCH] fix: `-1|--select-1` in $FZF_DEFAULT_OPTS (closes #1589) --- lua/fzf-lua/fzf.lua | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/lua/fzf-lua/fzf.lua b/lua/fzf-lua/fzf.lua index cbd76376..47cbfd13 100644 --- a/lua/fzf-lua/fzf.lua +++ b/lua/fzf-lua/fzf.lua @@ -248,6 +248,7 @@ function M.raw_fzf(contents, fzf_cli_args, opts) -- from FZF_DEFAULT_OPTS (#1107) local default_opts = os.getenv("FZF_DEFAULT_OPTS") if not default_opts then return end + local flags = { "--select-1", "-1" } local patterns = { "--preview-window" } for _, p in ipairs(patterns) do -- remove flag end of string @@ -255,6 +256,18 @@ function M.raw_fzf(contents, fzf_cli_args, opts) -- remove flag start/mid of string default_opts = default_opts:gsub(utils.lua_regex_escape(p) .. "[=%s]+.-%s+%-%-", " --") end + for _, p in ipairs(flags) do + local escaped = utils.lua_regex_escape(p) + repeat + local before, has_opt, after = default_opts:match("(.?)(" .. escaped .. ")(.?)") + if has_opt and #has_opt > 0 + and before and (#before == 0 or string.sub(before, 1, 1) == " ") + and after and (#after == 0 or string.sub(after, 1, 1) == " ") + then + default_opts = default_opts:gsub(string.format("%s%s%s", before, escaped, after), "") + end + until not has_opt + end return default_opts end)(), -- Nullify user's RG config as this can cause conflicts