summaryrefslogtreecommitdiff
path: root/lua/telescope/pickers/highlights.lua
diff options
context:
space:
mode:
authorTJ DeVries <devries.timothyj@gmail.com>2020-12-21 16:03:48 -0500
committerGitHub <noreply@github.com>2020-12-21 16:03:48 -0500
commit2aa8bcb87898ed4f45d67c640fe1d6a60b184637 (patch)
tree2207ccb7546112fdc03700525e79c55ffaed7679 /lua/telescope/pickers/highlights.lua
parent1e7ef41c704f027a989325c0171a852e8207ec24 (diff)
feat: Add better highlighting and new CI abilities (#355)
* Revert "Revert "fix: Better highlights (#344)" (#350)" This reverts commit 7950fc8ba0accfcf6c540c7810feee646281fd8a. * better highlights take 2 * fixup * install fd find for sameness * add some debug output * more deterministic * better ci
Diffstat (limited to 'lua/telescope/pickers/highlights.lua')
-rw-r--r--lua/telescope/pickers/highlights.lua82
1 files changed, 82 insertions, 0 deletions
diff --git a/lua/telescope/pickers/highlights.lua b/lua/telescope/pickers/highlights.lua
new file mode 100644
index 0000000..23e796e
--- /dev/null
+++ b/lua/telescope/pickers/highlights.lua
@@ -0,0 +1,82 @@
+local a = vim.api
+
+local highlights = {}
+
+local ns_telescope_selection = a.nvim_create_namespace('telescope_selection')
+local ns_telescope_entry = a.nvim_create_namespace('telescope_entry')
+
+local Highlighter = {}
+Highlighter.__index = Highlighter
+
+function Highlighter:new(picker)
+ return setmetatable({
+ picker = picker,
+ }, self)
+end
+
+function Highlighter:hi_display(row, prefix, display_highlights)
+ -- This is the bug that made my highlight fixes not work.
+ -- We will leave the solutino commented, so the test fails.
+ if not display_highlights or vim.tbl_isempty(display_highlights) then
+ return
+ end
+
+ local results_bufnr = assert(self.picker.results_bufnr, "Must have a results bufnr")
+
+ a.nvim_buf_clear_namespace(results_bufnr, ns_telescope_entry, row, row + 1)
+ local len_prefix = #prefix
+
+ for _, hl_block in ipairs(display_highlights) do
+ a.nvim_buf_add_highlight(
+ results_bufnr,
+ ns_telescope_entry,
+ hl_block[2],
+ row,
+ len_prefix + hl_block[1][1],
+ len_prefix + hl_block[1][2]
+ )
+ end
+end
+
+function Highlighter:clear_display()
+ a.nvim_buf_clear_namespace(self.picker.results_bufnr, ns_telescope_entry, 0, -1)
+end
+
+function Highlighter:hi_sorter(row, prompt, display)
+ local picker = self.picker
+ if not picker.sorter or not picker.sorter.highlighter then
+ return
+ end
+
+ local results_bufnr = assert(self.picker.results_bufnr, "Must have a results bufnr")
+ picker:highlight_one_row(results_bufnr, prompt, display, row)
+end
+
+function Highlighter:hi_selection(row, caret)
+ local results_bufnr = assert(self.picker.results_bufnr, "Must have a results bufnr")
+
+ a.nvim_buf_clear_namespace(results_bufnr, ns_telescope_selection, 0, -1)
+ a.nvim_buf_add_highlight(
+ results_bufnr,
+ ns_telescope_selection,
+ 'TelescopeSelectionCaret',
+ row,
+ 0,
+ #caret
+ )
+
+ a.nvim_buf_add_highlight(
+ results_bufnr,
+ ns_telescope_selection,
+ 'TelescopeSelection',
+ row,
+ #caret,
+ -1
+ )
+end
+
+highlights.new = function(...)
+ return Highlighter:new(...)
+end
+
+return highlights