1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
{ nixpkgs ? import <nixpkgs> {}, compiler ? "ghc8107", doBenchmark ? false }:
let
inherit (nixpkgs) pkgs;
f = { mkDerivation, aeson, base, bytestring, cassava, conduit
, containers, data-default-class, either, extra, fmt, http-media
, lens, lib, monad-logger, mtl, path-pieces, persistent
, persistent-postgresql, protocol-buffers
, protocol-buffers-descriptor, regex-tdfa, resource-pool, servant
, servant-docs, servant-server, servant-swagger, stm, swagger2
, text, time, transformers, unliftio-core, uuid, vector
, vector-algorithms, wai-extra, warp, zip-archive
}:
mkDerivation {
pname = "tracktrain";
version = "0.1.0.0";
src = ./.;
isLibrary = true;
isExecutable = true;
libraryHaskellDepends = [
aeson base bytestring cassava conduit containers either extra fmt
http-media lens monad-logger mtl path-pieces persistent
persistent-postgresql protocol-buffers protocol-buffers-descriptor
regex-tdfa resource-pool servant servant-docs servant-server
servant-swagger stm swagger2 text time transformers unliftio-core
uuid vector vector-algorithms warp zip-archive
];
executableHaskellDepends = [
aeson base bytestring data-default-class fmt monad-logger
persistent-postgresql protocol-buffers time wai-extra warp
];
doHaddock = false;
description = "tracktrain tracks trains on their traintracks";
license = "unknown";
hydraPlatforms = lib.platforms.none;
};
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 # if pkgs.lib.inNixShell then drv.env else drv
|