mirror of
				https://github.com/NotAShelf/nvf.git
				synced 2025-10-25 00:52:43 +00:00 
			
		
		
		
	neovim/init: add API for autocmds and autogroups (#656)
This commit is contained in:
		
					parent
					
						
							
								9f276a0c5f
							
						
					
				
			
			
				commit
				
					
						dd281b78e5
					
				
			
		
					 3 changed files with 194 additions and 0 deletions
				
			
		|  | @ -52,6 +52,14 @@ | ||||||
| 
 | 
 | ||||||
| - Add [yazi.nvim] as a companion plugin for Yazi, the terminal file manager. | - Add [yazi.nvim] as a companion plugin for Yazi, the terminal file manager. | ||||||
| 
 | 
 | ||||||
|  | - Add [](#opt-vim.autocmds) and [](#opt-vim.augroups) to allow declaring | ||||||
|  |   autocommands via Nix. | ||||||
|  | 
 | ||||||
|  | - Fix plugin `setupOpts` for yanky.nvim and assert if shada is configured as a | ||||||
|  |   backend while shada is disabled in Neovim options. | ||||||
|  | 
 | ||||||
|  | - Add [yazi.nvim] as a companion plugin for Yazi, the terminal file manager. | ||||||
|  | 
 | ||||||
| [amadaluzia](https://github.com/amadaluzia): | [amadaluzia](https://github.com/amadaluzia): | ||||||
| 
 | 
 | ||||||
| [haskell-tools.nvim]: https://github.com/MrcJkb/haskell-tools.nvim | [haskell-tools.nvim]: https://github.com/MrcJkb/haskell-tools.nvim | ||||||
|  |  | ||||||
							
								
								
									
										185
									
								
								modules/neovim/init/autocmds.nix
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										185
									
								
								modules/neovim/init/autocmds.nix
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,185 @@ | ||||||
|  | { | ||||||
|  |   config, | ||||||
|  |   lib, | ||||||
|  |   ... | ||||||
|  | }: let | ||||||
|  |   inherit (lib.options) mkOption mkEnableOption literalExpression; | ||||||
|  |   inherit (lib.lists) filter; | ||||||
|  |   inherit (lib.strings) optionalString; | ||||||
|  |   inherit (lib.types) nullOr submodule listOf str bool; | ||||||
|  |   inherit (lib.nvim.types) luaInline; | ||||||
|  |   inherit (lib.nvim.lua) toLuaObject; | ||||||
|  |   inherit (lib.nvim.dag) entryAfter; | ||||||
|  | 
 | ||||||
|  |   autocommandType = submodule { | ||||||
|  |     options = { | ||||||
|  |       enable = | ||||||
|  |         mkEnableOption "" | ||||||
|  |         // { | ||||||
|  |           default = true; | ||||||
|  |           description = "Whether to enable this autocommand"; | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |       event = mkOption { | ||||||
|  |         type = nullOr (listOf str); | ||||||
|  |         default = null; | ||||||
|  |         example = ["BufRead" "BufWritePre"]; | ||||||
|  |         description = "The event(s) that trigger the autocommand."; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       pattern = mkOption { | ||||||
|  |         type = nullOr (listOf str); | ||||||
|  |         default = null; | ||||||
|  |         example = ["*.lua" "*.vim"]; | ||||||
|  |         description = "The file pattern(s) that determine when the autocommand applies)."; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       callback = mkOption { | ||||||
|  |         type = nullOr luaInline; | ||||||
|  |         default = null; | ||||||
|  |         example = literalExpression '' | ||||||
|  |           mkLuaInline ''' | ||||||
|  |             function() | ||||||
|  |                 print("Saving a Lua file...") | ||||||
|  |             end | ||||||
|  |           '''' | ||||||
|  |         ''; | ||||||
|  |         description = "The file pattern(s) that determine when the autocommand applies."; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       command = mkOption { | ||||||
|  |         type = nullOr str; | ||||||
|  |         default = null; | ||||||
|  |         description = "Vim command string instead of a Lua function."; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       group = mkOption { | ||||||
|  |         type = nullOr str; | ||||||
|  |         default = null; | ||||||
|  |         example = "MyAutoCmdGroup"; | ||||||
|  |         description = "An optional autocommand group to manage related autocommands."; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       desc = mkOption { | ||||||
|  |         type = nullOr str; | ||||||
|  |         default = null; | ||||||
|  |         example = "Notify when saving a Lua file"; | ||||||
|  |         description = "A description for the autocommand."; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       once = mkOption { | ||||||
|  |         type = bool; | ||||||
|  |         default = false; | ||||||
|  |         description = "Whether autocommand run only once."; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       nested = mkOption { | ||||||
|  |         type = bool; | ||||||
|  |         default = false; | ||||||
|  |         description = "Whether to allow nested autocommands to trigger."; | ||||||
|  |       }; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   autogroupType = submodule { | ||||||
|  |     options = { | ||||||
|  |       enable = | ||||||
|  |         mkEnableOption "" | ||||||
|  |         // { | ||||||
|  |           default = true; | ||||||
|  |           description = "Whether to enable this autogroup"; | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |       name = mkOption { | ||||||
|  |         type = str; | ||||||
|  |         example = "MyAutoCmdGroup"; | ||||||
|  |         description = "The name of the autocommand group."; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       clear = mkOption { | ||||||
|  |         type = bool; | ||||||
|  |         default = true; | ||||||
|  |         description = '' | ||||||
|  |           Whether to clear existing autocommands in this group before defining new ones. | ||||||
|  |           This helps avoid duplicate autocommands. | ||||||
|  |         ''; | ||||||
|  |       }; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   cfg = config.vim; | ||||||
|  | in { | ||||||
|  |   options.vim = { | ||||||
|  |     augroups = mkOption { | ||||||
|  |       type = listOf autogroupType; | ||||||
|  |       default = []; | ||||||
|  |       description = '' | ||||||
|  |         A list of Neovim autogroups, which are used to organize and manage related | ||||||
|  |         autocommands together. Groups allow multiple autocommands to be cleared | ||||||
|  |         or redefined collectively, preventing duplicate definitions. | ||||||
|  | 
 | ||||||
|  |         Each autogroup consists of a name, a boolean indicating whether to clear | ||||||
|  |         existing autocommands, and a list of associated autocommands. | ||||||
|  |       ''; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     autocmds = mkOption { | ||||||
|  |       type = listOf autocommandType; | ||||||
|  |       default = []; | ||||||
|  |       description = '' | ||||||
|  |         A list of Neovim autocommands to be registered. | ||||||
|  | 
 | ||||||
|  |         Each entry defines an autocommand, specifying events, patterns, optional | ||||||
|  |         callbacks, commands, groups, and execution settings. | ||||||
|  |       ''; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   config = { | ||||||
|  |     vim = let | ||||||
|  |       enabledAutocommands = filter (cmd: cmd.enable) cfg.autocmds; | ||||||
|  |       enabledAutogroups = filter (au: au.enable) cfg.augroups; | ||||||
|  |     in { | ||||||
|  |       luaConfigRC = { | ||||||
|  |         augroups = entryAfter ["pluginConfigs"] (optionalString (enabledAutogroups != []) '' | ||||||
|  |           local nvf_autogroups = {} | ||||||
|  |           for _, group in ipairs(${toLuaObject enabledAutogroups}) do | ||||||
|  |             if group.name then | ||||||
|  |               nvf_autogroups[group.name] = { clear = group.clear } | ||||||
|  |             end | ||||||
|  |           end | ||||||
|  | 
 | ||||||
|  |           for group_name, options in pairs(nvf_autogroups) do | ||||||
|  |             vim.api.nvim_create_augroup(group_name, options) | ||||||
|  |           end | ||||||
|  |         ''); | ||||||
|  | 
 | ||||||
|  |         autocmds = entryAfter ["pluginConfigs"] (optionalString (enabledAutocommands != []) '' | ||||||
|  |           local nvf_autocommands = ${toLuaObject enabledAutocommands} | ||||||
|  |           for _, autocmd in ipairs(nvf_autocommands) do | ||||||
|  |             vim.api.nvim_create_autocmd( | ||||||
|  |               autocmd.event, | ||||||
|  |               { | ||||||
|  |                 group     = autocmd.group, | ||||||
|  |                 pattern   = autocmd.pattern, | ||||||
|  |                 buffer    = autocmd.buffer, | ||||||
|  |                 desc      = autocmd.desc, | ||||||
|  |                 callback  = autocmd.callback, | ||||||
|  |                 command   = autocmd.command, | ||||||
|  |                 once      = autocmd.once, | ||||||
|  |                 nested    = autocmd.nested | ||||||
|  |               } | ||||||
|  |             ) | ||||||
|  |           end | ||||||
|  |         ''); | ||||||
|  |       }; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     assertions = [ | ||||||
|  |       { | ||||||
|  |         assertion = builtins.all (cmd: (cmd.command == null || cmd.callback == null)) cfg.autocmds; | ||||||
|  |         message = "An autocommand cannot have both 'command' and 'callback' defined at the same time."; | ||||||
|  |       } | ||||||
|  |     ]; | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  | @ -1,5 +1,6 @@ | ||||||
| { | { | ||||||
|   imports = [ |   imports = [ | ||||||
|  |     ./autocmds.nix | ||||||
|     ./basic.nix |     ./basic.nix | ||||||
|     ./debug.nix |     ./debug.nix | ||||||
|     ./highlight.nix |     ./highlight.nix | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 raf
				raf