From 1e3d8e19b0e0aa8a50dcab09d4ba0f3351273ca5 Mon Sep 17 00:00:00 2001 From: Soliprem Date: Fri, 27 Sep 2024 18:14:03 +0200 Subject: [PATCH] kotlin: LSP and treesitter --- configuration.nix | 1 + modules/plugins/languages/default.nix | 1 + modules/plugins/languages/haskell.nix | 4 +- modules/plugins/languages/kotlin.nix | 55 +++++++++++++++++++++++++++ 4 files changed, 59 insertions(+), 2 deletions(-) create mode 100644 modules/plugins/languages/kotlin.nix diff --git a/configuration.nix b/configuration.nix index 36db2721..7ee86137 100644 --- a/configuration.nix +++ b/configuration.nix @@ -51,6 +51,7 @@ isMaximal: { css.enable = isMaximal; sql.enable = isMaximal; java.enable = isMaximal; + kotlin.enable = isMaximal; ts.enable = isMaximal; svelte.enable = isMaximal; go.enable = isMaximal; diff --git a/modules/plugins/languages/default.nix b/modules/plugins/languages/default.nix index 024c65a5..6d12e08b 100644 --- a/modules/plugins/languages/default.nix +++ b/modules/plugins/languages/default.nix @@ -9,6 +9,7 @@ in { ./elixir.nix ./go.nix ./haskell.nix + ./kotlin.nix ./html.nix ./java.nix ./lua.nix diff --git a/modules/plugins/languages/haskell.nix b/modules/plugins/languages/haskell.nix index b2df406e..d2440f3f 100644 --- a/modules/plugins/languages/haskell.nix +++ b/modules/plugins/languages/haskell.nix @@ -20,7 +20,7 @@ in { }; lsp = { - enable = mkEnableOption "Haskell LSP support (haskell-language-server)" // {default = config.vim.languages.enableLSP;}; + enable = mkEnableOption "Haskell LSP support (haskell-language-server)" // {default = true;}; package = mkOption { description = "haskell_ls package"; @@ -41,7 +41,7 @@ in { lspconfig.haskell_ls.setup { capabilities = capabilities, on_attach=default_on_attach, - cmd = "${cfg.lsp.package}/bin/haskell-language-server-wrapper", + cmd = "${cfg.lsp.package}/bin/haskell-language-server", } ''; }) diff --git a/modules/plugins/languages/kotlin.nix b/modules/plugins/languages/kotlin.nix new file mode 100644 index 00000000..14023e57 --- /dev/null +++ b/modules/plugins/languages/kotlin.nix @@ -0,0 +1,55 @@ +{ + config, + pkgs, + lib, + ... +}: let + inherit (lib.options) mkEnableOption mkOption; + inherit (lib.modules) mkIf mkMerge; + inherit (lib.types) package; + inherit (lib.nvim.types) mkGrammarOption; + inherit (lib.lists) isList; + inherit (lib.nvim.lua) expToLua; + + cfg = config.vim.languages.kotlin; +in { + options.vim.languages.kotlin = { + enable = mkEnableOption "kotlin/HCL support"; + + treesitter = { + enable = mkEnableOption "kotlin treesitter" // {default = config.vim.languages.enableTreesitter;}; + package = mkGrammarOption pkgs "kotlin"; + }; + + lsp = { + enable = mkEnableOption "kotlin LSP support (kotlin-ls)" // {default = config.vim.languages.enableLSP;}; + + package = mkOption { + description = "kotlin-ls package"; + type = package; + default = pkgs.kotlin-language-server; + }; + }; + }; + config = mkIf cfg.enable (mkMerge [ + (mkIf cfg.treesitter.enable { + vim.treesitter.enable = true; + vim.treesitter.grammars = [cfg.treesitter.package]; + }) + + (mkIf cfg.lsp.enable { + vim.lsp.lspconfig.enable = true; + vim.lsp.lspconfig.sources.kotlin-ls = '' + lspconfig.kotlinls.setup { + capabilities = capabilities, + on_attach=default_on_attach, + cmd = ${ + if isList cfg.lsp.package + then expToLua cfg.lsp.package + else ''{"${cfg.lsp.package}/bin/kotlin-language-server"}'' + }, + } + ''; + }) + ]); +}