finish indent markers properly

This commit is contained in:
kiyan42
2020-06-20 15:34:06 +02:00
parent 7988dd407c
commit 4f499d9e53
5 changed files with 30 additions and 25 deletions

View File

@@ -29,6 +29,7 @@ local function get_hl_groups()
local colors = get_colors()
return {
IndentMarker = { fg = '#90a4ae' },
Symlink = { gui = 'bold', fg = colors.cyan },
FolderIcon = { fg = '#90a4ae' },

View File

@@ -88,28 +88,22 @@ if icon_state.show_git_icon then
end
local get_padding = function(depth)
return string.rep(' ', depth), 0
return string.rep(' ', depth)
end
local add_padding_glyph = true
if vim.g.lua_tree_indent_markers == 1 then
get_padding = function(depth, idx, tree, node)
local padding = ""
local offset = 0
if depth ~= 0 then
padding = string.rep(" ", depth-2)
if add_padding_glyph and (idx == #tree.entries or node.open) then
padding = padding..''
offset = string.len('') -2
add_padding_glyph = false
elseif add_padding_glyph then
padding = padding..''
offset = string.len('') -2
else
padding = padding..' '
for i=1,depth/2 do
if idx == #tree.entries and i == depth/2 then
padding = padding..''
else
padding = padding..''
end
end
end
return padding, offset
return padding
end
end
@@ -134,13 +128,16 @@ local function update_draw_data(tree, depth)
index = 1
end
add_padding_glyph = true
for idx, node in ipairs(tree.entries) do
local padding, offset = get_padding(depth, idx, tree, node, add_padding_glyph)
local padding = get_padding(depth, idx, tree, node)
local offset = string.len(padding)
if depth > 0 then
table.insert(hl, { 'LuaTreeIndentMarker', index, 0, offset })
end
if node.entries then
local icon = get_folder_icon(node.open)
local git_icon = get_git_icons(node, index, depth+offset+#node.name, #icon+1)
set_folder_hl(index, depth+offset, #icon, #node.name)
local git_icon = get_git_icons(node, index, offset+#node.name, #icon+1)
set_folder_hl(index, offset, #icon, #node.name)
index = index + 1
if node.open then
table.insert(lines, padding..icon..node.name.." "..git_icon)
@@ -149,7 +146,7 @@ local function update_draw_data(tree, depth)
table.insert(lines, padding..icon..node.name.." "..git_icon)
end
elseif node.link_to then
table.insert(hl, { 'LuaTreeSymlink', index, depth+offset, -1 })
table.insert(hl, { 'LuaTreeSymlink', index, offset, -1 })
table.insert(lines, padding..node.name..""..node.link_to)
index = index + 1
@@ -158,17 +155,17 @@ local function update_draw_data(tree, depth)
local git_icons
if special[node.name] then
icon = ""
git_icons = get_git_icons(node, index, depth+offset, 0)
table.insert(hl, {'LuaTreeSpecialFile', index, depth+offset+#git_icons, -1})
git_icons = get_git_icons(node, index, offset, 0)
table.insert(hl, {'LuaTreeSpecialFile', index, offset+#git_icons, -1})
else
icon = get_file_icon(node.name, node.extension, index, depth+offset)
git_icons = get_git_icons(node, index, depth+offset, #icon)
icon = get_file_icon(node.name, node.extension, index, offset)
git_icons = get_git_icons(node, index, offset, #icon)
end
table.insert(lines, padding..icon..git_icons..node.name)
if node.executable then
table.insert(hl, {'LuaTreeExecFile', index, depth+offset+#icon+#git_icons, -1 })
table.insert(hl, {'LuaTreeExecFile', index, offset+#icon+#git_icons, -1 })
elseif picture[node.extension] then
table.insert(hl, {'LuaTreeImageFile', index, depth+offset+#icon+#git_icons, -1 })
table.insert(hl, {'LuaTreeImageFile', index, offset+#icon+#git_icons, -1 })
end
index = index + 1
end