mirror of
				https://github.com/NotAShelf/nvf.git
				synced 2025-10-25 17:06:11 +00:00 
			
		
		
		
	docs/tips: document pure-lua/hybrid setups
This commit is contained in:
		
					parent
					
						
							
								ef1fa6bf25
							
						
					
				
			
			
				commit
				
					
						9f1bd7fb35
					
				
			
		
					 3 changed files with 68 additions and 0 deletions
				
			
		|  | @ -17,3 +17,9 @@ nvf-print-config | bat --language=lua | |||
| ``` | ||||
| 
 | ||||
| Alternatively, `cat` or `less` may also be used. | ||||
| 
 | ||||
| ## Accessing `neovimConfig` {#sec-accessing-config} | ||||
| 
 | ||||
| It is also possible to access the configuration for the wrapped package. The | ||||
| _built_ Neovim package will contain a `neovimConfig` attribute in its | ||||
| `passthru`. | ||||
|  |  | |||
							
								
								
									
										61
									
								
								docs/manual/tips/pure-lua-config.md
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								docs/manual/tips/pure-lua-config.md
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,61 @@ | |||
| # Pure Lua Configuration {#pure-lua-config} | ||||
| 
 | ||||
| We recognize that you might not always want to configure your setup purely in | ||||
| Nix, sometimes doing things in Lua is simply the "superior" option. In such a | ||||
| case you might want to configure your Neovim instance using Lua, and nothing but | ||||
| Lua. It is also possible to mix Lua and Nix configurations through the following | ||||
| method. | ||||
| 
 | ||||
| ## Custom Configuration Directory {#custom-config-dir} | ||||
| 
 | ||||
| [Neovim 0.9]: https://github.com/neovim/neovim/pull/22128 | ||||
| 
 | ||||
| As of [Neovim 0.9], `$NVIM_APPNAME` is a variable expected by Neovim to decide | ||||
| on the configuration directory. nvf sets this variable as `"nvf"`, meaning | ||||
| `~/.config/nvf` will be regarded as _the_ configuration directory by Neovim, | ||||
| similar to how `~/.config/nvim` behaves in regular installations. This allows | ||||
| some degree[^1] of Lua configuration, backed by our low-level wrapper | ||||
| [mnw](https://github.com/Gerg-L/mnw). Creating a `lua/` directory located in | ||||
| `$NVIM_APPNAME` ("nvf" by default) and placing your configuration in, e.g., | ||||
| `~/.config/nvf/lua/myconfig` will allow you to `require` it as a part of the Lua | ||||
| module system through nvf's module system. | ||||
| 
 | ||||
| Let's assume your `~/.config/nvf/lua/myconfig/init.lua` consists of the | ||||
| following: | ||||
| 
 | ||||
| ```lua | ||||
| vim.keymap.set("n", " ", "<Nop>", { silent = true, remap = false }) | ||||
| vim.g.mapleader = " " | ||||
| ``` | ||||
| 
 | ||||
| The following Nix configuration via [](#opt-vim.luaConfigRC) will allow loading | ||||
| this | ||||
| 
 | ||||
| ```nix | ||||
| { | ||||
|   # The attribute name "myconfig-dir" here is arbitrary. It is required to be | ||||
|   # a *named* attribute by the DAG system, but the name is entirely up to you. | ||||
|   vim.luaConfigRC.myconfig-dir = '' | ||||
|     require("myconfig") | ||||
| 
 | ||||
|     -- Any additional Lua | ||||
|   ''; | ||||
| } | ||||
| ``` | ||||
| 
 | ||||
| [DAG system]: https://notashelf.github.io/nvf/index.xhtml#ch-using-dags | ||||
| 
 | ||||
| After you load your custom configuration, you may use an `init.lua` located in | ||||
| your custom configuration directory to configure Neovim exactly as you would | ||||
| without a wrapper like nvf. If you want to place your `require` call in a | ||||
| specific position (i.e., before or after options you set in nvf) the | ||||
| [DAG system] will let you place your configuration in a location of your | ||||
| choosing. | ||||
| 
 | ||||
| [top-level DAG system]: https://notashelf.github.io/nvf/index.xhtml#ch-vim-luaconfigrc | ||||
| 
 | ||||
| [^1]: You might sometimes face "overrides" set by nvf. Those should be very | ||||
|     rare, and almost always exclusive to `vim.globals` or `vim.options`. In such | ||||
|     a case, simply placing the `require` call for your configuration _after_ | ||||
|     `optionsScript` in the [top-level DAG system] will allow you to override | ||||
|     previous options. | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue