summaryrefslogtreecommitdiff
path: root/lua/telescope/pickers/highlights.lua
blob: 8378e9becfb17bfeea3ca985ad2723c86063c8d8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
local a = vim.api
local log = require('telescope.log')

local highlights = {}

local ns_telescope_selection = a.nvim_create_namespace('telescope_selection')
local ns_telescope_multiselection = a.nvim_create_namespace('telescope_mulitselection')
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()
  if not self
      or not self.picker
      or not self.picker.results_bufnr
      or not vim.api.nvim_buf_is_valid(self.picker.results_bufnr)
        then
    return
  end

  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

function Highlighter:hi_multiselect(row, is_selected)
  local results_bufnr = assert(self.picker.results_bufnr, "Must have a results bufnr")

  if is_selected then
    vim.api.nvim_buf_add_highlight(
      results_bufnr, ns_telescope_multiselection, "TelescopeMultiSelection", row, 0, -1
    )
  else
    local existing_marks = vim.api.nvim_buf_get_extmarks(
      results_bufnr, ns_telescope_multiselection, {row, 0}, {row, -1}, {}
    )

    -- This is still kind of weird to me, since it seems like I'm erasing stuff
    -- when i shouldn't... perhaps it's a bout the gravity of the extmark?
    if #existing_marks > 0 then
      log.trace("Clearning row: ", row)

      vim.api.nvim_buf_clear_namespace(
        results_bufnr,
        ns_telescope_multiselection,
        row,
        row + 1
      )
    end
  end
end

highlights.new = function(...)
  return Highlighter:new(...)
end

return highlights