fix finder highlight in grep

This commit is contained in:
2026-02-03 11:12:59 +02:00
parent b84e46bda1
commit 2c8524df9d
4 changed files with 72 additions and 43 deletions

View File

@@ -7,10 +7,23 @@ vim.env.PATH = vim.fn.stdpath('data') .. '/mason/bin:' .. vim.env.PATH
vim.filetype.add({ vim.filetype.add({
pattern = { pattern = {
['.*/templates/.*%.ya?ml'] = 'yaml.helm-values', ['.*/templates/.*%.ya?ml'] = 'helm',
['.*/manifests/.*%.ya?ml'] = 'helm',
['.*/crds/.*%.ya?ml'] = 'helm',
['.*/kubernetes/.*%.ya?ml'] = 'helm',
['.*/k8s/.*%.ya?ml'] = 'helm',
['.*/charts/.*%.ya?ml'] = 'helm',
}, },
}) })
function _G.see(val)
local lines = vim.split(vim.inspect(val), '\n')
vim.cmd('new')
vim.api.nvim_buf_set_lines(0, 0, -1, false, lines)
vim.bo.buftype = 'nofile'
vim.bo.bufhidden = 'wipe'
end
require('core.options') require('core.options')
require('core.keymaps') require('core.keymaps')
require('core.events') require('core.events')

View File

@@ -62,13 +62,16 @@
---@type vim.lsp.Config ---@type vim.lsp.Config
return { return {
cmd = { 'yaml-language-server', '--stdio' }, cmd = { 'yaml-language-server', '--stdio' },
filetypes = { 'helm', 'yaml', 'yaml.docker-compose', 'yaml.gitlab', 'yaml.helm-values' }, filetypes = { 'yaml', 'yaml.docker-compose', 'yaml.gitlab', 'yaml.helm-values' },
root_markers = { '.git' }, root_markers = { '.git' },
settings = { settings = {
-- https://github.com/redhat-developer/vscode-redhat-telemetry#how-to-disable-telemetry-reporting -- https://github.com/redhat-developer/vscode-redhat-telemetry#how-to-disable-telemetry-reporting
redhat = { telemetry = { enabled = false } }, redhat = { telemetry = { enabled = false } },
-- formatting disabled by default in yaml-language-server; enable it -- formatting disabled by default in yaml-language-server; enable it
yaml = { format = { enable = true } }, yaml = {
format = { enable = true },
validate = false, -- Disable all schema validation
},
}, },
on_init = function(client) on_init = function(client)
--- https://github.com/neovim/nvim-lspconfig/pull/4016 --- https://github.com/neovim/nvim-lspconfig/pull/4016

View File

@@ -16,11 +16,11 @@ local M = {}
-- --
function M.get() function M.get()
return { return {
{ -- {
ft = 'yaml.helm-values', -- ft = 'helm',
ts = 'helm', -- ts = 'helm',
lsp = 'helm-ls', -- lsp = 'helm-ls',
}, -- },
{ {
ft = 'yaml', ft = 'yaml',
ts = 'yaml', ts = 'yaml',

View File

@@ -152,13 +152,17 @@ local function save_cache(root, files)
end end
local function project_root() local function project_root()
local obj = vim.system({ 'git', 'rev-parse', '--show-toplevel' }, { text = true }):wait()
if obj.code == 0 and obj.stdout and obj.stdout ~= '' then
return vim.trim(obj.stdout)
end
return vim.fn.getcwd(0, 0) return vim.fn.getcwd(0, 0)
end end
-- local function project_root()
-- local obj = vim.system({ 'git', 'rev-parse', '--show-toplevel' }, { text = true }):wait()
-- if obj.code == 0 and obj.stdout and obj.stdout ~= '' then
-- return vim.trim(obj.stdout)
-- end
-- return vim.fn.getcwd(0, 0)
-- end
local function normalize_rel(root, p) local function normalize_rel(root, p)
if not p or p == '' then if not p or p == '' then
return '' return ''
@@ -244,53 +248,49 @@ local function render()
-- For grep mode, reformat lines with fixed-width path column -- For grep mode, reformat lines with fixed-width path column
local offset_map = {} -- maps display line -> character offset for highlighting local offset_map = {} -- maps display line -> character offset for highlighting
-- In render(), replace the grep reformatting section:
-- In render(), replace the grep reformatting section:
if S.mode == 'grep' and total > 0 then if S.mode == 'grep' and total > 0 then
local path_width = M.config.grep_path_width or 40 local path_width = M.config.grep_path_width or 40
for i = 1, #view do for i = 1, #view do
local line = view[i] local line = view[i]
if line then if line then
-- Parse original vimgrep format: file:line:col:content local file, lnum, col, content_start_pos = line:match('^(.-):(%d+):(%d+):()')
local file, lnum, col = line:match('^(.-):(%d+):(%d+):') if file and lnum and col and content_start_pos then
if file and lnum and col then
-- Pad line number to 3 chars with underscores
local padded_lnum = lnum local padded_lnum = lnum
while #padded_lnum < 3 do while #padded_lnum < 3 do
padded_lnum = ' ' .. padded_lnum padded_lnum = ' ' .. padded_lnum
end end
local lineinfo = ':' .. padded_lnum .. '|' local lineinfo = ':' .. padded_lnum .. '|'
local content_start = #file + 1 + #lnum + 1 + #col + 2 -- file + :lnum: + col: local content_part = line:sub(content_start_pos)
local content_part = line:sub(content_start)
-- Calculate how much space we need for file + lineinfo
local prefix_len = #file + #lineinfo local prefix_len = #file + #lineinfo
local formatted_line local formatted_line
local new_content_start -- 1-based position where content starts in formatted line
if prefix_len > path_width then if prefix_len > path_width then
-- Need to truncate the filepath part only
local available_for_file = path_width - #lineinfo local available_for_file = path_width - #lineinfo
if available_for_file > 1 then if available_for_file > 1 then
local truncated_file = '' .. file:sub(-(available_for_file - 1)) local truncated_file = '' .. file:sub(-(available_for_file - 1))
formatted_line = truncated_file .. lineinfo .. content_part formatted_line = truncated_file .. lineinfo .. content_part
-- Offset is: original_file_length - truncated_file_length new_content_start = #truncated_file + #lineinfo + 1
offset_map[i] = #file - #truncated_file
else else
-- Extreme case: line info itself is too long, just show what we can
formatted_line = ('' .. file):sub(1, path_width) .. lineinfo .. content_part formatted_line = ('' .. file):sub(1, path_width) .. lineinfo .. content_part
offset_map[i] = #file - (path_width - #lineinfo) new_content_start = path_width + #lineinfo + 1
end end
elseif prefix_len < path_width then elseif prefix_len < path_width then
-- Right-align by padding before the filepath
local padding = string.rep(' ', path_width - prefix_len) local padding = string.rep(' ', path_width - prefix_len)
formatted_line = padding .. file .. lineinfo .. content_part formatted_line = padding .. file .. lineinfo .. content_part
offset_map[i] = -(path_width - prefix_len) -- negative for padding added new_content_start = #padding + #file + #lineinfo + 1
else else
formatted_line = file .. lineinfo .. content_part formatted_line = file .. lineinfo .. content_part
offset_map[i] = 0 new_content_start = #file + #lineinfo + 1
end end
view[i] = formatted_line view[i] = formatted_line
offset_map[i] = content_start_pos - new_content_start
end end
end end
end end
@@ -397,12 +397,16 @@ local function compute_positions_grep(lines, q)
if q == '' then if q == '' then
return lines, {} return lines, {}
end end
-- Match rg's --smart-case: case-insensitive unless query has uppercase
local case_insensitive = not q:match('[A-Z]') local case_insensitive = not q:match('[A-Z]')
local qmatch = case_insensitive and q:lower() or q local qmatch = case_insensitive and q:lower() or q
local positions = {} local positions = {}
for i, line in ipairs(lines) do for i, line in ipairs(lines) do
local lmatch = case_insensitive and tostring(line or ''):lower() or tostring(line or '') local file, lnum, col, content_start_pos = line:match('^(.-):(%d+):(%d+):()')
if not content_start_pos then
positions[i] = nil
else
local content = line:sub(content_start_pos)
local lmatch = case_insensitive and content:lower() or content
local spans = {} local spans = {}
local sidx = 1 local sidx = 1
while true do while true do
@@ -410,7 +414,8 @@ local function compute_positions_grep(lines, q)
if not s then if not s then
break break
end end
table.insert(spans, { s - 1, e }) -- Use content_start_pos from the pattern match, not manual calculation
table.insert(spans, { content_start_pos - 1 + s - 1, content_start_pos - 1 + e })
sidx = e + 1 sidx = e + 1
if #spans > 64 then if #spans > 64 then
break break
@@ -418,6 +423,7 @@ local function compute_positions_grep(lines, q)
end end
positions[i] = (#spans > 0) and spans or nil positions[i] = (#spans > 0) and spans or nil
end end
end
return lines, positions return lines, positions
end end
@@ -715,7 +721,6 @@ local function grep_async(query, cb)
'/', '/',
} }
-- Add excludes before the pattern
for _, p in ipairs(M.config.exclude_patterns or {}) do for _, p in ipairs(M.config.exclude_patterns or {}) do
table.insert(args, '--glob') table.insert(args, '--glob')
table.insert(args, '!' .. p) table.insert(args, '!' .. p)
@@ -730,11 +735,19 @@ local function grep_async(query, cb)
return return
end end
local list = {} local list = {}
local seen = {} -- track file:line to deduplicate
if obj.stdout and #obj.stdout > 0 then if obj.stdout and #obj.stdout > 0 then
for line in obj.stdout:gmatch('[^\n]+') do for line in obj.stdout:gmatch('[^\n]+') do
local file, lnum = line:match('^(.-):(%d+):%d+:')
if file and lnum then
local key = file .. ':' .. lnum
if not seen[key] then
seen[key] = true
list[#list + 1] = line list[#list + 1] = line
end end
end end
end
end
if #list > M.config.max_items then if #list > M.config.max_items then
local tmp = {} local tmp = {}
for i = 1, M.config.max_items do for i = 1, M.config.max_items do