mirror of
https://github.com/NotAShelf/nvf.git
synced 2026-06-23 21:13:28 +00:00
Merge 577e11fe34 into 0b92b1783d
This commit is contained in:
commit
5067654346
11 changed files with 137 additions and 5 deletions
|
|
@ -381,6 +381,9 @@
|
||||||
- Added [Selenen](https://github.com/kampfkarren/selene) for more diagnostics in
|
- Added [Selenen](https://github.com/kampfkarren/selene) for more diagnostics in
|
||||||
`languages.lua`.
|
`languages.lua`.
|
||||||
|
|
||||||
|
- Added the [Stimulus LSP](https://github.com/marcoroth/stimulus-lsp) as LSP
|
||||||
|
preset.
|
||||||
|
|
||||||
- Added `languages.docker` for Docker and Docker-Compose support. Thanks to
|
- Added `languages.docker` for Docker and Docker-Compose support. Thanks to
|
||||||
[poseidon-rises](https://github.com/poseidon-rises) for creating most of it in
|
[poseidon-rises](https://github.com/poseidon-rises) for creating most of it in
|
||||||
[!1104](https://github.com/NotAShelf/nvf/pull/1104).
|
[!1104](https://github.com/NotAShelf/nvf/pull/1104).
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,15 @@
|
||||||
|
--- a/package.json
|
||||||
|
+++ b/package.json
|
||||||
|
@@ -13,3 +13,3 @@
|
||||||
|
"dependencies": {
|
||||||
|
- "@hotwired/stimulus": "https://github.com/hotwired/dev-builds/archive/refs/tags/@hotwired/stimulus/8cbca6d.tar.gz",
|
||||||
|
+ "@hotwired/stimulus": "file:./hotwired-stimulus.tar.gz",
|
||||||
|
"dedent": "^1.5.1",
|
||||||
|
--- a/yarn.lock
|
||||||
|
+++ b/yarn.lock
|
||||||
|
@@ -27,3 +27,3 @@
|
||||||
|
-"@hotwired/stimulus@https://github.com/hotwired/dev-builds/archive/refs/tags/@hotwired/stimulus/8cbca6d.tar.gz":
|
||||||
|
+"@hotwired/stimulus@file:./hotwired-stimulus.tar.gz":
|
||||||
|
version "3.2.2"
|
||||||
|
- resolved "https://github.com/hotwired/dev-builds/archive/refs/tags/@hotwired/stimulus/8cbca6d.tar.gz#bcca3015d4e1a7e6defad94db626e11dc97e69e5"
|
||||||
|
+ resolved "file:./hotwired-stimulus.tar.gz"
|
||||||
|
|
@ -0,0 +1,22 @@
|
||||||
|
--- a/package.json
|
||||||
|
+++ b/package.json
|
||||||
|
@@ -38,2 +38,3 @@
|
||||||
|
"devDependencies": {
|
||||||
|
+ "@types/node": "^20.0.0",
|
||||||
|
"@types/estree": "^1.0.5",
|
||||||
|
--- a/yarn.lock
|
||||||
|
+++ b/yarn.lock
|
||||||
|
@@ -307,4 +307,13 @@
|
||||||
|
vscode-uri@^3.1.0:
|
||||||
|
version "3.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/vscode-uri/-/vscode-uri-3.1.0.tgz#dd09ec5a66a38b5c3fffc774015713496d14e09c"
|
||||||
|
integrity sha512-/BpdSx+yCQGnCvecbyXdxHDkuk55/G3xwnC0GqY4gmQ3j+A+g8kzzgB4Nk/SINjqn6+waqw3EgbVF2QKExkRxQ==
|
||||||
|
+
|
||||||
|
+"@types/node@^20.0.0":
|
||||||
|
+ version "20.19.0"
|
||||||
|
+ resolved "https://registry.yarnpkg.com/@types/node/-/node-20.19.0.tgz#7006b097b15dfea06695c3bbdba98b268797f65b"
|
||||||
|
+
|
||||||
|
+undici-types@~6.19.2:
|
||||||
|
+ version "6.19.8"
|
||||||
|
+ resolved "https://registry.yarnpkg.com/undici-types/-/undici-types-6.19.8.tgz#35111c9d1437ab83a7cdc0abae2f26d88eda0a02"
|
||||||
|
+ integrity sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==
|
||||||
65
flake/pkgs/by-name/stimulus-language-server/package.nix
Normal file
65
flake/pkgs/by-name/stimulus-language-server/package.nix
Normal file
|
|
@ -0,0 +1,65 @@
|
||||||
|
{
|
||||||
|
lib,
|
||||||
|
stdenvNoCC,
|
||||||
|
fetchFromGitHub,
|
||||||
|
fetchYarnDeps,
|
||||||
|
fetchurl,
|
||||||
|
yarnConfigHook,
|
||||||
|
yarnBuildHook,
|
||||||
|
yarnInstallHook,
|
||||||
|
nodejs,
|
||||||
|
runCommand,
|
||||||
|
patch,
|
||||||
|
nix-update-script,
|
||||||
|
}: let
|
||||||
|
version = "1.1.0";
|
||||||
|
|
||||||
|
upstream = fetchFromGitHub {
|
||||||
|
owner = "marcoroth";
|
||||||
|
repo = "stimulus-lsp";
|
||||||
|
tag = "v${version}";
|
||||||
|
hash = "sha256-QAXQKZoFvqhnbAIi9fnJ7pV8fXah0NjwxdrqKB5e5Vw=";
|
||||||
|
};
|
||||||
|
|
||||||
|
# `fetchYarnDeps` doesn't support tarballs so we need to patch this manually
|
||||||
|
stimulusTarball = fetchurl {
|
||||||
|
url = "https://github.com/hotwired/dev-builds/archive/refs/tags/@hotwired/stimulus/8cbca6d.tar.gz";
|
||||||
|
hash = "sha256-2iRIiwXmdcSw7y3CQNIPt6duwZuVvDvdU/FEdqcnzW4=";
|
||||||
|
};
|
||||||
|
|
||||||
|
src = runCommand "stimulus-lsp-server-patched" {nativeBuildInputs = [patch];} ''
|
||||||
|
cp -r ${upstream}/server $out
|
||||||
|
chmod -R +w $out
|
||||||
|
cp '${stimulusTarball}' $out/hotwired-stimulus.tar.gz
|
||||||
|
patch -d $out -p1 < '${./0001-use-local-hotwired.patch}'
|
||||||
|
patch -d $out -p1 < '${./0002-add-types-node.patch}'
|
||||||
|
'';
|
||||||
|
in
|
||||||
|
stdenvNoCC.mkDerivation {
|
||||||
|
pname = "stimulus-language-server";
|
||||||
|
inherit version;
|
||||||
|
|
||||||
|
src = src;
|
||||||
|
|
||||||
|
offlineCache = fetchYarnDeps {
|
||||||
|
yarnLock = "${src}/yarn.lock";
|
||||||
|
hash = "sha256-UvojI/Ow602Q+iiwRpSgxm4DV0IJ0sURicdgghmpBsU=";
|
||||||
|
};
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
yarnConfigHook
|
||||||
|
yarnBuildHook
|
||||||
|
yarnInstallHook
|
||||||
|
nodejs
|
||||||
|
];
|
||||||
|
|
||||||
|
passthru.updateScript = nix-update-script {};
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "Intelligent Stimulus tooling";
|
||||||
|
homepage = "https://hotwire.io/ecosystem/tooling/stimulus-lsp";
|
||||||
|
changelog = "https://github.com/marcoroth/stimulus-lsp/releases/tag/v${version}";
|
||||||
|
license = lib.licenses.mit;
|
||||||
|
mainProgram = "stimulus-language-server";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
@ -18,7 +18,7 @@
|
||||||
cfg = config.vim.languages.html;
|
cfg = config.vim.languages.html;
|
||||||
|
|
||||||
defaultServers = ["superhtml"];
|
defaultServers = ["superhtml"];
|
||||||
servers = ["superhtml" "emmet-ls" "angular-language-server"];
|
servers = ["superhtml" "emmet-ls" "angular-language-server" "stimulus-language-server"];
|
||||||
|
|
||||||
defaultFormat = ["superhtml"];
|
defaultFormat = ["superhtml"];
|
||||||
formats = {
|
formats = {
|
||||||
|
|
|
||||||
|
|
@ -13,7 +13,7 @@
|
||||||
cfg = config.vim.languages.jinja;
|
cfg = config.vim.languages.jinja;
|
||||||
|
|
||||||
defaultServers = ["jinja-lsp"];
|
defaultServers = ["jinja-lsp"];
|
||||||
servers = ["jinja-lsp" "emmet-ls"];
|
servers = ["jinja-lsp" "emmet-ls" "stimulus-language-server"];
|
||||||
in {
|
in {
|
||||||
options.vim.languages.jinja = {
|
options.vim.languages.jinja = {
|
||||||
enable = mkEnableOption "Jinja template language support";
|
enable = mkEnableOption "Jinja template language support";
|
||||||
|
|
|
||||||
|
|
@ -16,7 +16,7 @@
|
||||||
cfg = config.vim.languages.ruby;
|
cfg = config.vim.languages.ruby;
|
||||||
|
|
||||||
defaultServers = ["solargraph"];
|
defaultServers = ["solargraph"];
|
||||||
servers = ["ruby-lsp" "solargraph"];
|
servers = ["ruby-lsp" "solargraph" "stimulus-language-server"];
|
||||||
|
|
||||||
# testing
|
# testing
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -13,7 +13,7 @@
|
||||||
cfg = config.vim.languages.tera;
|
cfg = config.vim.languages.tera;
|
||||||
|
|
||||||
defaultServers = [];
|
defaultServers = [];
|
||||||
servers = ["emmet-ls"];
|
servers = ["emmet-ls" "stimulus-language-server"];
|
||||||
in {
|
in {
|
||||||
options.vim.languages.tera = {
|
options.vim.languages.tera = {
|
||||||
enable = mkEnableOption "Tera templating language support";
|
enable = mkEnableOption "Tera templating language support";
|
||||||
|
|
|
||||||
|
|
@ -16,7 +16,7 @@
|
||||||
cfg = config.vim.languages.twig;
|
cfg = config.vim.languages.twig;
|
||||||
|
|
||||||
defaultServers = ["twig-language-server"];
|
defaultServers = ["twig-language-server"];
|
||||||
servers = ["twig-language-server" "emmet-ls"];
|
servers = ["twig-language-server" "emmet-ls" "stimulus-language-server"];
|
||||||
|
|
||||||
defaultFormat = ["djlint"];
|
defaultFormat = ["djlint"];
|
||||||
formats = {
|
formats = {
|
||||||
|
|
|
||||||
|
|
@ -61,6 +61,7 @@
|
||||||
./solargraph.nix
|
./solargraph.nix
|
||||||
./some-sass-language-server.nix
|
./some-sass-language-server.nix
|
||||||
./sqls.nix
|
./sqls.nix
|
||||||
|
./stimulus-language-server.nix
|
||||||
./superhtml.nix
|
./superhtml.nix
|
||||||
./svelte-language-server.nix
|
./svelte-language-server.nix
|
||||||
./tailwindcss-language-server.nix
|
./tailwindcss-language-server.nix
|
||||||
|
|
|
||||||
26
modules/plugins/lsp/presets/stimulus-language-server.nix
Normal file
26
modules/plugins/lsp/presets/stimulus-language-server.nix
Normal 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;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue