summaryrefslogtreecommitdiff
path: root/lua
diff options
context:
space:
mode:
authorSimon Hauser <Simon-Hauser@outlook.de>2022-07-06 20:38:51 +0200
committerGitHub <noreply@github.com>2022-07-06 20:38:51 +0200
commit30f2a367f2d9dbf1a9aaf4eb447523d8fa56d9d8 (patch)
tree03a0b24f9783884dd9b93fd37078102b02f2a61e /lua
parentb44e657986be5cae5679d5c12337e03a04848562 (diff)
feat(grep_string): invert_match for search="", removing empty lines (#2040)
Diffstat (limited to 'lua')
-rw-r--r--lua/telescope/builtin/__files.lua34
-rw-r--r--lua/telescope/make_entry.lua33
2 files changed, 46 insertions, 21 deletions
diff --git a/lua/telescope/builtin/__files.lua b/lua/telescope/builtin/__files.lua
index 8eb373b..7036f6a 100644
--- a/lua/telescope/builtin/__files.lua
+++ b/lua/telescope/builtin/__files.lua
@@ -126,43 +126,43 @@ end
files.grep_string = function(opts)
-- TODO: This should probably check your visual selection as well, if you've got one
-
- local vimgrep_arguments = opts.vimgrep_arguments or conf.vimgrep_arguments
- local search_dirs = opts.search_dirs
- local word = opts.search or vim.fn.expand "<cword>"
- local search = opts.use_regex and word or escape_chars(word)
- local word_match = opts.word_match
- local grep_open_files = opts.grep_open_files
- opts.entry_maker = opts.entry_maker or make_entry.gen_from_vimgrep(opts)
opts.cwd = opts.cwd and vim.fn.expand(opts.cwd) or vim.loop.cwd()
-
- local title_word = word:gsub("\n", "\\n")
+ local vimgrep_arguments = vim.F.if_nil(opts.vimgrep_arguments, conf.vimgrep_arguments)
+ local word = vim.F.if_nil(opts.search, vim.fn.expand "<cword>")
+ local search = opts.use_regex and word or escape_chars(word)
local additional_args = {}
if opts.additional_args ~= nil and type(opts.additional_args) == "function" then
additional_args = opts.additional_args(opts)
end
+ if search == "" then
+ search = { "-v", "--", "^[[:space:]]*$" }
+ opts.__inverted = true
+ else
+ search = { "--", search }
+ end
+
local args = flatten {
vimgrep_arguments,
additional_args,
- word_match,
- "--",
+ opts.word_match,
search,
}
- if grep_open_files then
- for _, file in ipairs(get_open_filelist(grep_open_files, opts.cwd)) do
+ if opts.grep_open_files then
+ for _, file in ipairs(get_open_filelist(opts.grep_open_files, opts.cwd)) do
table.insert(args, file)
end
- elseif search_dirs then
- for _, path in ipairs(search_dirs) do
+ elseif opts.search_dirs then
+ for _, path in ipairs(opts.search_dirs) do
table.insert(args, vim.fn.expand(path))
end
end
+ opts.entry_maker = opts.entry_maker or make_entry.gen_from_vimgrep(opts)
pickers.new(opts, {
- prompt_title = "Find Word (" .. title_word .. ")",
+ prompt_title = "Find Word (" .. word:gsub("\n", "\\n") .. ")",
finder = finders.new_oneshot_job(args, opts),
previewer = conf.grep_previewer(opts),
sorter = conf.generic_sorter(opts),
diff --git a/lua/telescope/make_entry.lua b/lua/telescope/make_entry.lua
index 43810f2..805218e 100644
--- a/lua/telescope/make_entry.lua
+++ b/lua/telescope/make_entry.lua
@@ -205,7 +205,7 @@ do
}
-- Gets called only once to parse everything out for the vimgrep, after that looks up directly.
- local parse = function(t)
+ local parse_with_col = function(t)
local _, _, filename, lnum, col, text = string.find(t.value, [[(..-):(%d+):(%d+):(.*)]])
local ok
@@ -227,11 +227,32 @@ do
return { filename, lnum, col, text }
end
- function make_entry.gen_from_vimgrep(opts)
- local mt_vimgrep_entry
+ local parse_without_col = function(t)
+ local _, _, filename, lnum, text = string.find(t.value, [[(..-):(%d+):(.*)]])
+
+ local ok
+ ok, lnum = pcall(tonumber, lnum)
+ if not ok then
+ lnum = nil
+ end
+ t.filename = filename
+ t.lnum = lnum
+ t.col = nil
+ t.text = text
+
+ return { filename, lnum, nil, text }
+ end
+
+ function make_entry.gen_from_vimgrep(opts)
opts = opts or {}
+ local mt_vimgrep_entry
+ local parse = parse_with_col
+ if opts.__inverted == true then
+ parse = parse_without_col
+ end
+
local disable_devicons = opts.disable_devicons
local disable_coordinates = opts.disable_coordinates
local only_sort_text = opts.only_sort_text
@@ -279,7 +300,11 @@ do
local coordinates = ""
if not disable_coordinates then
- coordinates = string.format("%s:%s:", entry.lnum, entry.col)
+ if entry.col then
+ coordinates = string.format("%s:%s:", entry.lnum, entry.col)
+ else
+ coordinates = string.format("%s:", entry.lnum)
+ end
end
local display, hl_group = utils.transform_devicons(