1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-03-13 02:05:40 +08:00

pref(indentline): update bundle indent-blankline.nvim

ref: 9920ceb79b
This commit is contained in:
wsdjeg 2022-03-30 23:41:26 +08:00
parent 662480aabf
commit fe0fb46018
7 changed files with 227 additions and 69 deletions

View File

@ -1,22 +1,43 @@
name: Pull request check
on:
pull_request:
pull_request:
jobs:
format:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: JohnnyMorganz/stylua-action@1.0.0
with:
token: ${{ secrets.GITHUB_TOKEN }}
args: --check .
format:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: JohnnyMorganz/stylua-action@1.0.0
with:
token: ${{ secrets.GITHUB_TOKEN }}
args: --check .
block-fixup:
runs-on: ubuntu-latest
block-fixup:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Block Fixup Commit Merge
uses: 13rac1/block-fixup-merge-action@v2.0.0
luacheck:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: leafo/gh-actions-lua@v8.0.0
with:
luaVersion: 'luajit-2.1.0-beta3'
- uses: leafo/gh-actions-luarocks@v4.0.0
- name: build
run: |
luarocks install luacheck
- name: test
run: |
luacheck lua
steps:
- uses: actions/checkout@v2
- name: Block Fixup Commit Merge
uses: 13rac1/block-fixup-merge-action@v2.0.0

View File

@ -0,0 +1,2 @@
globals = { "vim", "_" }
max_line_length = false

View File

@ -1,18 +0,0 @@
function! indent_blankline#Refresh(...)
try
if a:0 > 0
call luaeval("require('indent_blankline').refresh(_A)", a:1)
else
lua require("indent_blankline").refresh()
end
catch /E12/
return
catch
if g:indent_blankline_debug
echohl Error
echom 'indent-blankline encountered an error on refresh: ' . v:exception
echohl None
endif
endtry
endfunction

View File

@ -2,7 +2,7 @@
Author: Lukas Reineke <lukas.reineke@protonmail.com>
Version: 2.11.0
Version: 2.15.0
==============================================================================
CONTENTS *indent-blankline*
@ -149,6 +149,18 @@ g:indent_blankline_char *g:indent_blankline_char*
let g:indent_blankline_char = '|'
------------------------------------------------------------------------------
g:indent_blankline_char_blankline *g:indent_blankline_char_blankline*
Specifies the character to be used as indent line for blanklines.
Not used if |g:indent_blankline_char_list_blankline| is not empty.
Default: '' ~
Example: >
let g:indent_blankline_char_blankline = '┆'
------------------------------------------------------------------------------
g:indent_blankline_char_list *g:indent_blankline_char_list*
@ -164,6 +176,19 @@ g:indent_blankline_char_list *g:indent_blankline_char_list*
let g:indent_blankline_char_list = ['|', '¦', '┆', '┊']
------------------------------------------------------------------------------
g:indent_blankline_char_list_blankline *g:indent_blankline_char_list_blankline*
Specifies a list of characters to be used as indent line for
each indentation level on blanklines.
Ignored if the value is an empty list.
Default: [] ~
Example: >
let g:indent_blankline_char_list_blankline = ['|', '¦', '┆', '┊']
------------------------------------------------------------------------------
g:indent_blankline_char_highlight_list *g:indent_blankline_char_highlight_list*
@ -359,7 +384,13 @@ g:indent_blankline_filetype_exclude *g:indent_blankline_filetype_exclude*
Also set by |g:indentLine_fileTypeExclude|
Default: [] ~
Default: [ ~
"lspinfo", ~
"packer", ~
"checkhealth", ~
"help", ~
"", ~
] ~
Example: >
@ -475,6 +506,18 @@ g:indent_blankline_context_char *g:indent_blankline_context_char*
let g:indent_blankline_context_char = '┃'
------------------------------------------------------------------------------
g:indent_blankline_context_char_blankline *g:indent_blankline_context_char_blankline*
Equivalent of |g:indent_blankline_char_blankline| for
|g:indent_blankline_context_char|.
Default: '' ~
Example: >
let g:indent_blankline_context_char_blankline = '┆'
------------------------------------------------------------------------------
g:indent_blankline_context_char_list *g:indent_blankline_context_char_list*
@ -487,6 +530,18 @@ g:indent_blankline_context_char_list *g:indent_blankline_context_char_list*
let g:indent_blankline_context_char_list = ['┃', '║', '╬', '█']
------------------------------------------------------------------------------
g:indent_blankline_context_char_list_blankline *g:indent_blankline_context_char_list_blankline*
Equivalent of |g:indent_blankline_char_list_blankline| for
|g:indent_blankline_context_char_blankline|.
Default: [] ~
Example: >
let g:indent_blankline_context_char_list_blankline = ['┃', '║', '╬', '█']
------------------------------------------------------------------------------
g:indent_blankline_context_highlight_list *g:indent_blankline_context_highlight_list*
@ -514,7 +569,24 @@ g:indent_blankline_context_patterns *g:indent_blankline_context_patterns*
Only used when |g:indent_blankline_show_current_context| is active
Default: ['class', 'function', 'method'] ~
Default: [ ~
"class", ~
"^func", ~
"method", ~
"^if", ~
"while", ~
"for", ~
"with", ~
"try", ~
"except", ~
"arguments", ~
"argument_list", ~
"object", ~
"dictionary", ~
"element", ~
"table", ~
"tuple", ~
] ~
Example: >
@ -637,6 +709,26 @@ g:indent_blankline_debug *g:indent_blankline_debug*
==============================================================================
6. CHANGELOG *indent-blankline-changelog*
2.15.0
* Add |g:indent_blankline_context_char_blankline| and
|g:indent_blankline_context_char_list_blankline| options
2.14.0
* Add |g:indent_blankline_char_blankline| and
|g:indent_blankline_char_list_blankline| options
2.13.0
* Support both the concatenated string, as well as the individual |filetypes|
in |g:indent_blankline_filetype_exclude| when a buffer has multiple filetypes
2.12.1
* Add ext mark priority
2.12.0
* Remove old vimscript functions
* Better default values for |g:indent_blankline_context_patterns| and
|g:indent_blankline_filetype_exclude|
2.11.0
* Add |g:indent_blankline_show_current_context_start_on_current_line|

View File

@ -4,12 +4,12 @@ M.refresh = function(bang, scroll)
scroll = scroll or false
if bang then
local win = vim.api.nvim_get_current_win()
vim.cmd(string.format([[noautocmd windo call indent_blankline#Refresh(v:%s)]], tostring(scroll)))
vim.cmd(string.format([[noautocmd windo lua require("indent_blankline").refresh(%s)]], tostring(scroll)))
if vim.api.nvim_win_is_valid(win) then
vim.api.nvim_set_current_win(win)
end
else
vim.cmd(string.format([[call indent_blankline#Refresh(v:%s)]], tostring(scroll)))
require("indent_blankline").refresh(scroll)
end
end
@ -17,11 +17,11 @@ M.enable = function(bang)
if bang then
vim.g.indent_blankline_enabled = true
local win = vim.api.nvim_get_current_win()
vim.cmd [[noautocmd windo call indent_blankline#Refresh()]]
vim.cmd [[noautocmd windo lua require("indent_blankline").refresh(false)]]
vim.api.nvim_set_current_win(win)
else
vim.b.indent_blankline_enabled = true
vim.cmd [[call indent_blankline#Refresh()]]
require("indent_blankline").refresh(false)
end
end

View File

@ -24,17 +24,31 @@ M.setup = function(options)
local o = utils.first_not_nil
vim.g.indent_blankline_char = o(options.char, vim.g.indent_blankline_char, vim.g.indentLine_char, "")
vim.g.indent_blankline_char_blankline = o(options.char_blankline, vim.g.indent_blankline_char_blankline)
vim.g.indent_blankline_char_list = o(
options.char_list,
vim.g.indent_blankline_char_list,
vim.g.indentLine_char_list
)
vim.g.indent_blankline_char_list_blankline = o(
options.char_list_blankline,
vim.g.indent_blankline_char_list_blankline
)
vim.g.indent_blankline_context_char = o(
options.context_char,
vim.g.indent_blankline_context_char,
vim.g.indent_blankline_char
)
vim.g.indent_blankline_context_char_blankline = o(
options.context_char_blankline,
vim.g.indent_blankline_context_char_blankline,
vim.g.indent_blankline_char_blankline
)
vim.g.indent_blankline_context_char_list = o(options.context_char_list, vim.g.indent_blankline_context_char_list)
vim.g.indent_blankline_context_char_list_blankline = o(
options.context_char_list_blankline,
vim.g.indent_blankline_context_char_list
)
vim.g.indent_blankline_char_highlight_list = o(
options.char_highlight_list,
vim.g.indent_blankline_char_highlight_list
@ -65,7 +79,8 @@ M.setup = function(options)
vim.g.indent_blankline_filetype_exclude = o(
options.filetype_exclude,
vim.g.indent_blankline_filetype_exclude,
vim.g.indentLine_fileTypeExclude
vim.g.indentLine_fileTypeExclude,
{ "lspinfo", "packer", "checkhealth", "help", "" }
)
vim.g.indent_blankline_bufname_exclude = o(
options.bufname_exclude,
@ -120,11 +135,24 @@ M.setup = function(options)
options.context_highlight_list,
vim.g.indent_blankline_context_highlight_list
)
vim.g.indent_blankline_context_patterns = o(
options.context_patterns,
vim.g.indent_blankline_context_patterns,
{ "class", "function", "method" }
)
vim.g.indent_blankline_context_patterns = o(options.context_patterns, vim.g.indent_blankline_context_patterns, {
"class",
"^func",
"method",
"^if",
"while",
"for",
"with",
"try",
"except",
"arguments",
"argument_list",
"object",
"dictionary",
"element",
"table",
"tuple",
})
vim.g.indent_blankline_context_pattern_highlight = o(
options.context_pattern_highlight,
vim.g.indent_blankline_context_pattern_highlight
@ -166,7 +194,7 @@ local refresh = function(scroll)
vim.opt.list:get(),
vim.bo.filetype,
v "indent_blankline_filetype" or {},
v "indent_blankline_filetype_exclude" or {},
v "indent_blankline_filetype_exclude",
vim.bo.buftype,
v "indent_blankline_buftype_exclude" or {},
v "indent_blankline_bufname_exclude" or {},
@ -237,15 +265,19 @@ local refresh = function(scroll)
local lines = vim.api.nvim_buf_get_lines(bufnr, offset, range, false)
local char = v "indent_blankline_char"
local char_blankline = v "indent_blankline_char_blankline"
local char_list = v "indent_blankline_char_list" or {}
local char_list_blankline = v "indent_blankline_char_list_blankline" or {}
local context_char = v "indent_blankline_context_char"
local context_char_blankline = v "indent_blankline_context_char_blankline"
local context_char_list = v "indent_blankline_context_char_list" or {}
local context_char_list_blankline = v "indent_blankline_context_char_list_blankline" or {}
local char_highlight_list = v "indent_blankline_char_highlight_list" or {}
local space_char_highlight_list = v "indent_blankline_space_char_highlight_list" or {}
local space_char_blankline_highlight_list = v "indent_blankline_space_char_blankline_highlight_list" or {}
local space_char_blankline = v "indent_blankline_space_char_blankline"
local list_chars = {}
local list_chars
local no_tab_character = false
-- No need to check for disable_with_nolist as this part would never be executed if "true" && nolist
if vim.opt.list:get() then
@ -317,11 +349,23 @@ local refresh = function(scroll)
local virtual_text = {}
local current_left_offset = left_offset
local local_max_indent_level = math.min(max_indent_level, prev_indent + max_indent_increase)
local indent_char = utils._if(blankline and char_blankline, char_blankline, char)
local context_indent_char = utils._if(
blankline and context_char_blankline,
context_char_blankline,
context_char
)
local indent_char_list = utils._if(blankline and #char_list_blankline > 0, char_list_blankline, char_list)
local context_indent_char_list = utils._if(
blankline and #context_char_list_blankline > 0,
context_char_list_blankline,
context_char_list
)
for i = 1, math.min(math.max(indent, 0), local_max_indent_level) do
local space_count = shiftwidth
local context = context_active and context_indent == i
local show_indent_char = (i ~= 1 or first_indent) and char ~= ""
local show_context_indent_char = context and (i ~= 1 or first_indent) and context_char ~= ""
local show_indent_char = (i ~= 1 or first_indent) and indent_char ~= ""
local show_context_indent_char = context and (i ~= 1 or first_indent) and context_indent_char ~= ""
local show_end_of_line_char = i == 1 and blankline and end_of_line and list_chars["eol_char"]
local show_indent_or_eol_char = show_indent_char or show_context_indent_char or show_end_of_line_char
if show_indent_or_eol_char then
@ -336,11 +380,15 @@ local refresh = function(scroll)
utils._if(
context,
utils.get_from_list(
context_char_list,
context_indent_char_list,
i - utils._if(not first_indent, 1, 0),
context_char
context_indent_char
),
utils.get_from_list(char_list, i - utils._if(not first_indent, 1, 0), char)
utils.get_from_list(
indent_char_list,
i - utils._if(not first_indent, 1, 0),
indent_char
)
)
),
utils._if(
@ -393,7 +441,10 @@ local refresh = function(scroll)
local extra_context_active = context_active and context_indent == index
if
(char ~= "" or (extra_context_active and context_char ~= ""))
(
(indent_char ~= "" or #indent_char_list > 0)
or (extra_context_active and (context_indent_char ~= "" or #context_char_list > 0))
)
and ((blankline or extra) and trail_indent)
and (first_indent or #virtual_text > 0)
and current_left_offset < 1
@ -402,8 +453,12 @@ local refresh = function(scroll)
table.insert(virtual_text, {
utils._if(
extra_context_active,
utils.get_from_list(context_char_list, index - utils._if(not first_indent, 1, 0), context_char),
utils.get_from_list(char_list, index - utils._if(not first_indent, 1, 0), char)
utils.get_from_list(
context_indent_char_list,
index - utils._if(not first_indent, 1, 0),
context_indent_char
),
utils.get_from_list(indent_char_list, index - utils._if(not first_indent, 1, 0), indent_char)
),
utils._if(
extra_context_active,
@ -487,7 +542,7 @@ local refresh = function(scroll)
vim.g.indent_blankline_namespace,
i - 1 + offset,
0,
{ virt_text = virtual_text, virt_text_pos = "overlay", hl_mode = "combine" }
{ virt_text = virtual_text, virt_text_pos = "overlay", hl_mode = "combine", priority = 1 }
)
end)()
return async:close()
@ -584,7 +639,7 @@ local refresh = function(scroll)
vim.g.indent_blankline_namespace,
i - 1 + offset,
0,
{ virt_text = virtual_text, virt_text_pos = "overlay", hl_mode = "combine" }
{ virt_text = virtual_text, virt_text_pos = "overlay", hl_mode = "combine", priority = 1 }
)
end)()
return async:close()

View File

@ -70,9 +70,14 @@ M.is_indent_blankline_enabled = M.memo(
return false
end
local undotted_filetypes = vim.split(filetype, ".", { plain = true })
table.insert(undotted_filetypes, filetype)
for _, ft in ipairs(filetype_exclude) do
if ft == filetype then
return false
for _, undotted_filetype in ipairs(undotted_filetypes) do
if undotted_filetype == ft then
return false
end
end
end
@ -188,7 +193,6 @@ M.get_current_context = function(type_patterns)
if node_start ~= node_end then
return true, node_start + 1, node_end + 1, rgx
end
node_start, node_end = nil, nil
end
end
cursor_node = cursor_node:parent()
@ -210,13 +214,15 @@ M.reset_highlights = function()
vim.fn.synIDattr(label_highlight, "fg", "cterm"),
}
for highlight_name, highlight in pairs {
IndentBlanklineChar = whitespace_fg,
IndentBlanklineSpaceChar = whitespace_fg,
IndentBlanklineSpaceCharBlankline = whitespace_fg,
IndentBlanklineContextChar = label_fg,
IndentBlanklineContextStart = label_fg,
} do
for highlight_name, highlight in
pairs {
IndentBlanklineChar = whitespace_fg,
IndentBlanklineSpaceChar = whitespace_fg,
IndentBlanklineSpaceCharBlankline = whitespace_fg,
IndentBlanklineContextChar = label_fg,
IndentBlanklineContextStart = label_fg,
}
do
local current_highlight = vim.fn.synIDtrans(vim.fn.hlID(highlight_name))
if
vim.fn.synIDattr(current_highlight, "fg") == ""
@ -246,7 +252,7 @@ M.reset_highlights = function()
end
M.first_not_nil = function(...)
for _, value in pairs { ... } do
for _, value in pairs { ... } do -- luacheck: ignore
return value
end
end