haskell-language-server: Fix build for 1.9.0.0
This commit is contained in:
parent
e3134c8180
commit
aaf6118fd5
5 changed files with 42 additions and 16 deletions
|
@ -1358,7 +1358,9 @@ self: super: {
|
||||||
haskell-language-server = (lib.pipe super.haskell-language-server [
|
haskell-language-server = (lib.pipe super.haskell-language-server [
|
||||||
dontCheck
|
dontCheck
|
||||||
(disableCabalFlag "stan") # Sorry stan is totally unmaintained and terrible to get to run. It only works on ghc 8.8 or 8.10 anyways …
|
(disableCabalFlag "stan") # Sorry stan is totally unmaintained and terrible to get to run. It only works on ghc 8.8 or 8.10 anyways …
|
||||||
|
(disableCabalFlag "callHierarchy") # Disabled temporarily: https://github.com/haskell/haskell-language-server/pull/3431
|
||||||
]).overrideScope (lself: lsuper: {
|
]).overrideScope (lself: lsuper: {
|
||||||
|
hls-call-hierarchy-plugin = null;
|
||||||
hlint = enableCabalFlag "ghc-lib" lsuper.hlint;
|
hlint = enableCabalFlag "ghc-lib" lsuper.hlint;
|
||||||
# For most ghc versions, we overrideScope Cabal in the configuration-ghc-???.nix,
|
# For most ghc versions, we overrideScope Cabal in the configuration-ghc-???.nix,
|
||||||
# because some packages, like ormolu, need a newer Cabal version.
|
# because some packages, like ormolu, need a newer Cabal version.
|
||||||
|
@ -1375,6 +1377,7 @@ self: super: {
|
||||||
hls-hlint-plugin = super.hls-hlint-plugin.overrideScope (lself: lsuper: {
|
hls-hlint-plugin = super.hls-hlint-plugin.overrideScope (lself: lsuper: {
|
||||||
# For "ghc-lib" flag see https://github.com/haskell/haskell-language-server/issues/3185#issuecomment-1250264515
|
# For "ghc-lib" flag see https://github.com/haskell/haskell-language-server/issues/3185#issuecomment-1250264515
|
||||||
hlint = enableCabalFlag "ghc-lib" lsuper.hlint;
|
hlint = enableCabalFlag "ghc-lib" lsuper.hlint;
|
||||||
|
apply-refact = lsuper.apply-refact_0_11_0_0;
|
||||||
});
|
});
|
||||||
|
|
||||||
# For -f-auto see cabal.project in haskell-language-server.
|
# For -f-auto see cabal.project in haskell-language-server.
|
||||||
|
@ -1398,9 +1401,6 @@ self: super: {
|
||||||
# 2022-09-19: https://github.com/haskell/haskell-language-server/issues/3200
|
# 2022-09-19: https://github.com/haskell/haskell-language-server/issues/3200
|
||||||
hls-refactor-plugin = dontCheck super.hls-refactor-plugin;
|
hls-refactor-plugin = dontCheck super.hls-refactor-plugin;
|
||||||
|
|
||||||
# 2022-11-18: https://github.com/haskell/haskell-language-server/commit/c1a7527c4fb348bee6093d9794b7d3e0c8d563f2
|
|
||||||
hls-fourmolu-plugin = assert super.hls-fourmolu-plugin.version == "1.1.0.0"; doJailbreak super.hls-fourmolu-plugin;
|
|
||||||
|
|
||||||
# tests require network
|
# tests require network
|
||||||
ghcide = dontCheck super.ghcide;
|
ghcide = dontCheck super.ghcide;
|
||||||
|
|
||||||
|
|
|
@ -2322,7 +2322,6 @@ broken-packages:
|
||||||
- hls-brittany-plugin
|
- hls-brittany-plugin
|
||||||
- hls-haddock-comments-plugin
|
- hls-haddock-comments-plugin
|
||||||
- hls-selection-range-plugin
|
- hls-selection-range-plugin
|
||||||
- hls-splice-plugin
|
|
||||||
- hls-stan-plugin
|
- hls-stan-plugin
|
||||||
- hls-tactics-plugin
|
- hls-tactics-plugin
|
||||||
- hlwm
|
- hlwm
|
||||||
|
|
|
@ -88,6 +88,8 @@ default-package-overrides:
|
||||||
- hnix-store-remote == 0.5.0.0 # 2022-06-17: Until hnix 0.17
|
- hnix-store-remote == 0.5.0.0 # 2022-06-17: Until hnix 0.17
|
||||||
# reflex-dom-core 0.7.0.2 has no reflex 0.9 compatible release and most likely most people will want to use them together
|
# reflex-dom-core 0.7.0.2 has no reflex 0.9 compatible release and most likely most people will want to use them together
|
||||||
- reflex < 0.9.0.0
|
- reflex < 0.9.0.0
|
||||||
|
# reqired by haskell-language-server 1.9.0.0
|
||||||
|
- implicit-hie < 0.1.3
|
||||||
|
|
||||||
extra-packages:
|
extra-packages:
|
||||||
- Cabal == 2.2.* # required for jailbreak-cabal etc.
|
- Cabal == 2.2.* # required for jailbreak-cabal etc.
|
||||||
|
|
|
@ -694,13 +694,7 @@ self: super: builtins.intersectAttrs super {
|
||||||
retrie_1_2_0_0 = addTestToolDepends [pkgs.git pkgs.mercurial] super.retrie_1_2_0_0;
|
retrie_1_2_0_0 = addTestToolDepends [pkgs.git pkgs.mercurial] super.retrie_1_2_0_0;
|
||||||
retrie_1_2_1_1 = addTestToolDepends [pkgs.git pkgs.mercurial] super.retrie_1_2_1_1;
|
retrie_1_2_1_1 = addTestToolDepends [pkgs.git pkgs.mercurial] super.retrie_1_2_1_1;
|
||||||
|
|
||||||
haskell-language-server = let
|
haskell-language-server = overrideCabal (drv: {
|
||||||
# This wrapper will be included in the sdist in the next release, then we can remove this custom fetch.
|
|
||||||
abi-compat-check-wrapper = assert super.haskell-language-server.version == "1.8.0.0"; pkgs.fetchurl {
|
|
||||||
url = "https://raw.githubusercontent.com/haskell/haskell-language-server/c12379c57ab8f0abd606e9f397de54e508d024a0/bindist/wrapper.in";
|
|
||||||
sha256 = "sha256-vHi6+s8/V4WJSCxIqjP+thumEpttokpCc+a823WEPPk=";
|
|
||||||
}; in
|
|
||||||
overrideCabal (drv: {
|
|
||||||
# starting with 1.6.1.1 haskell-language-server wants to be linked dynamically
|
# starting with 1.6.1.1 haskell-language-server wants to be linked dynamically
|
||||||
# by default. Unless we reflect this in the generic builder, GHC is going to
|
# by default. Unless we reflect this in the generic builder, GHC is going to
|
||||||
# produce some illegal references to /build/.
|
# produce some illegal references to /build/.
|
||||||
|
@ -717,7 +711,7 @@ self: super: builtins.intersectAttrs super {
|
||||||
-e "s/@@BOOT_PKGS@@/$BOOT_PKGS/" \
|
-e "s/@@BOOT_PKGS@@/$BOOT_PKGS/" \
|
||||||
-e "s/@@ABI_HASHES@@/$(for dep in $BOOT_PKGS; do printf "%s:" "$dep" && ghc-pkg-${self.ghc.version} field $dep abi --simple-output ; done | tr '\n' ' ' | xargs)/" \
|
-e "s/@@ABI_HASHES@@/$(for dep in $BOOT_PKGS; do printf "%s:" "$dep" && ghc-pkg-${self.ghc.version} field $dep abi --simple-output ; done | tr '\n' ' ' | xargs)/" \
|
||||||
-e "s!Consider installing ghc.* via ghcup or build HLS from source.!Visit https://haskell4nix.readthedocs.io/nixpkgs-users-guide.html#how-to-install-haskell-language-server to learn how to correctly install a matching hls for your ghc with nix.!" \
|
-e "s!Consider installing ghc.* via ghcup or build HLS from source.!Visit https://haskell4nix.readthedocs.io/nixpkgs-users-guide.html#how-to-install-haskell-language-server to learn how to correctly install a matching hls for your ghc with nix.!" \
|
||||||
${abi-compat-check-wrapper} > "$out/bin/haskell-language-server"
|
bindist/wrapper.in > "$out/bin/haskell-language-server"
|
||||||
ln -s "$out/bin/haskell-language-server" "$out/bin/haskell-language-server-${self.ghc.version}"
|
ln -s "$out/bin/haskell-language-server" "$out/bin/haskell-language-server-${self.ghc.version}"
|
||||||
chmod +x "$out/bin/haskell-language-server"
|
chmod +x "$out/bin/haskell-language-server"
|
||||||
'';
|
'';
|
||||||
|
@ -1089,13 +1083,18 @@ self: super: builtins.intersectAttrs super {
|
||||||
hls-module-name-plugin
|
hls-module-name-plugin
|
||||||
hls-splice-plugin
|
hls-splice-plugin
|
||||||
hls-refactor-plugin
|
hls-refactor-plugin
|
||||||
hls-code-range-plugin
|
hls-cabal-plugin;
|
||||||
hls-explicit-fixity-plugin;
|
|
||||||
# Tests have file permissions expections that don‘t work with the nix store.
|
# Tests have file permissions expections that don‘t work with the nix store.
|
||||||
hls-stylish-haskell-plugin = dontCheck super.hls-stylish-haskell-plugin;
|
hls-stylish-haskell-plugin = dontCheck super.hls-stylish-haskell-plugin;
|
||||||
hls-gadt-plugin = dontCheck super.hls-gadt-plugin;
|
hls-gadt-plugin = dontCheck super.hls-gadt-plugin;
|
||||||
|
|
||||||
|
# https://github.com/haskell/haskell-language-server/pull/3431
|
||||||
|
hls-cabal-fmt-plugin = dontCheck super.hls-cabal-fmt-plugin;
|
||||||
|
hls-code-range-plugin = dontCheck super.hls-code-range-plugin;
|
||||||
|
hls-explicit-record-fields-plugin = dontCheck super.hls-explicit-record-fields-plugin;
|
||||||
|
|
||||||
# Flaky tests
|
# Flaky tests
|
||||||
|
hls-explicit-fixity-plugin = dontCheck super.hls-explicit-fixity-plugin;
|
||||||
hls-hlint-plugin = dontCheck super.hls-hlint-plugin;
|
hls-hlint-plugin = dontCheck super.hls-hlint-plugin;
|
||||||
hls-pragmas-plugin = dontCheck super.hls-pragmas-plugin;
|
hls-pragmas-plugin = dontCheck super.hls-pragmas-plugin;
|
||||||
hls-class-plugin = dontCheck super.hls-class-plugin;
|
hls-class-plugin = dontCheck super.hls-class-plugin;
|
||||||
|
|
|
@ -141775,8 +141775,6 @@ self: {
|
||||||
testHaskellDepends = [ base filepath hls-test-utils text ];
|
testHaskellDepends = [ base filepath hls-test-utils text ];
|
||||||
description = "HLS Plugin to expand TemplateHaskell Splices and QuasiQuotes";
|
description = "HLS Plugin to expand TemplateHaskell Splices and QuasiQuotes";
|
||||||
license = lib.licenses.asl20;
|
license = lib.licenses.asl20;
|
||||||
hydraPlatforms = lib.platforms.none;
|
|
||||||
broken = true;
|
|
||||||
}) {};
|
}) {};
|
||||||
|
|
||||||
"hls-stan-plugin" = callPackage
|
"hls-stan-plugin" = callPackage
|
||||||
|
@ -159416,6 +159414,33 @@ self: {
|
||||||
}) {};
|
}) {};
|
||||||
|
|
||||||
"implicit-hie" = callPackage
|
"implicit-hie" = callPackage
|
||||||
|
({ mkDerivation, attoparsec, base, directory, filepath, filepattern
|
||||||
|
, hspec, hspec-attoparsec, text, transformers, yaml
|
||||||
|
}:
|
||||||
|
mkDerivation {
|
||||||
|
pname = "implicit-hie";
|
||||||
|
version = "0.1.2.7";
|
||||||
|
sha256 = "0yb457n26455kbq6kv8g48q66pmmaxcpikmpg9gm00sd6adgq6gl";
|
||||||
|
isLibrary = true;
|
||||||
|
isExecutable = true;
|
||||||
|
libraryHaskellDepends = [
|
||||||
|
attoparsec base directory filepath filepattern text transformers
|
||||||
|
yaml
|
||||||
|
];
|
||||||
|
executableHaskellDepends = [
|
||||||
|
attoparsec base directory filepath filepattern text transformers
|
||||||
|
yaml
|
||||||
|
];
|
||||||
|
testHaskellDepends = [
|
||||||
|
attoparsec base directory filepath filepattern hspec
|
||||||
|
hspec-attoparsec text transformers yaml
|
||||||
|
];
|
||||||
|
description = "Auto generate hie-bios cradles & hie.yaml";
|
||||||
|
license = lib.licenses.bsd3;
|
||||||
|
mainProgram = "gen-hie";
|
||||||
|
}) {};
|
||||||
|
|
||||||
|
"implicit-hie_0_1_4_0" = callPackage
|
||||||
({ mkDerivation, attoparsec, base, directory, filepath, filepattern
|
({ mkDerivation, attoparsec, base, directory, filepath, filepattern
|
||||||
, hspec, hspec-attoparsec, text, transformers, yaml
|
, hspec, hspec-attoparsec, text, transformers, yaml
|
||||||
}:
|
}:
|
||||||
|
@ -159439,6 +159464,7 @@ self: {
|
||||||
];
|
];
|
||||||
description = "Auto generate hie-bios cradles & hie.yaml";
|
description = "Auto generate hie-bios cradles & hie.yaml";
|
||||||
license = lib.licenses.bsd3;
|
license = lib.licenses.bsd3;
|
||||||
|
hydraPlatforms = lib.platforms.none;
|
||||||
mainProgram = "gen-hie";
|
mainProgram = "gen-hie";
|
||||||
}) {};
|
}) {};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue