aboutsummaryrefslogtreecommitdiff
path: root/test/functional/lua/api_spec.lua
diff options
context:
space:
mode:
authorLuuk van Baal <luukvbaal@gmail.com>2023-12-06 13:34:19 +0100
committerLewis Russell <me@lewisr.dev>2023-12-07 14:22:24 +0000
commit4a34da82c18e6da1e46d6bf3d21082a6b6c8b947 (patch)
tree0f9b6b45e4aa4a757526e6727ca9943b8170ba87 /test/functional/lua/api_spec.lua
parente42f03264b424450b560a69994879f09b6c555d8 (diff)
downloadrneovim-4a34da82c18e6da1e46d6bf3d21082a6b6c8b947.tar.gz
rneovim-4a34da82c18e6da1e46d6bf3d21082a6b6c8b947.tar.bz2
rneovim-4a34da82c18e6da1e46d6bf3d21082a6b6c8b947.zip
perf(column): keep track of number of lines that hold up the 'signcolumn'
Problem: The entire marktree needs to be traversed each time a sign is removed from the sentinel line. Solution: Remove sentinel line and instead keep track of the number of lines that hold up the 'signcolumn' in "max_count". Adjust this number for added/removed signs, and set it to 0 when the maximum number of signs on a line changes. Only when "max_count" is decremented to 0 due to sign removal do we need to check the entire buffer. Also replace "invalid_top" and "invalid_bot" with a map of invalid ranges, further reducing the number of lines to be checked. Also improve tree traversal when counting the number of signs. Instead of looping over the to be checked range and counting the overlap for each row, keep track of the overlap in an array and add this to the count.
Diffstat (limited to 'test/functional/lua/api_spec.lua')
0 files changed, 0 insertions, 0 deletions