2021-05-01 11:36:24 +00:00
|
|
|
{ lib, writeText, haskellPackages, cabal-install }:
|
shellFor: Refactor for consistency and cross
This makes it work like work-on-multi from Reflex Platform. In
particular, rather than making `.env` from `shellFor`, we make `.env`
the primitive, and `shellFor` works by combining together the arguments
of all the packages to `generic-builder` and taking the `.env` of the
resulting mashup-package.
There are 2 benefits of this:
1. The dependency logic is deduplicated. generic builder just concatted
lists, whereas all the envs until now would sieve apart haskell and
system build inputs. Now, they both decide haskell vs system the same
way: according to the argument list and without reflection.
Consistency is good, especially because it mean that if the build
works, the shell is more likely to work.
2. Cross is handled better. For native builds, because the
`ghcWithPackages` calls would shadow, we through both the regular
component (lib, exe, test, bench) haskell deps and Setup.hs haskell
deps in the same `ghcWithPackages` call. But for cross builds we use
`buildPackages.ghcWithPackages` to get the setup deps. This ensures
everything works correctly.
2019-12-23 20:33:18 +00:00
|
|
|
|
2020-09-22 11:35:39 +00:00
|
|
|
(haskellPackages.shellFor {
|
2021-05-01 11:25:13 +00:00
|
|
|
packages = p: [ p.constraints p.linear ];
|
2023-07-04 06:38:23 +00:00
|
|
|
# WARNING: When updating this, make sure that the libraries passed to
|
|
|
|
# `extraDependencies` are not actually transitive dependencies of libraries in
|
|
|
|
# `packages` above. We explicitly want to test that it is possible to specify
|
|
|
|
# `extraDependencies` that are not in the closure of `packages`.
|
|
|
|
extraDependencies = p: { libraryHaskellDepends = [ p.conduit ]; };
|
shellFor: Refactor for consistency and cross
This makes it work like work-on-multi from Reflex Platform. In
particular, rather than making `.env` from `shellFor`, we make `.env`
the primitive, and `shellFor` works by combining together the arguments
of all the packages to `generic-builder` and taking the `.env` of the
resulting mashup-package.
There are 2 benefits of this:
1. The dependency logic is deduplicated. generic builder just concatted
lists, whereas all the envs until now would sieve apart haskell and
system build inputs. Now, they both decide haskell vs system the same
way: according to the argument list and without reflection.
Consistency is good, especially because it mean that if the build
works, the shell is more likely to work.
2. Cross is handled better. For native builds, because the
`ghcWithPackages` calls would shadow, we through both the regular
component (lib, exe, test, bench) haskell deps and Setup.hs haskell
deps in the same `ghcWithPackages` call. But for cross builds we use
`buildPackages.ghcWithPackages` to get the setup deps. This ensures
everything works correctly.
2019-12-23 20:33:18 +00:00
|
|
|
nativeBuildInputs = [ cabal-install ];
|
|
|
|
phases = [ "unpackPhase" "buildPhase" "installPhase" ];
|
|
|
|
unpackPhase = ''
|
|
|
|
sourceRoot=$(pwd)/scratch
|
|
|
|
mkdir -p "$sourceRoot"
|
|
|
|
cd "$sourceRoot"
|
2020-09-22 11:35:39 +00:00
|
|
|
tar -xf ${haskellPackages.constraints.src}
|
2021-05-01 11:25:13 +00:00
|
|
|
tar -xf ${haskellPackages.linear.src}
|
2021-05-01 11:36:24 +00:00
|
|
|
cp ${writeText "cabal.project" "packages: constraints* linear*"} cabal.project
|
shellFor: Refactor for consistency and cross
This makes it work like work-on-multi from Reflex Platform. In
particular, rather than making `.env` from `shellFor`, we make `.env`
the primitive, and `shellFor` works by combining together the arguments
of all the packages to `generic-builder` and taking the `.env` of the
resulting mashup-package.
There are 2 benefits of this:
1. The dependency logic is deduplicated. generic builder just concatted
lists, whereas all the envs until now would sieve apart haskell and
system build inputs. Now, they both decide haskell vs system the same
way: according to the argument list and without reflection.
Consistency is good, especially because it mean that if the build
works, the shell is more likely to work.
2. Cross is handled better. For native builds, because the
`ghcWithPackages` calls would shadow, we through both the regular
component (lib, exe, test, bench) haskell deps and Setup.hs haskell
deps in the same `ghcWithPackages` call. But for cross builds we use
`buildPackages.ghcWithPackages` to get the setup deps. This ensures
everything works correctly.
2019-12-23 20:33:18 +00:00
|
|
|
'';
|
|
|
|
buildPhase = ''
|
|
|
|
export HOME=$(mktemp -d)
|
|
|
|
mkdir -p $HOME/.cabal
|
|
|
|
touch $HOME/.cabal/config
|
2022-03-15 19:36:31 +00:00
|
|
|
|
2023-07-04 06:38:23 +00:00
|
|
|
# Check that the extraDependencies.libraryHaskellDepends arg is correctly
|
|
|
|
# picked up. This uses ghci to interpret a small Haskell program that uses
|
|
|
|
# a package from extraDependencies.
|
2022-03-15 19:36:31 +00:00
|
|
|
ghci <<EOF
|
2023-07-04 06:38:23 +00:00
|
|
|
:set -XOverloadedStrings
|
|
|
|
:m + Conduit
|
|
|
|
runResourceT $ connect (yield "done") (sinkFile "outfile")
|
2022-03-15 19:36:31 +00:00
|
|
|
EOF
|
2023-07-04 06:38:23 +00:00
|
|
|
|
|
|
|
if [[ "done" != "$(cat outfile)" ]]; then
|
|
|
|
echo "ERROR: extraDependencies appear not to be available in the environment"
|
|
|
|
exit 1
|
|
|
|
fi
|
2022-03-15 19:36:31 +00:00
|
|
|
|
|
|
|
# Check packages arg
|
2021-05-01 11:25:13 +00:00
|
|
|
cabal v2-build --offline --verbose constraints linear --ghc-options="-O0 -j$NIX_BUILD_CORES"
|
shellFor: Refactor for consistency and cross
This makes it work like work-on-multi from Reflex Platform. In
particular, rather than making `.env` from `shellFor`, we make `.env`
the primitive, and `shellFor` works by combining together the arguments
of all the packages to `generic-builder` and taking the `.env` of the
resulting mashup-package.
There are 2 benefits of this:
1. The dependency logic is deduplicated. generic builder just concatted
lists, whereas all the envs until now would sieve apart haskell and
system build inputs. Now, they both decide haskell vs system the same
way: according to the argument list and without reflection.
Consistency is good, especially because it mean that if the build
works, the shell is more likely to work.
2. Cross is handled better. For native builds, because the
`ghcWithPackages` calls would shadow, we through both the regular
component (lib, exe, test, bench) haskell deps and Setup.hs haskell
deps in the same `ghcWithPackages` call. But for cross builds we use
`buildPackages.ghcWithPackages` to get the setup deps. This ensures
everything works correctly.
2019-12-23 20:33:18 +00:00
|
|
|
'';
|
|
|
|
installPhase = ''
|
|
|
|
touch $out
|
|
|
|
'';
|
2020-09-22 11:35:39 +00:00
|
|
|
}).overrideAttrs (oldAttrs: {
|
|
|
|
meta =
|
|
|
|
let
|
|
|
|
oldMeta = oldAttrs.meta or {};
|
|
|
|
oldMaintainers = oldMeta.maintainers or [];
|
|
|
|
additionalMaintainers = with lib.maintainers; [ cdepillabout ];
|
|
|
|
allMaintainers = oldMaintainers ++ additionalMaintainers;
|
|
|
|
in
|
2021-07-13 13:37:22 +00:00
|
|
|
oldMeta // {
|
|
|
|
maintainers = allMaintainers;
|
|
|
|
inherit (cabal-install.meta) platforms;
|
|
|
|
};
|
2020-09-22 11:35:39 +00:00
|
|
|
})
|