diff options
| author | Simon Hauser <Simon-Hauser@outlook.de> | 2020-12-31 16:17:09 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-12-31 16:17:09 +0100 |
| commit | a0b37473a924083386118c8467717843cfb6b0cb (patch) | |
| tree | 68fdbd952bc15a0c1f70c9073d7d620d5ee76c32 /lua/telescope/previewers/buffer_previewer.lua | |
| parent | 686d560fa50e130801d5bd64493d79f1c65e3f7c (diff) | |
fix: tags now work with hasktags (#375)
Diffstat (limited to 'lua/telescope/previewers/buffer_previewer.lua')
| -rw-r--r-- | lua/telescope/previewers/buffer_previewer.lua | 42 |
1 files changed, 30 insertions, 12 deletions
diff --git a/lua/telescope/previewers/buffer_previewer.lua b/lua/telescope/previewers/buffer_previewer.lua index 64cb5d5..354bca0 100644 --- a/lua/telescope/previewers/buffer_previewer.lua +++ b/lua/telescope/previewers/buffer_previewer.lua @@ -222,11 +222,40 @@ end, {}) previewers.qflist = previewers.vimgrep previewers.ctags = defaulter(function(_) + local determine_jump = function(entry) + if entry.scode then + return function(self) + local scode = string.gsub(entry.scode, '[$]$', '') + scode = string.gsub(scode, [[\\]], [[\]]) + scode = string.gsub(scode, [[\/]], [[/]]) + scode = string.gsub(scode, '[*]', [[\*]]) + + pcall(vim.fn.matchdelete, self.state.hl_id, self.state.winid) + vim.cmd "norm! gg" + vim.fn.search(scode, "W") + vim.cmd "norm! zz" + + self.state.hl_id = vim.fn.matchadd('TelescopePreviewMatch', scode) + end + else + return function(self, bufnr) + if self.state.last_set_bufnr then + pcall(vim.api.nvim_buf_clear_namespace, self.state.last_set_bufnr, ns_previewer, 0, -1) + end + pcall(vim.api.nvim_buf_add_highlight, bufnr, ns_previewer, "TelescopePreviewMatch", entry.lnum - 1, 0, -1) + pcall(vim.api.nvim_win_set_cursor, self.state.winid, { entry.lnum, 0 }) + self.state.last_set_bufnr = bufnr + end + end + end + return previewers.new_buffer_previewer { teardown = function(self) if self.state and self.state.hl_id then pcall(vim.fn.matchdelete, self.state.hl_id, self.state.hl_win) self.state.hl_id = nil + elseif self.state and self.state.last_set_bufnr and vim.api.nvim_buf_is_valid(self.state.last_set_bufnr) then + vim.api.nvim_buf_clear_namespace(self.state.last_set_bufnr, ns_previewer, 0, -1) end end, @@ -236,22 +265,11 @@ previewers.ctags = defaulter(function(_) define_preview = function(self, entry, status) putils.with_preview_window(status, nil, function() - local scode = string.gsub(entry.scode, '[$]$', '') - scode = string.gsub(scode, [[\\]], [[\]]) - scode = string.gsub(scode, [[\/]], [[/]]) - scode = string.gsub(scode, '[*]', [[\*]]) - conf.buffer_previewer_maker(entry.filename, self.state.bufnr, self.state.bufname, true, function(bufnr) vim.api.nvim_buf_call(bufnr, function() - pcall(vim.fn.matchdelete, self.state.hl_id, self.state.winid) - vim.cmd "norm! gg" - vim.fn.search(scode, "W") - vim.cmd "norm! zz" - - self.state.hl_id = vim.fn.matchadd('TelescopePreviewMatch', scode) + determine_jump(entry)(self, bufnr) end) end) - end) end } |
