mirror of
				https://github.com/NotAShelf/nvf.git
				synced 2025-10-31 02:52:37 +00:00 
			
		
		
		
	Merge branch 'v0.8' into v0.8
This commit is contained in:
		
				commit
				
					
						085d161ca9
					
				
			
		
					 55 changed files with 1652 additions and 732 deletions
				
			
		|  | @ -30,6 +30,7 @@ in { | |||
|     ./ocaml.nix | ||||
|     ./php.nix | ||||
|     ./python.nix | ||||
|     ./qml.nix | ||||
|     ./r.nix | ||||
|     ./rust.nix | ||||
|     ./scala.nix | ||||
|  |  | |||
|  | @ -4,14 +4,44 @@ | |||
|   lib, | ||||
|   ... | ||||
| }: let | ||||
|   inherit (builtins) attrNames; | ||||
|   inherit (lib.meta) getExe; | ||||
|   inherit (lib.options) mkEnableOption mkOption; | ||||
|   inherit (lib.modules) mkIf mkMerge; | ||||
|   inherit (lib.types) bool; | ||||
|   inherit (lib.types) bool enum package; | ||||
|   inherit (lib.lists) optional; | ||||
|   inherit (lib.nvim.types) mkGrammarOption; | ||||
|   inherit (lib.nvim.types) mkGrammarOption diagnostics singleOrListOf; | ||||
|   inherit (lib.nvim.dag) entryAnywhere; | ||||
|   inherit (lib.nvim.attrsets) mapListToAttrs; | ||||
| 
 | ||||
|   cfg = config.vim.languages.html; | ||||
| 
 | ||||
|   defaultServers = ["superhtml"]; | ||||
|   servers = { | ||||
|     superhtml = { | ||||
|       cmd = [(getExe pkgs.superhtml) "lsp"]; | ||||
|       filetypes = ["html" "shtml" "htm"]; | ||||
|       root_markers = ["index.html" ".git"]; | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|   defaultFormat = "superhtml"; | ||||
|   formats = { | ||||
|     superhtml = { | ||||
|       package = pkgs.writeShellApplication { | ||||
|         name = "superhtml_fmt"; | ||||
|         runtimeInputs = [pkgs.superhtml]; | ||||
|         text = "superhtml fmt -"; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|   defaultDiagnosticsProvider = ["htmlhint"]; | ||||
|   diagnosticsProviders = { | ||||
|     htmlhint = { | ||||
|       config.cmd = getExe pkgs.htmlhint; | ||||
|     }; | ||||
|   }; | ||||
| in { | ||||
|   options.vim.languages.html = { | ||||
|     enable = mkEnableOption "HTML language support"; | ||||
|  | @ -19,9 +49,44 @@ in { | |||
|       enable = mkEnableOption "HTML treesitter support" // {default = config.vim.languages.enableTreesitter;}; | ||||
|       package = mkGrammarOption pkgs "html"; | ||||
|       autotagHtml = mkOption { | ||||
|         description = "Enable autoclose/autorename of html tags (nvim-ts-autotag)"; | ||||
|         type = bool; | ||||
|         default = true; | ||||
|         description = "Enable autoclose/autorename of html tags (nvim-ts-autotag)"; | ||||
|       }; | ||||
|     }; | ||||
| 
 | ||||
|     lsp = { | ||||
|       enable = mkEnableOption "HTML LSP support" // {default = config.vim.lsp.enable;}; | ||||
|       servers = mkOption { | ||||
|         type = singleOrListOf (enum (attrNames servers)); | ||||
|         default = defaultServers; | ||||
|         description = "HTML LSP server to use"; | ||||
|       }; | ||||
|     }; | ||||
| 
 | ||||
|     format = { | ||||
|       enable = mkEnableOption "HTML formatting" // {default = config.vim.languages.enableFormat;}; | ||||
| 
 | ||||
|       type = mkOption { | ||||
|         type = enum (attrNames formats); | ||||
|         default = defaultFormat; | ||||
|         description = "HTML formatter to use"; | ||||
|       }; | ||||
| 
 | ||||
|       package = mkOption { | ||||
|         type = package; | ||||
|         default = formats.${cfg.format.type}.package; | ||||
|         description = "HTML formatter package"; | ||||
|       }; | ||||
|     }; | ||||
| 
 | ||||
|     extraDiagnostics = { | ||||
|       enable = mkEnableOption "extra HTML diagnostics" // {default = config.vim.languages.enableExtraDiagnostics;}; | ||||
| 
 | ||||
|       types = diagnostics { | ||||
|         langDesc = "HTML"; | ||||
|         inherit diagnosticsProviders; | ||||
|         inherit defaultDiagnosticsProvider; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
|  | @ -41,5 +106,35 @@ in { | |||
|         ''); | ||||
|       }; | ||||
|     }) | ||||
| 
 | ||||
|     (mkIf cfg.lsp.enable { | ||||
|       vim.lsp.servers = | ||||
|         mapListToAttrs (n: { | ||||
|           name = n; | ||||
|           value = servers.${n}; | ||||
|         }) | ||||
|         cfg.lsp.servers; | ||||
|     }) | ||||
| 
 | ||||
|     (mkIf (cfg.format.enable && !cfg.lsp.enable) { | ||||
|       vim.formatter.conform-nvim = { | ||||
|         enable = true; | ||||
|         setupOpts.formatters_by_ft.html = [cfg.format.type]; | ||||
|         setupOpts.formatters.${cfg.format.type} = { | ||||
|           command = getExe cfg.format.package; | ||||
|         }; | ||||
|       }; | ||||
|     }) | ||||
| 
 | ||||
|     (mkIf cfg.extraDiagnostics.enable { | ||||
|       vim.diagnostics.nvim-lint = { | ||||
|         enable = true; | ||||
|         linters_by_ft.html = cfg.extraDiagnostics.types; | ||||
|         linters = mkMerge (map (name: { | ||||
|             ${name} = diagnosticsProviders.${name}.config; | ||||
|           }) | ||||
|           cfg.extraDiagnostics.types); | ||||
|       }; | ||||
|     }) | ||||
|   ]); | ||||
| } | ||||
|  |  | |||
							
								
								
									
										98
									
								
								modules/plugins/languages/qml.nix
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								modules/plugins/languages/qml.nix
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,98 @@ | |||
| { | ||||
|   config, | ||||
|   pkgs, | ||||
|   lib, | ||||
|   ... | ||||
| }: let | ||||
|   inherit (builtins) attrNames; | ||||
|   inherit (lib.meta) getExe getExe'; | ||||
|   inherit (lib.options) mkEnableOption mkOption; | ||||
|   inherit (lib.modules) mkIf mkMerge; | ||||
|   inherit (lib.types) enum package; | ||||
|   inherit (lib.nvim.types) mkGrammarOption singleOrListOf; | ||||
|   inherit (lib.nvim.attrsets) mapListToAttrs; | ||||
| 
 | ||||
|   cfg = config.vim.languages.qml; | ||||
| 
 | ||||
|   qmlPackage = pkgs.kdePackages.qtdeclarative; | ||||
| 
 | ||||
|   defaultServers = ["qmlls"]; | ||||
|   servers = { | ||||
|     qmlls = { | ||||
|       cmd = [(getExe' qmlPackage "qmlls")]; | ||||
|       filetypes = ["qml" "qmljs"]; | ||||
|       rootmarkers = [".git"]; | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|   defaultFormat = "qmlformat"; | ||||
|   formats = { | ||||
|     qmlformat = { | ||||
|       package = pkgs.writeShellApplication { | ||||
|         name = "qmlformat"; | ||||
|         runtimeInputs = [qmlPackage]; | ||||
|         text = "qmlformat -"; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
| in { | ||||
|   options.vim.languages.qml = { | ||||
|     enable = mkEnableOption "QML language support"; | ||||
|     treesitter = { | ||||
|       enable = mkEnableOption "QML treesitter support" // {default = config.vim.languages.enableTreesitter;}; | ||||
|       package = mkGrammarOption pkgs "qmljs"; | ||||
|     }; | ||||
| 
 | ||||
|     lsp = { | ||||
|       enable = mkEnableOption "QML LSP support" // {default = config.vim.lsp.enable;}; | ||||
|       servers = mkOption { | ||||
|         type = singleOrListOf (enum (attrNames servers)); | ||||
|         default = defaultServers; | ||||
|         description = "QML LSP server to use"; | ||||
|       }; | ||||
|     }; | ||||
| 
 | ||||
|     format = { | ||||
|       enable = mkEnableOption "QML formatting" // {default = config.vim.languages.enableFormat;}; | ||||
| 
 | ||||
|       type = mkOption { | ||||
|         type = enum (attrNames formats); | ||||
|         default = defaultFormat; | ||||
|         description = "QML formatter to use"; | ||||
|       }; | ||||
| 
 | ||||
|       package = mkOption { | ||||
|         type = package; | ||||
|         default = formats.${cfg.format.type}.package; | ||||
|         description = "QML formatter package"; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|   config = mkIf cfg.enable (mkMerge [ | ||||
|     (mkIf cfg.treesitter.enable { | ||||
|       vim.treesitter = { | ||||
|         enable = true; | ||||
|         grammars = [cfg.treesitter.package]; | ||||
|       }; | ||||
|     }) | ||||
|     (mkIf cfg.lsp.enable { | ||||
|       vim.lsp.servers = | ||||
|         mapListToAttrs (n: { | ||||
|           name = n; | ||||
|           value = servers.${n}; | ||||
|         }) | ||||
|         cfg.lsp.servers; | ||||
|     }) | ||||
| 
 | ||||
|     (mkIf (cfg.format.enable && !cfg.lsp.enable) { | ||||
|       vim.formatter.conform-nvim = { | ||||
|         enable = true; | ||||
|         setupOpts.formatters_by_ft.qml = [cfg.format.type]; | ||||
|         setupOpts.formatters.${cfg.format.type} = { | ||||
|           command = getExe cfg.format.package; | ||||
|         }; | ||||
|       }; | ||||
|     }) | ||||
|   ]); | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 GitHub
					GitHub