Newer
Older
{
description = "A Haskell implementation of the Tahoe-LAFS SSK cryptographic protocols";
inputs = {
# Nix Inputs
flake-utils.url = github:numtide/flake-utils;
hs-flake-utils.url = "git+https://whetstone.private.storage/jcalderone/hs-flake-utils.git?ref=main";
nixpkgs.follows = "hs-flake-utils/nixpkgs";
url = "git+https://whetstone.private.storage/PrivateStorage/tahoe-chk?ref=refs/tags/0.2.0.0";
inputs.nixpkgs.follows = "hs-flake-utils/nixpkgs";
};
tahoe-capabilities = {
url = "git+https://whetstone.private.storage/PrivateStorage/tahoe-capabilities";
inputs.nixpkgs.follows = "hs-flake-utils/nixpkgs";
};
};
outputs = {
self,
nixpkgs,
flake-utils,
hs-flake-utils,
tahoe-capabilities,
}: let
ulib = flake-utils.lib;
ghcVersion = "ghc8107";
in
ulib.eachSystem ["x86_64-linux" "aarch64-darwin"] (system: let
# Get a nixpkgs customized for this system
pkgs = import nixpkgs {
inherit system;
};
hslib = hs-flake-utils.lib {
inherit pkgs;
src = ./.;
compilerVersion = ghcVersion;
packageName = "tahoe-ssk";
hsPkgsOverrides = hprev: hfinal: {
tahoe-chk = tahoe-chk.outputs.packages.${system}.default;
tahoe-capabilities = tahoe-capabilities.outputs.packages.${system}.default;
};
in {
checks = hslib.checks {};
devShells = hslib.devShells {
shellHook = ''
nix run .#write-cabal-project
'';
extraBuildInputs = pkgs:
with pkgs; [
zlib
];
};
packages = hslib.packages {};
apps.write-cabal-project = hslib.apps.write-cabal-project {
localPackages = {
"tahoe-chk" = tahoe-chk.sourceInfo.outPath;
"tahoe-capabilities" = tahoe-capabilities.sourceInfo.outPath;
};
apps.cabal-test = hslib.apps.cabal-test {
preBuild = "nix run .#generate-cabal-project";
apps.release = hslib.apps.release {};