Newer
Older
inputs = {
# Nix Inputs
nixpkgs.follows = "hs-flake-utils/nixpkgs";
flake-utils.url = github:numtide/flake-utils;
hs-flake-utils.url = "git+https://whetstone.private.storage/jcalderone/hs-flake-utils.git?ref=main";
tahoe-directory = {
url = "git+https://whetstone.private.storage/PrivateStorage/tahoe-directory.git";
inputs.nixpkgs.follows = "hs-flake-utils/nixpkgs";
};
tahoe-chk.follows = "tahoe-directory/tahoe-chk";
tahoe-ssk.follows = "tahoe-directory/tahoe-ssk";
tahoe-capabilities.follows = "tahoe-directory/tahoe-capabilities";
tahoe-great-black-swamp = {
url = "git+https://whetstone.private.storage/PrivateStorage/tahoe-great-black-swamp?ref=refs/tags/0.3.0.0";
inputs.nixpkgs.follows = "hs-flake-utils/nixpkgs";
};
outputs = {
self,
nixpkgs,
flake-utils,
hs-flake-utils,
tahoe-chk,
tahoe-capabilities,
tahoe-directory,
tahoe-great-black-swamp,
}: let
ulib = flake-utils.lib;
ghcVersion = "ghc8107";
in
ulib.eachSystem ["x86_64-linux" "aarch64-darwin"] (system: let
# Get a nixpkgs customized for this system and including our overlay.
pkgs = import nixpkgs {
inherit system;
};
hslib = hs-flake-utils.lib {
inherit pkgs;
src = ./.;
compilerVersion = ghcVersion;
hsPkgsOverrides = hfinal: hprev: {
tahoe-chk = tahoe-chk.outputs.packages.${system}.default;
tahoe-ssk = tahoe-ssk.outputs.packages.${system}.default;
tahoe-directory = tahoe-directory.outputs.packages.${system}.default;
tahoe-capabilities = tahoe-capabilities.outputs.packages.${system}.default;
tahoe-great-black-swamp = tahoe-great-black-swamp.outputs.packages.${system}.default;
# A broken dependency of a tahoe-great-black-swamp executable that
# we don't use. Flip the broken bit so we can get a build.
language-ecmascript = pkgs.haskell.unmarkBroken hprev.language-ecmascript;
};
in {
checks = hslib.checks {};
devShells = hslib.devShells {
shellHook = ''
'';
extraBuildInputs = pkgs:
with pkgs; [
# We configure cabal to use zlib:pkg-config so we better supply
# pkg-config in the dev shell or `cabal ...` builds will surely
# fail.
pkg-config
# And also that pesky zlib dependency.
zlib
];
};
packages = hslib.packages {};
apps.hlint = hslib.apps.hlint {};
apps.generate-cabal-project = {
type = "app";
program = "${
pkgs.writeShellApplication {
name = "generate-cabal-project";
text = ''
cat >cabal.project.local <<EOF
-- This file is auto-generated by the flake devShell's shellHook. Do
-- not edit this file. Make changes in flake.nix.
packages:
-- These aren't released on hackage yet so we have to get them
-- another way. Here, we get them from the Nix store.
-- tahoe-chk
${tahoe-chk}
-- tahoe-ssk
${tahoe-ssk}
-- tahoe-capabilities
${tahoe-capabilities}
-- tahoe-directory
${tahoe-directory}
-- tahoe-great-black-swamp
${tahoe-great-black-swamp}
EOF
'';
}
}/bin/generate-cabal-project";
};
apps.entr-test = {
type = "app";
program = "${
pkgs.writeShellApplication {
name = "entr-test";
runtimeInputs = with pkgs; [
entr
cabal-install
haskell.compiler.${ghcVersion}
];
text = ''
find . -iname '*.hs' -or -iname '*.cabal' | entr bash -c "cabal run tests; if [ \$? != 0 ]; then printf '\e[31m%s\e[0m\n' \"FAILED: \$?\"; else printf '\e[32m%s\e[0m\n' 'SUCCESS'; fi"
# Using the working directory of `nix run`, do a build with cabal and
# then run the test suite.
apps.cabal-test = {
type = "app";
program = "${
pkgs.writeShellApplication {
name = "cabal-build-and-test";
# Only put packages with things that need to be on PATH here
# because that's all that runtimeInputs buys us. Packages with
# different requirements need to be handled differently.
runtimeInputs = with pkgs; [
pkg-config
haskell.compiler.${ghcVersion}
cabal-install
];
# Here we make zlib discoverable by pkg-config so cabal can find
# headers and stuff.
export PKG_CONFIG_PATH=${pkgs.lib.makeSearchPath "lib/pkgconfig" [pkgs.zlib.dev]}
# Get (or update if we have one) a package database so cabal can
# solve our dependencies.
# Run the default test suite. The local cabal project file
# written above should have enabled tests so the build plan will
# support them.
cabal run tests
'';
}
}/bin/cabal-build-and-test";
};
});
}