mirror of
				https://github.com/NotAShelf/nvf.git
				synced 2025-10-31 11:02:37 +00:00 
			
		
		
		
	Merge pull request #838 from Noah765/fix-flutter-tools
languages/dart: address hidden dependencies of flutter-tools.nvim
This commit is contained in:
		
				commit
				
					
						afca477b39
					
				
			
		
					 2 changed files with 26 additions and 13 deletions
				
			
		|  | @ -334,3 +334,5 @@ | ||||||
| [Noah765](https://github.com/Noah765): | [Noah765](https://github.com/Noah765): | ||||||
| 
 | 
 | ||||||
| - Add missing `flutter-tools.nvim` dependency `plenary.nvim`. | - Add missing `flutter-tools.nvim` dependency `plenary.nvim`. | ||||||
|  | - Add necessary dependency of `flutter-tools.nvim` on lsp. | ||||||
|  | - Add the `vim.languages.dart.flutter-tools.flutterPackage` option. | ||||||
|  |  | ||||||
|  | @ -13,7 +13,7 @@ | ||||||
|   inherit (lib.strings) optionalString; |   inherit (lib.strings) optionalString; | ||||||
|   inherit (lib.nvim.lua) expToLua; |   inherit (lib.nvim.lua) expToLua; | ||||||
|   inherit (lib.nvim.types) mkGrammarOption; |   inherit (lib.nvim.types) mkGrammarOption; | ||||||
|   inherit (lib.nvim.dag) entryAnywhere; |   inherit (lib.nvim.dag) entryAfter; | ||||||
| 
 | 
 | ||||||
|   cfg = config.vim.languages.dart; |   cfg = config.vim.languages.dart; | ||||||
|   ftcfg = cfg.flutter-tools; |   ftcfg = cfg.flutter-tools; | ||||||
|  | @ -81,16 +81,25 @@ in { | ||||||
|         description = "Enable flutter-tools for flutter support"; |         description = "Enable flutter-tools for flutter support"; | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|  |       flutterPackage = mkOption { | ||||||
|  |         type = nullOr package; | ||||||
|  |         default = pkgs.flutter; | ||||||
|  |         description = "Flutter package, or null to detect the flutter path at runtime instead."; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|       enableNoResolvePatch = mkOption { |       enableNoResolvePatch = mkOption { | ||||||
|         type = bool; |         type = bool; | ||||||
|         default = true; |         default = false; | ||||||
|         description = '' |         description = '' | ||||||
|           Whether to patch flutter-tools so that it doesn't resolve |           Whether to patch flutter-tools so that it doesn't resolve | ||||||
|           symlinks when detecting flutter path. |           symlinks when detecting flutter path. | ||||||
| 
 | 
 | ||||||
|           This is required if you want to use a flutter package built with nix. |           ::: {.note} | ||||||
|           If you are using a flutter SDK installed from a different source |           This is required if `flutterPackage` is set to null and the flutter | ||||||
|           and encounter the error "`dart` missing from PATH", disable this option. |           package in your `PATH` was built with Nix. If you are using a flutter | ||||||
|  |           SDK installed from a different source and encounter the error "`dart` | ||||||
|  |           missing from `PATH`", leave this option disabled. | ||||||
|  |           ::: | ||||||
|         ''; |         ''; | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|  | @ -122,19 +131,21 @@ in { | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   config = mkIf cfg.enable (mkMerge [ |   config.vim = mkIf cfg.enable (mkMerge [ | ||||||
|     (mkIf cfg.treesitter.enable { |     (mkIf cfg.treesitter.enable { | ||||||
|       vim.treesitter.enable = true; |       treesitter.enable = true; | ||||||
|       vim.treesitter.grammars = [cfg.treesitter.package]; |       treesitter.grammars = [cfg.treesitter.package]; | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     (mkIf cfg.lsp.enable { |     (mkIf cfg.lsp.enable { | ||||||
|       vim.lsp.lspconfig.enable = true; |       lsp.lspconfig.enable = true; | ||||||
|       vim.lsp.lspconfig.sources.dart-lsp = servers.${cfg.lsp.server}.lspConfig; |       lsp.lspconfig.sources.dart-lsp = servers.${cfg.lsp.server}.lspConfig; | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     (mkIf ftcfg.enable { |     (mkIf ftcfg.enable { | ||||||
|       vim.startPlugins = [ |       lsp.enable = true; | ||||||
|  | 
 | ||||||
|  |       startPlugins = [ | ||||||
|         ( |         ( | ||||||
|           if ftcfg.enableNoResolvePatch |           if ftcfg.enableNoResolvePatch | ||||||
|           then "flutter-tools-patched" |           then "flutter-tools-patched" | ||||||
|  | @ -143,8 +154,9 @@ in { | ||||||
|         "plenary-nvim" |         "plenary-nvim" | ||||||
|       ]; |       ]; | ||||||
| 
 | 
 | ||||||
|       vim.pluginRC.flutter-tools = entryAnywhere '' |       pluginRC.flutter-tools = entryAfter ["lsp-setup"] '' | ||||||
|         require('flutter-tools').setup { |         require('flutter-tools').setup { | ||||||
|  |           ${optionalString (ftcfg.flutterPackage != null) "flutter_path = \"${ftcfg.flutterPackage}/bin/flutter\","} | ||||||
|           lsp = { |           lsp = { | ||||||
|             color = { -- show the derived colours for dart variables |             color = { -- show the derived colours for dart variables | ||||||
|               enabled = ${boolToString ftcfg.color.enable}, -- whether or not to highlight color variables at all, only supported on flutter >= 2.10 |               enabled = ${boolToString ftcfg.color.enable}, -- whether or not to highlight color variables at all, only supported on flutter >= 2.10 | ||||||
|  | @ -156,7 +168,6 @@ in { | ||||||
| 
 | 
 | ||||||
|             capabilities = capabilities, |             capabilities = capabilities, | ||||||
|             on_attach = default_on_attach; |             on_attach = default_on_attach; | ||||||
|             flags = lsp_flags, |  | ||||||
|           }, |           }, | ||||||
|           ${optionalString cfg.dap.enable '' |           ${optionalString cfg.dap.enable '' | ||||||
|           debugger = { |           debugger = { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 raf
				raf