Merge branch 'main' into deprecate-jump

This commit is contained in:
raf 2026-06-12 14:23:42 +03:00 committed by GitHub
commit 35c31515b8
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
22 changed files with 577 additions and 76 deletions

View file

@ -117,6 +117,9 @@ in {
vim.treesitter = {
enable = true;
grammars = [cfg.treesitter.package];
filetypeMappings = {
yaml = ["dockercompose"];
};
};
})

View file

@ -205,7 +205,7 @@ in {
dap = {
enable =
mkEnableOption "Go Debug Adapter (DAP) via `nvim-dap-go"
mkEnableOption "Go Debug Adapter"
// {
default = config.vim.languages.enableDAP;
defaultText = literalExpression "config.vim.languages.enableDAP";

View file

@ -18,7 +18,7 @@
cfg = config.vim.languages.html;
defaultServers = ["superhtml"];
servers = ["superhtml" "emmet-ls" "angular-language-server"];
servers = ["superhtml" "emmet-ls" "angular-language-server" "stimulus-language-server"];
defaultFormat = ["superhtml"];
formats = {

View file

@ -2,19 +2,45 @@
config,
pkgs,
lib,
inputs,
...
}: let
inherit (lib.options) literalExpression mkEnableOption mkOption;
inherit (lib.modules) mkIf mkMerge;
inherit (lib) genAttrs;
inherit (lib.types) listOf str;
inherit (lib.meta) getExe;
inherit (lib.options) literalExpression mkEnableOption mkOption;
inherit (lib.types) listOf str enum package;
inherit (lib.attrsets) attrNames genAttrs;
inherit (lib.meta) getExe getExe';
inherit (lib.nvim.types) mkGrammarOption mkPluginSetupOption enumWithRename;
cfg = config.vim.languages.java;
defaultServers = ["jdt-language-server"];
servers = ["jdt-language-server"];
servers = ["jdt-language-server" "jls"];
defaultDebugger = "jls";
debuggers = {
jls = let
pkg = inputs.self.packages.${pkgs.stdenv.hostPlatform.system}.jls;
in {
package = pkg;
config = ''
dap.adapters.jls= {
type = 'executable',
command = '${getExe' pkg "jls-dap"}',
}
dap.configurations.java = {
{
type = "jls",
request = "attach",
name = "Attach",
hostName = "localhost",
port = 5005,
sourceRoots = vim.fn.glob("**/src/main/java", true, true),
},
}
'';
};
};
in {
options.vim.languages.java = {
enable = mkEnableOption "Java language support";
@ -48,6 +74,72 @@ in {
};
};
dap = {
enable =
mkEnableOption "Java Debug Adapter"
// {
default = config.vim.languages.enableDAP;
defaultText = literalExpression "config.vim.languages.enableDAP";
};
debugger = mkOption {
type = enum (attrNames debuggers);
default = defaultDebugger;
description = ''
Java debugger to use.
**JLS**
For `jls` to work, you need to run your application with debug symbols and networking.
The `jls` configuration is hardcoded to listen on port `5005`.
This matches the configuration described [upstream](https://github.com/idelice/jls#usage).
You can change this by modifying `vim.debugger.nvim-dap.sources.java-debugger`.
```nix
vim.debugger.nvim-dap.sources.java-debugger = /* lua */ '''
dap.adapters.jls= {
type = 'executable',
command = ''\'''${getExe' inputs.self.packages.''${pkgs.stdenv.hostPlatform.system}.jls "jls-dap"}',
}
dap.configurations.java = {
{
type = "jls",
request = "attach",
name = "Attach",
hostName = "localhost",
port = 6969, -- your custom port
sourceRoots = vim.fn.glob("**/src/main/java", true, true),
},
}
''';
```
*Examples:*
- Manual:
1. Build with debug symbols.
```sh
javac -g ...
```
1. Run with debug socket.
```sh
java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=*:5005 -jar your.jar
```
- Springboot Maven:
For Springboot you can just pass the JVM args directly into the `spring-boot:run`.
```sh
mvn spring-boot:run -Dspring-boot.run.jvmArguments="-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=*:5005"
```
'';
};
package = mkOption {
type = package;
default = debuggers.${cfg.dap.debugger}.package;
description = "Java debugger package.";
};
};
extensions = {
maven-nvim = {
enable = mkEnableOption "maven integration";
@ -88,6 +180,11 @@ in {
};
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 = {
presets = genAttrs cfg.lsp.servers (_: {enable = true;});
@ -97,9 +194,11 @@ in {
};
})
(mkIf cfg.treesitter.enable {
vim.treesitter.enable = true;
vim.treesitter.grammars = [cfg.treesitter.package];
(mkIf cfg.dap.enable {
vim.debugger.nvim-dap = {
enable = true;
sources.java-debugger = debuggers.${cfg.dap.debugger}.config;
};
})
(mkIf cfg.extensions.maven-nvim.enable {

View file

@ -13,7 +13,7 @@
cfg = config.vim.languages.jinja;
defaultServers = ["jinja-lsp"];
servers = ["jinja-lsp" "emmet-ls"];
servers = ["jinja-lsp" "emmet-ls" "stimulus-language-server"];
in {
options.vim.languages.jinja = {
enable = mkEnableOption "Jinja template language support";

View file

@ -16,7 +16,7 @@
cfg = config.vim.languages.ruby;
defaultServers = ["solargraph"];
servers = ["ruby-lsp" "solargraph"];
servers = ["ruby-lsp" "solargraph" "stimulus-language-server"];
# testing

View file

@ -13,7 +13,7 @@
cfg = config.vim.languages.tera;
defaultServers = [];
servers = ["emmet-ls"];
servers = ["emmet-ls" "stimulus-language-server"];
in {
options.vim.languages.tera = {
enable = mkEnableOption "Tera templating language support";

View file

@ -16,7 +16,7 @@
cfg = config.vim.languages.twig;
defaultServers = ["twig-language-server"];
servers = ["twig-language-server" "emmet-ls"];
servers = ["twig-language-server" "emmet-ls" "stimulus-language-server"];
defaultFormat = ["djlint"];
formats = {

View file

@ -28,6 +28,7 @@
./intelephense.nix
./jdt-language-server.nix
./jinja-lsp.nix
./jls.nix
./jq-lsp.nix
./julia-languageserver.nix
./just-lsp.nix
@ -61,6 +62,7 @@
./solargraph.nix
./some-sass-language-server.nix
./sqls.nix
./stimulus-language-server.nix
./superhtml.nix
./svelte-language-server.nix
./tailwindcss-language-server.nix

View file

@ -0,0 +1,34 @@
{
config,
lib,
pkgs,
inputs,
...
}: let
inherit (lib.meta) getExe;
inherit (lib.modules) mkIf;
inherit (lib.nvim.types) mkLspPresetEnableOption;
cfg = config.vim.lsp.presets.jls;
in {
options.vim.lsp.presets.jls = {
enable = mkLspPresetEnableOption "jls" "NeoVim Java" [];
};
config = mkIf cfg.enable {
vim.lsp.servers.jls = {
enable = true;
cmd = [(getExe inputs.self.packages.${pkgs.stdenv.hostPlatform.system}.jls)];
root_markers = [
".git"
".java-version"
"pom.xml"
"build.xml"
"build.gradle"
"build.gradle.kts"
"settings.gradle"
"settings.gradle.kts"
];
};
};
}

View file

@ -0,0 +1,26 @@
{
config,
lib,
pkgs,
inputs,
...
}: let
inherit (lib.meta) getExe;
inherit (lib.modules) mkIf;
inherit (lib.nvim.types) mkLspPresetEnableOption;
cfg = config.vim.lsp.presets.stimulus-language-server;
in {
options.vim.lsp.presets.stimulus-language-server = {
enable = mkLspPresetEnableOption "stimulus-language-server" "Stimulus" [];
};
config = mkIf cfg.enable {
vim.lsp.servers.stimulus-language-server = {
enable = true;
cmd = [(getExe inputs.self.packages.${pkgs.stdenv.hostPlatform.system}.stimulus-language-server) "--stdio"];
root_markers = [".git"];
workspace_required = true;
};
};
}