From 4fc8799d38226363522e5711a645bfaea2b304ff Mon Sep 17 00:00:00 2001 From: Baitinq Date: Sat, 16 Jul 2022 17:14:30 +0200 Subject: Have dependencies be managed by nix --- shell.nix | 42 ++++++++++++++++++++++++++++++++---------- 1 file changed, 32 insertions(+), 10 deletions(-) (limited to 'shell.nix') diff --git a/shell.nix b/shell.nix index 72fce48..1ab7f90 100644 --- a/shell.nix +++ b/shell.nix @@ -1,10 +1,32 @@ -{ pkgs ? import { } }: -pkgs.mkShell { - buildInputs = with pkgs; [ - ghc - cabal-install - stack - - haskell-language-server - ]; -} +{ nixpkgs ? import {}, compiler ? "default", doBenchmark ? false }: + +let + + inherit (nixpkgs) pkgs; + + f = { mkDerivation, astro, base, hpack, lib }: + mkDerivation { + pname = "sky-info"; + version = "0.1.0.0"; + src = ./.; + isLibrary = true; + isExecutable = true; + libraryHaskellDepends = [ astro base ]; + libraryToolDepends = [ hpack ]; + executableHaskellDepends = [ astro base ]; + testHaskellDepends = [ astro base ]; + prePatch = "hpack"; + homepage = "https://github.com/githubuser/sky-info#readme"; + license = lib.licenses.bsd3; + }; + + haskellPackages = if compiler == "default" + then pkgs.haskellPackages + else pkgs.haskell.packages.${compiler}; + + variant = if doBenchmark then pkgs.haskell.lib.doBenchmark else pkgs.lib.id; + + drv = variant (haskellPackages.callPackage f {}); + +in + drv.env -- cgit 1.4.1