mirror of
				https://github.com/NotAShelf/nvf.git
				synced 2025-10-31 02:52:37 +00:00 
			
		
		
		
	treewide: implement lazy loading via lz.n for selected plugins (#407)
* flake: add lz.n and lzn-auto-require * lazy: init module * lzn-auto-require: add init lua code * wrapper: fix opt plugin format * lib.binds: add lz.n variant of bind functions * telescope: lazy load * nvim-tree: lazy load * dapui: lazy load * trouble: lazy load * toggleterm: lazy load * cheatsheet: lazy load * diffview: lazy load * icon-picker: lazy load * leap: lazy load * fidget: lazy load * docs: add section on lazy plugins * lazy: support lazy.enable=false * comment-nvim: lazy load * surround-nvim: lazy load * neo-tree: lazy load * fixup! lazy: init module * dap: appease the nix gods (fix statix lint) * flake.lock: fix merge mistake * doc: update release note * fixup! doc: update release note * neo-tree: fix duplicate neo-tree install * lazy: use attrsOf for lazy.plugins * treewide: update lazy.plugins syntax * docs: update lazy.plugins syntax * lazy: cleanup * Update docs/manual/hacking/additional-plugins.md Co-authored-by: diniamo <55629891+diniamo@users.noreply.github.com> * formatting nitpick Co-authored-by: diniamo <55629891+diniamo@users.noreply.github.com> * typo tee hee :3 Co-authored-by: diniamo <55629891+diniamo@users.noreply.github.com> * typo tee hee :4 Co-authored-by: diniamo <55629891+diniamo@users.noreply.github.com> * flake: update lz.n * lazy: update lz.n plugin spec * lazy: allow lines in place of str for lua code * copilot: lazy load * cmp: lazy load this moves cmp itself to lazy.plugins but other plugins that call cmp are not yet lazy so cmp is technically not yet lazy * luasnip: lazy load * flake: add rtp.nvim * cmp: actually lazy load source * fixup! cmp: actually lazy load source * format * docs: fix broken link * cmp-nvim-lsp: lazy load * lazy: allow key mode of str type * cmp: install sourcess via cmp.sourcePlugins * Update docs/manual/hacking/additional-plugins.md Co-authored-by: diniamo <55629891+diniamo@users.noreply.github.com> * lazy: refactor common var * nvim-dap-ui: add setupOpts * refactor: re-order plugin and lz.n configs lazy: make lzn-auto-require togglable * docs: update dag-entries * trouble: remove redundant import * lazy: remove unused module arg * toggleterm: make lazygit keybind optional * toggleterm: use toLuaObject for clarity * surround: rework keymap config * remove stale FIXME * lsp: use cmp_nvim_lsp capabilities * cmp: deduplicate attr key * theme: ensure themes load before lazy plugins * doc: update description of `theme` dag entry * lsp: avoid loading cmp on startup * doc: update configuration docs on custom plugins * cmp: skip trigger_load if lazy disabled * treesitter: remove redundant code * lsp: mark hack as HACK * comment: remove redundant plugin * Squash merge v0.7 into feature/lzn --------- Co-authored-by: raf <raf@notashelf.dev> Co-authored-by: diniamo <55629891+diniamo@users.noreply.github.com>
This commit is contained in:
		
					parent
					
						
							
								0e763161e2
							
						
					
				
			
			
				commit
				
					
						21fcace3ed
					
				
			
		
					 42 changed files with 1226 additions and 501 deletions
				
			
		|  | @ -1,6 +1,7 @@ | |||
| {lib, ...}: let | ||||
|   inherit (lib.options) mkEnableOption; | ||||
|   inherit (lib.nvim.binds) mkMappingOption; | ||||
|   inherit (lib.nvim.types) mkPluginSetupOption; | ||||
| in { | ||||
|   options.vim.comments.comment-nvim = { | ||||
|     enable = mkEnableOption "smart and powerful comment plugin for neovim comment-nvim"; | ||||
|  | @ -15,5 +16,12 @@ in { | |||
|       toggleSelectedLine = mkMappingOption "Toggle selected comment" "gc"; | ||||
|       toggleSelectedBlock = mkMappingOption "Toggle selected block" "gb"; | ||||
|     }; | ||||
| 
 | ||||
|     setupOpts = mkPluginSetupOption "Comment-nvim" { | ||||
|       mappings = { | ||||
|         basic = mkEnableOption "basic mappings"; | ||||
|         extra = mkEnableOption "extra mappings"; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
|  |  | |||
|  | @ -3,46 +3,38 @@ | |||
|   lib, | ||||
|   ... | ||||
| }: let | ||||
|   inherit (lib.modules) mkIf mkMerge; | ||||
|   inherit (lib.nvim.binds) mkExprBinding mkBinding; | ||||
|   inherit (lib.nvim.dag) entryAnywhere; | ||||
|   inherit (lib.modules) mkIf; | ||||
|   inherit (lib.nvim.binds) mkLznExprBinding mkLznBinding; | ||||
| 
 | ||||
|   cfg = config.vim.comments.comment-nvim; | ||||
|   self = import ./comment-nvim.nix {inherit lib;}; | ||||
|   inherit (self.options.vim.comments.comment-nvim) mappings; | ||||
| in { | ||||
|   config = mkIf cfg.enable { | ||||
|     vim.startPlugins = ["comment-nvim"]; | ||||
| 
 | ||||
|     vim.maps.normal = mkMerge [ | ||||
|       (mkBinding cfg.mappings.toggleOpLeaderLine "<Plug>(comment_toggle_linewise)" mappings.toggleOpLeaderLine.description) | ||||
|       (mkBinding cfg.mappings.toggleOpLeaderBlock "<Plug>(comment_toggle_blockwise)" mappings.toggleOpLeaderBlock.description) | ||||
| 
 | ||||
|       (mkExprBinding cfg.mappings.toggleCurrentLine '' | ||||
|           function() | ||||
|             return vim.api.nvim_get_vvar('count') == 0 and '<Plug>(comment_toggle_linewise_current)' | ||||
|                     or '<Plug>(comment_toggle_linewise_count)' | ||||
|           end | ||||
|         '' | ||||
|         mappings.toggleCurrentLine.description) | ||||
|       (mkExprBinding cfg.mappings.toggleCurrentBlock '' | ||||
|           function() | ||||
|             return vim.api.nvim_get_vvar('count') == 0 and '<Plug>(comment_toggle_blockwise_current)' | ||||
|                     or '<Plug>(comment_toggle_blockwise_count)' | ||||
|           end | ||||
|         '' | ||||
|         mappings.toggleCurrentBlock.description) | ||||
|     ]; | ||||
| 
 | ||||
|     vim.maps.visual = mkMerge [ | ||||
|       (mkBinding cfg.mappings.toggleSelectedLine "<Plug>(comment_toggle_linewise_visual)" mappings.toggleSelectedLine.description) | ||||
|       (mkBinding cfg.mappings.toggleSelectedBlock "<Plug>(comment_toggle_blockwise_visual)" mappings.toggleSelectedBlock.description) | ||||
|     ]; | ||||
| 
 | ||||
|     vim.pluginRC.comment-nvim = entryAnywhere '' | ||||
|       require('Comment').setup({ | ||||
|         mappings = { basic = false, extra = false, }, | ||||
|       }) | ||||
|     ''; | ||||
|     vim.lazy.plugins.comment-nvim = { | ||||
|       package = "comment-nvim"; | ||||
|       setupModule = "Comment"; | ||||
|       inherit (cfg) setupOpts; | ||||
|       keys = [ | ||||
|         (mkLznBinding ["n"] cfg.mappings.toggleOpLeaderLine "<Plug>(comment_toggle_linewise)" mappings.toggleOpLeaderLine.description) | ||||
|         (mkLznBinding ["n"] cfg.mappings.toggleOpLeaderBlock "<Plug>(comment_toggle_blockwise)" mappings.toggleOpLeaderBlock.description) | ||||
|         (mkLznExprBinding ["n"] cfg.mappings.toggleCurrentLine '' | ||||
|             function() | ||||
|               return vim.api.nvim_get_vvar('count') == 0 and '<Plug>(comment_toggle_linewise_current)' | ||||
|                       or '<Plug>(comment_toggle_linewise_count)' | ||||
|             end | ||||
|           '' | ||||
|           mappings.toggleCurrentLine.description) | ||||
|         (mkLznExprBinding ["n"] cfg.mappings.toggleCurrentBlock '' | ||||
|             function() | ||||
|               return vim.api.nvim_get_vvar('count') == 0 and '<Plug>(comment_toggle_blockwise_current)' | ||||
|                       or '<Plug>(comment_toggle_blockwise_count)' | ||||
|             end | ||||
|           '' | ||||
|           mappings.toggleCurrentBlock.description) | ||||
|         (mkLznBinding ["x"] cfg.mappings.toggleSelectedLine "<Plug>(comment_toggle_linewise_visual)" mappings.toggleSelectedLine.description) | ||||
|         (mkLznBinding ["x"] cfg.mappings.toggleSelectedBlock "<Plug>(comment_toggle_blockwise_visual)" mappings.toggleSelectedBlock.description) | ||||
|       ]; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Ching Pei Yang
				Ching Pei Yang