Commit 9d0238cb authored by Matthieu Coudron's avatar Matthieu Coudron

flake: expose ihaskell directly

we used to expose just the ihaskellEnv. Also added devShell and attribute set for 921. I've renamed some of the packages on the same model as haskell-language-server.
parent 94cee8a7
...@@ -20,19 +20,26 @@ ...@@ -20,19 +20,26 @@
inherit system; inherit system;
}; };
ihaskellEnv = compilerVersion: compilerVersionFromHsPkgs = hsPkgs:
pkgs.lib.replaceStrings [ "." ] [ "" ] hsPkgs.ghc.version;
mkEnv = hsPkgs:
import ./release.nix { import ./release.nix {
compiler = "ghc${compilerVersion}"; compiler = "ghc${compilerVersionFromHsPkgs hsPkgs}";
nixpkgs = pkgs; nixpkgs = pkgs;
}; };
mkExe = hsPkgs: (mkEnv hsPkgs).ihaskellExe;
ghcDefault = ghc8107;
ghc884 = pkgs.haskell.packages.ghc884; ghc884 = pkgs.haskell.packages.ghc884;
ghc8107 = pkgs.haskell.packages.ghc8107; ghc8107 = pkgs.haskell.packages.ghc8107;
ghc921 = pkgs.haskell.packages.ghc921;
mkDevShell = hsPkgs: mkDevShell = hsPkgs:
let let
myIHaskell = (mkPackage hsPkgs); myIHaskell = (mkPackage hsPkgs);
compilerVersion = pkgs.lib.replaceStrings [ "." ] [ "" ] hsPkgs.ghc.version; compilerVersion = compilerVersionFromHsPkgs hsPkgs;
myModifier = drv: myModifier = drv:
pkgs.haskell.lib.addBuildTools drv (with hsPkgs; [ pkgs.haskell.lib.addBuildTools drv (with hsPkgs; [
...@@ -51,19 +58,29 @@ ...@@ -51,19 +58,29 @@
name = "ihaskell"; name = "ihaskell";
returnShellEnv = false; returnShellEnv = false;
modifier = pkgs.haskell.lib.dontCheck; modifier = pkgs.haskell.lib.dontCheck;
overrides = (ihaskellEnv compilerVersion).ihaskellOverlay ; overrides = (mkEnv hsPkgs).ihaskellOverlay ;
withHoogle = true; withHoogle = true;
}; };
in { in {
packages = { packages = {
ihaskell = mkDevShell ghc8107; ihaskell-dev = mkDevShell ghcDefault;
ihaskell8107 = mkDevShell ghc8107; ihaskell-dev-921 = mkDevShell ghc921;
ihaskell884 = mkDevShell ghc884; ihaskell-dev-8107 = mkDevShell ghc8107;
ihaskellEnv = ihaskellEnv ghc8107; ihaskell-dev-884 = mkDevShell ghc884;
ihaskell = mkExe ghcDefault;
ihaskell-8107 = mkExe ghc8107;
ihaskell-921 = mkExe ghc921;
# I actually wish those would disappear ? let jupyterWith or use deal with it
ihaskell-env = mkEnv ghcDefault;
ihaskell-env-8107 = mkEnv ghc8107;
}; };
defaultPackage = self.packages.${system}.ihaskell; defaultPackage = self.packages.${system}.ihaskell;
devShell = self.packages.${system}.ihaskell-dev;
}); });
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment