https://github.com/EasyCrypt/easycrypt
Tip revision: bad3a6373b77fe080e1c3cee422142a108d27f57 authored by Pierre-Yves Strub on 11 December 2023, 09:29:21 UTC
Internal change: primitive notion of forall-bindings in proof terms
Internal change: primitive notion of forall-bindings in proof terms
Tip revision: bad3a63
default.nix
{ withProvers ? false, devDeps ? [] }:
with import <nixpkgs> {};
let provers =
if withProvers then [
alt-ergo
cvc4
cvc5
z3
] else []; in
let why3-pin =
why3.overrideAttrs (o : rec {
version = "1.6.0";
src = fetchurl {
url = "https://why3.gitlabpages.inria.fr/releases/${o.pname}-${version}.tar.gz";
sha256 = "sha256-hFvM6kHScaCtcHCc6Vezl9CR7BFbiKPoTEh7kj0ZJxw=";
};
});
in
stdenv.mkDerivation {
pname = "easycrypt";
version = "git";
src = ./.;
buildInputs = [ git ] ++ (with ocamlPackages; [
ocaml
findlib
batteries
camlp-streams
dune_3
dune-build-info
dune-site
inifiles
menhir
menhirLib
yojson
zarith
]);
propagatedBuildInputs = [ why3-pin ]
++ devDeps
++ provers;
installPhase = ''
runHook preInstall
dune install --prefix $out -p $pname
runHook postInstall
'';
}