add groovyls

This commit is contained in:
2023-06-06 16:32:00 +03:00
parent c69eab6ba9
commit 3dddf844ce
6 changed files with 95 additions and 8 deletions

71
flake.lock generated
View File

@@ -18,7 +18,60 @@
"type": "github" "type": "github"
} }
}, },
"flake-utils_2": {
"inputs": {
"systems": "systems_2"
},
"locked": {
"lastModified": 1685518550,
"narHash": "sha256-o2d0KcvaXzTrPRIo0kOLV0/QXHhDQ5DTi+OxcjO8xqY=",
"owner": "numtide",
"repo": "flake-utils",
"rev": "a1720a10a6cfe8234c0e93907ffe81be440f4cef",
"type": "github"
},
"original": {
"owner": "numtide",
"repo": "flake-utils",
"type": "github"
}
},
"groovyls": {
"inputs": {
"flake-utils": "flake-utils_2",
"nixpkgs": "nixpkgs"
},
"locked": {
"lastModified": 1686055585,
"narHash": "sha256-e+hjiIvQZ6Dmow7cJlGTS0LmJh8vNRhyU/HDHPOIqi0=",
"owner": "miknikif",
"repo": "groovyls",
"rev": "cb877e243f5b3c2e725ac2d50a6f70c184161d4a",
"type": "github"
},
"original": {
"owner": "miknikif",
"repo": "groovyls",
"type": "github"
}
},
"nixpkgs": { "nixpkgs": {
"locked": {
"lastModified": 1686043861,
"narHash": "sha256-duF1U12b7vVkf2Lt6noPYVeW8dVFw4CwJmQivhyZxYQ=",
"owner": "nixos",
"repo": "nixpkgs",
"rev": "96f8f4a038a190f7511da79ef7e77bec5e4b811a",
"type": "github"
},
"original": {
"owner": "nixos",
"ref": "release-23.05",
"repo": "nixpkgs",
"type": "github"
}
},
"nixpkgs_2": {
"locked": { "locked": {
"lastModified": 1685539144, "lastModified": 1685539144,
"narHash": "sha256-BvIghafqDrQqWSbnWuDVLD6fiPWRE/foLWSupFM+Hho=", "narHash": "sha256-BvIghafqDrQqWSbnWuDVLD6fiPWRE/foLWSupFM+Hho=",
@@ -37,7 +90,8 @@
"root": { "root": {
"inputs": { "inputs": {
"flake-utils": "flake-utils", "flake-utils": "flake-utils",
"nixpkgs": "nixpkgs" "groovyls": "groovyls",
"nixpkgs": "nixpkgs_2"
} }
}, },
"systems": { "systems": {
@@ -54,6 +108,21 @@
"repo": "default", "repo": "default",
"type": "github" "type": "github"
} }
},
"systems_2": {
"locked": {
"lastModified": 1681028828,
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
"owner": "nix-systems",
"repo": "default",
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
"type": "github"
},
"original": {
"owner": "nix-systems",
"repo": "default",
"type": "github"
}
} }
}, },
"root": "root", "root": "root",

View File

@@ -3,16 +3,24 @@
inputs = { inputs = {
nixpkgs.url = "github:nixos/nixpkgs/release-23.05"; nixpkgs.url = "github:nixos/nixpkgs/release-23.05";
flake-utils.url = "github:numtide/flake-utils"; flake-utils.url = "github:numtide/flake-utils";
groovyls.url = "github:miknikif/groovyls";
}; };
outputs = inputs @ { outputs = inputs @ {
self, self,
nixpkgs, nixpkgs,
flake-utils, flake-utils,
groovyls,
... ...
}: }:
flake-utils.lib.eachDefaultSystem (system: let flake-utils.lib.eachDefaultSystem (system: let
pkgs = import nixpkgs { pkgs = import nixpkgs {
inherit system; inherit system;
inherit
(import ./overlays.nix {
inherit inputs;
})
overlays
;
}; };
recursiveMerge = attrList: let recursiveMerge = attrList: let
@@ -51,6 +59,7 @@
vale # linter for prose vale # linter for prose
jdk # for groovy jdk # for groovy
groovy groovy
groovyls # groovy lsp
]; ];
neovim-augmented = recursiveMerge [ neovim-augmented = recursiveMerge [
pkgs.neovim-unwrapped pkgs.neovim-unwrapped
@@ -70,6 +79,7 @@
'' ''
lua << EOF lua << EOF
package.path = "${self}/?.lua;" .. package.path package.path = "${self}/?.lua;" .. package.path
groovyls_cmd = { "${pkgs.jdk}/bin/java", "-jar", "${pkgs.groovyls}/groovyls-all.jar" }
'' ''
+ pkgs.lib.readFile ./init.lua + pkgs.lib.readFile ./init.lua
+ '' + ''

View File

@@ -12,7 +12,7 @@ require('pwnvim.options').gui()
require('pwnvim.mappings') require('pwnvim.mappings')
require('pwnvim.abbreviations') require('pwnvim.abbreviations')
require('pwnvim.plugins').ui() require('pwnvim.plugins').ui()
require('pwnvim.plugins').diagnostics() require('pwnvim.plugins').diagnostics(groovyls_cmd) -- groovyls_cmd is dynamically created by nix
require('pwnvim.plugins').telescope() require('pwnvim.plugins').telescope()
require('pwnvim.plugins').completions() require('pwnvim.plugins').completions()
require('pwnvim.plugins').notes() require('pwnvim.plugins').notes()

7
overlays.nix Normal file
View File

@@ -0,0 +1,7 @@
{inputs, ...}: {
overlays = [
(final: prev: {
inherit (inputs.groovyls.packages.${final.system}) groovyls;
})
];
}

View File

@@ -36,7 +36,7 @@ M.config = function()
autocmd("FileType", autocmd("FileType",
{ {
pattern = { "c", "ruby", "php", "php3", "perl", "python", "mason", "vim", "sh", "zsh", "scala", "javascript", pattern = { "c", "ruby", "php", "php3", "perl", "python", "mason", "vim", "sh", "zsh", "scala", "javascript",
"javascriptreact", "typescript", "typescriptreact", "html", "svelte", "css", "nix", "terraform" }, "javascriptreact", "typescript", "typescriptreact", "html", "svelte", "css", "nix", "terraform", "groovy", "java" },
callback = function() require('pwnvim.options').programming() end, callback = function() require('pwnvim.options').programming() end,
group = filetypes group = filetypes
}) })

View File

@@ -34,7 +34,7 @@ M.ui = function()
end -- UI setup end -- UI setup
----------------------- DIAGNOSTICS -------------------------------- ----------------------- DIAGNOSTICS --------------------------------
M.diagnostics = function() M.diagnostics = function(groovyls_cmd)
-- IMPORTANT: make sure to setup neodev BEFORE lspconfig -- IMPORTANT: make sure to setup neodev BEFORE lspconfig
require("neodev").setup({ require("neodev").setup({
-- help for neovim lua api -- help for neovim lua api
@@ -258,7 +258,8 @@ M.diagnostics = function()
codeactions.eslint_d, codeactions.gitsigns, codeactions.statix, -- for nix codeactions.eslint_d, codeactions.gitsigns, codeactions.statix, -- for nix
diagnostics.statix, -- for nix diagnostics.statix, -- for nix
null_ls.builtins.hover.dictionary, codeactions.shellcheck, null_ls.builtins.hover.dictionary, codeactions.shellcheck,
diagnostics.shellcheck diagnostics.shellcheck,
diagnostics.npm_groovy_lint
-- removed formatting.rustfmt since rust_analyzer seems to do the same thing -- removed formatting.rustfmt since rust_analyzer seems to do the same thing
}, },
on_attach = attached on_attach = attached
@@ -352,7 +353,7 @@ M.diagnostics = function()
} }
lspconfig.terraformls.setup { on_attach = attached, capabilities = capabilities } -- terraform lsp lspconfig.terraformls.setup { on_attach = attached, capabilities = capabilities } -- terraform lsp
lspconfig.tflint.setup { on_attach = attached, capabilities = capabilities } -- terraform lsp lspconfig.tflint.setup { on_attach = attached, capabilities = capabilities } -- terraform lsp
lspconfig.groovyls.setup { on_attach = attached, capabilities = capabilities } -- groovy lsp lspconfig.groovyls.setup { on_attach = attached, capabilities = capabilities, cmd = groovyls_cmd } -- groovy lsp
require 'lspsaga'.init_lsp_saga({ require 'lspsaga'.init_lsp_saga({
use_saga_diagnostic_sign = not SimpleUI, use_saga_diagnostic_sign = not SimpleUI,