chk-test/default.nix
2023-02-07 13:16:26 -05:00

71 lines
3.8 KiB
Nix

{ system ? builtins.currentSystem
, nix-thunk ? import ./dep/nix-thunk {}
, obelisk ? import ./.obelisk/impl {
inherit system;
iosSdkVersion = "13.2";
# This argument (which is new, but was easy to add to Obelisk, thankfully), allows one to specify nixpkgs overlays.
# We'll use it to ensure we have the appropriate version of botan.
nixpkgsOverlays =
[
(self: super: rec {
botan2 =
(super.botan2.overrideAttrs (old: {
# Get rid of some patches that nixpkgs was applying to botan2 and which didn't apply to the branch.
patches = [];
# The --with-openssl flag didn't work for some reason, might need further figuring out.
configurePhase = builtins.replaceStrings [ "--with-openssl" ] [ " " ] old.configurePhase;
# Here, we use nix-thunk to get the source of the correct branch of the botan repo via a thunk.
# Nix thunks are essentially references to git repositories that can be unpacked to their
# source in-place when working on the project, or packed up into a few small files.
# After installing the nix-thunk command from https://github.com/obsidiansystems/nix-thunk
# you can run:
# nix-thunk unpack dep/botan
# from the top level of this repo to clone a copy of the botan git repo at the appropriate
# commit, and work on it from there. Similarly,
# nix-thunk pack dep/botan
# will pack it back up again, provided that the changes have been pushed somewhere.
# Note: there's a bug in the current version of Obelisk which occasionally gives it some trouble
# if certain repos are unpacked. If you have any trouble running an ob command
# (ob run, ob repl, etc.) with a thunk unpacked, try adding the flag --no-interpret dep
# and hopefully that will sort it out.
src = nix-thunk.thunkSource ./dep/botan;
})).override (old: {
# Also, turn on debugging.
extraConfigureFlags = "--debug-mode";
});
# For whatever reason, it seems callCabal2nix below wants to use the botan package rather than botan2.
# We could override the pkgconfigDepends of the resulting package, but this is easier.
botan = self.botan2;
})
];
# You must accept the Android Software Development Kit License Agreement at
# https://developer.android.com/studio/terms in order to build Android apps.
# Uncomment and set this to `true` to indicate your acceptance:
# config.android_sdk.accept_license = false;
# In order to use Let's Encrypt for HTTPS deployments you must accept
# their terms of service at https://letsencrypt.org/repository/.
# Uncomment and set this to `true` to indicate your acceptance:
# terms.security.acme.acceptTerms = false;
}
}:
with obelisk;
project ./. ({ pkgs, hackGet, ... }: {
android.applicationId = "systems.obsidian.obelisk.examples.minimal";
android.displayName = "Obelisk Minimal Example";
ios.bundleIdentifier = "systems.obsidian.obelisk.examples.minimal";
ios.bundleName = "Obelisk Minimal Example";
overrides = self: super:
with pkgs.haskell.lib; {
# Here, we get the tahoe-chk package from the chk.hs thunk, and use callCabal2nix to get a nix derivation to build it.
tahoe-chk = self.callCabal2nix "tahoe-chk" (nix-thunk.thunkSource ./dep/chkhs) {};
# We also ended up needing an override of the base32 library, which we obtain from Hackage.
base32 = self.callHackageDirect {
pkg = "base32";
ver = "0.2.2.0";
sha256 = "1qx7n2jyb9h1082434r90hfrjw5fab2j1yg0qzxh856fpksbh811";
};
};
})