Skip to content

Commit

Permalink
chore(plugins): revert "refactor: prefer native folds over plugins (#416
Browse files Browse the repository at this point in the history
)"

This reverts commit d3d9b4a.
  • Loading branch information
n3wborn committed Dec 11, 2024
1 parent af65e98 commit dd3d032
Show file tree
Hide file tree
Showing 3 changed files with 120 additions and 12 deletions.
11 changes: 6 additions & 5 deletions lazy-lock.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@
"cmp-under-comparator": { "branch": "master", "commit": "6857f10272c3cfe930cece2afa2406e1385bfef8" },
"conform.nvim": { "branch": "master", "commit": "f4e8837878fc5712d053ba3091a73d27d96a09e2" },
"diffview.nvim": { "branch": "main", "commit": "4516612fe98ff56ae0415a259ff6361a89419b0a" },
"dressing.nvim": { "branch": "master", "commit": "fc78a3ca96f4db9f8893bb7e2fd9823e0780451b" },
"fzf-lua": { "branch": "main", "commit": "b7e4d478d0ba4cb8495a7b249fe53cf4613072cf" },
"git-conflict.nvim": { "branch": "main", "commit": "4dc906855751096aaeba2edde7c2cdc7bb881c98" },
"gitsigns.nvim": { "branch": "main", "commit": "5f808b5e4fef30bd8aca1b803b4e555da07fc412" },
Expand All @@ -33,6 +32,7 @@
"nvim-navbuddy": { "branch": "master", "commit": "f22bac988f2dd073601d75ba39ea5636ab6e38cb" },
"nvim-navic": { "branch": "master", "commit": "8649f694d3e76ee10c19255dece6411c29206a54" },
"nvim-notify": { "branch": "master", "commit": "fbef5d32be8466dd76544a257d3f3dce20082a07" },
"nvim-origami": { "branch": "main", "commit": "53a46dbc2234eb86dcee33ced72b19ff3af91744" },
"nvim-rip-substitute": { "branch": "main", "commit": "afa6d8d2dd426eba90d0cd1c6cef6d6b88c5d8f5" },
"nvim-surround": { "branch": "main", "commit": "9f0cb495f25bff32c936062d85046fbda0c43517" },
"nvim-treesitter": { "branch": "master", "commit": "337b503688eccb3046547661e4c738e674548fcf" },
Expand All @@ -41,15 +41,16 @@
"nvim-treesitter-textobjects": { "branch": "master", "commit": "ad8f0a472148c3e0ae9851e26a722ee4e29b1595" },
"nvim-ts-autotag": { "branch": "main", "commit": "1cca23c9da708047922d3895a71032bc0449c52d" },
"nvim-ts-context-commentstring": { "branch": "main", "commit": "1b212c2eee76d787bbea6aa5e92a2b534e7b4f8f" },
"nvim-ufo": { "branch": "main", "commit": "95cbe2e99901135704aabdc8732d722cf68b12c9" },
"nvim-web-devicons": { "branch": "master", "commit": "e73d2774d12d0ecf9e05578d692ba1ea50508cf2" },
"nvim-window-picker": { "branch": "main", "commit": "41cfaa428577c53552200a404ae9b3a0b5719706" },
"oil.nvim": { "branch": "master", "commit": "7a55ede5e745e31ea8e4cb5483221524922294bf" },
"oil.nvim": { "branch": "master", "commit": "dba037598843973b8c54bc5ce0318db4a0da439d" },
"plenary.nvim": { "branch": "master", "commit": "2d9b06177a975543726ce5c73fca176cedbffe9d" },
"rainbow-delimiters.nvim": { "branch": "master", "commit": "e9dfb4582b9ca0ab7e987c65999f662242bd6f61" },
"resession.nvim": { "branch": "master", "commit": "18f507c42e213918ec28bf6ed9a5ec33990c0e95" },
"promise-async": { "branch": "main", "commit": "119e8961014c9bfaf1487bf3c2a393d254f337e2" },
"rainbow-delimiters.nvim": { "branch": "master", "commit": "dc788723f717bdd3041838b8db34cce53c9aa920" },
"rustaceanvim": { "branch": "master", "commit": "bc8c4b8f7606d5b7c067cd8369e25c1a7ff77bd0" },
"schemastore.nvim": { "branch": "main", "commit": "f8c2a0f5d51b800ea4625808e243d9e8f7c5e1df" },
"snacks.nvim": { "branch": "main", "commit": "51f95693aedcde10e65c8121c6fd1293a3ac3819" },
"snacks.nvim": { "branch": "main", "commit": "c9880ce872ca000d17ae8d62b10e913045f54735" },
"telescope-git-submodules.nvim": { "branch": "main", "commit": "e9bbf8b9451dcd7911e0c1bf3ab0f61bb33e0a59" },
"telescope.nvim": { "branch": "master", "commit": "a0bbec21143c7bc5f8bb02e0005fa0b982edc026" },
"todo-comments.nvim": { "branch": "main", "commit": "ae0a2afb47cf7395dc400e5dc4e05274bf4fb9e0" },
Expand Down
9 changes: 2 additions & 7 deletions lua/custom/options.lua
Original file line number Diff line number Diff line change
Expand Up @@ -45,13 +45,8 @@ vim.o.winwidth = 10
vim.o.winminwidth = 10
vim.o.equalalways = false
vim.g.markdown_recommended_style = 0
vim.o.foldcolumn = '1'
vim.o.foldenable = true
vim.o.foldexpr = 'v:lua.vim.lsp.foldexpr()'
vim.o.foldlevel = 99
vim.o.foldlevelstart = 99
vim.o.foldmethod = 'expr'
vim.o.fillchars = 'eob: ,fold: ,foldopen:,foldsep: ,foldclose:'

vim.wo.foldtext = 'v:lua.vim.treesitter.foldtext()'
vim.o.statuscolumn = '%@SignCb@%s%=%T%@NumCb@%l│%T'

-- taken from Lazyvim LazyVim/lua/lazyvim/plugins/extras/util/dot.lua
Expand Down
112 changes: 112 additions & 0 deletions lua/plugins/folds.lua
Original file line number Diff line number Diff line change
@@ -0,0 +1,112 @@
-- taken from https://github.com/chrisgrieser/.config/blob/main/nvim/lua/plugins/folding-plugins.lua
local foldIcon = ''
local hlgroup = 'NonText'
local function foldTextFormatter(virtText, lnum, endLnum, width, truncate)
local newVirtText = {}
local suffix = ' ' .. foldIcon .. ' ' .. tostring(endLnum - lnum)
local sufWidth = vim.fn.strdisplaywidth(suffix)
local targetWidth = width - sufWidth
local curWidth = 0
for _, chunk in ipairs(virtText) do
local chunkText = chunk[1]
local chunkWidth = vim.fn.strdisplaywidth(chunkText)
if targetWidth > curWidth + chunkWidth then
table.insert(newVirtText, chunk)
else
chunkText = truncate(chunkText, targetWidth - curWidth)
local hlGroup = chunk[2]
table.insert(newVirtText, { chunkText, hlGroup })
chunkWidth = vim.fn.strdisplaywidth(chunkText)
if curWidth + chunkWidth < targetWidth then
suffix = suffix .. (' '):rep(targetWidth - curWidth - chunkWidth)
end
break
end
curWidth = curWidth + chunkWidth
end
table.insert(newVirtText, { suffix, hlgroup })
return newVirtText
end

return {
{
'chrisgrieser/nvim-origami',
event = 'BufReadPost', -- later will not save folds
opts = true,
},
{ -- UFO
'kevinhwang91/nvim-ufo',
dependencies = 'kevinhwang91/promise-async',
event = 'BufReadPost', -- needed for folds to load in time
keys = {
{
'zr',
function()
require('ufo').openFoldsExceptKinds({ 'imports', 'comment' })
end,
desc = ' 󱃄 Open All Folds except comments',
},
{
'zm',
function()
require('ufo').closeAllFolds()
end,
desc = ' 󱃄 Close All Folds',
},
{
'z1',
function()
require('ufo').closeFoldsWith(1)
end,
desc = ' 󱃄 Close L1 Folds',
},
{
'z2',
function()
require('ufo').closeFoldsWith(2)
end,
desc = ' 󱃄 Close L2 Folds',
},
{
'z3',
function()
require('ufo').closeFoldsWith(3)
end,
desc = ' 󱃄 Close L3 Folds',
},
{
'z4',
function()
require('ufo').closeFoldsWith(4)
end,
desc = ' 󱃄 Close L4 Folds',
},
},
init = function()
-- INFO fold commands usually change the foldlevel, which fixes folds, e.g.
-- auto-closing them after leaving insert mode, however ufo does not seem to
-- have equivalents for zr and zm because there is no saved fold level.
-- Consequently, the vim-internal fold levels need to be disabled by setting
-- them to 99
vim.opt.foldlevel = 99
vim.opt.foldlevelstart = 99
end,
opts = {
provider_selector = function(_, ft, _)
-- INFO some filetypes only allow indent, some only LSP, some only
-- treesitter. However, ufo only accepts two kinds as priority,
-- therefore making this function necessary :/
local lspWithOutFolding = { 'markdown', 'sh', 'css', 'html', 'python' }
if vim.tbl_contains(lspWithOutFolding, ft) then
return { 'treesitter', 'indent' }
end
return { 'lsp', 'indent' }
end,
-- open opening the buffer, close these fold kinds
-- use `:UfoInspect` to get available fold kinds from the LSP
close_fold_kinds_for_ft = { lsp = { 'imports', 'comment' } },
open_fold_hl_timeout = 800,
fold_virt_text_handler = foldTextFormatter,
},
},
}

0 comments on commit dd3d032

Please sign in to comment.