coq: merge files 8.5.nix and 8.6.nix into default.nix
This commit is contained in:
parent
eb0192b83c
commit
a30e8db9f0
@ -1,88 +0,0 @@
|
|||||||
# - coqide compilation can be disabled by setting lablgtk to null;
|
|
||||||
# - The csdp program used for the Micromega tactic is statically referenced.
|
|
||||||
# However, coq can build without csdp by setting it to null.
|
|
||||||
# In this case some Micromega tactics will search the user's path for the csdp program and will fail if it is not found.
|
|
||||||
# - The patch-level version can be specified through the `pl` argument to
|
|
||||||
# the derivation; it defaults to the greatest.
|
|
||||||
|
|
||||||
{ stdenv, fetchurl, writeText, pkgconfig
|
|
||||||
, ocaml, findlib, camlp5, ncurses
|
|
||||||
, lablgtk ? null, csdp ? null
|
|
||||||
, pl ? "1"
|
|
||||||
}:
|
|
||||||
|
|
||||||
let
|
|
||||||
# version = "8.6pl${pl}";
|
|
||||||
version = "8.6";
|
|
||||||
sha256 = "1pw1xvy1657l1k69wrb911iqqflzhhp8wwsjvihbgc72r3skqg3f";
|
|
||||||
coq-version = "8.6";
|
|
||||||
buildIde = lablgtk != null;
|
|
||||||
ideFlags = if buildIde then "-lablgtkdir ${lablgtk}/lib/ocaml/*/site-lib/lablgtk2 -coqide opt" else "";
|
|
||||||
csdpPatch = if csdp != null then ''
|
|
||||||
substituteInPlace plugins/micromega/sos.ml --replace "; csdp" "; ${csdp}/bin/csdp"
|
|
||||||
substituteInPlace plugins/micromega/coq_micromega.ml --replace "System.is_in_system_path \"csdp\"" "true"
|
|
||||||
'' else "";
|
|
||||||
in
|
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
|
||||||
name = "coq-${version}";
|
|
||||||
|
|
||||||
inherit coq-version;
|
|
||||||
inherit ocaml camlp5;
|
|
||||||
|
|
||||||
src = fetchurl {
|
|
||||||
url = "http://coq.inria.fr/distrib/V${version}/files/coq-${version}.tar.gz";
|
|
||||||
inherit sha256;
|
|
||||||
};
|
|
||||||
|
|
||||||
buildInputs = [ pkgconfig ocaml findlib camlp5 ncurses lablgtk ];
|
|
||||||
|
|
||||||
postPatch = ''
|
|
||||||
UNAME=$(type -tp uname)
|
|
||||||
RM=$(type -tp rm)
|
|
||||||
substituteInPlace configure --replace "/bin/uname" "$UNAME"
|
|
||||||
substituteInPlace tools/beautify-archive --replace "/bin/rm" "$RM"
|
|
||||||
substituteInPlace configure.ml --replace '"md5 -q"' '"md5sum"'
|
|
||||||
${csdpPatch}
|
|
||||||
'';
|
|
||||||
|
|
||||||
setupHook = writeText "setupHook.sh" ''
|
|
||||||
addCoqPath () {
|
|
||||||
if test -d "''$1/lib/coq/${coq-version}/user-contrib"; then
|
|
||||||
export COQPATH="''${COQPATH}''${COQPATH:+:}''$1/lib/coq/${coq-version}/user-contrib/"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
envHooks=(''${envHooks[@]} addCoqPath)
|
|
||||||
'';
|
|
||||||
|
|
||||||
preConfigure = ''
|
|
||||||
configureFlagsArray=(
|
|
||||||
-opt
|
|
||||||
${ideFlags}
|
|
||||||
)
|
|
||||||
'';
|
|
||||||
|
|
||||||
prefixKey = "-prefix ";
|
|
||||||
|
|
||||||
buildFlags = "revision coq coqide bin/votour";
|
|
||||||
|
|
||||||
postInstall = ''
|
|
||||||
cp bin/votour $out/bin/
|
|
||||||
'';
|
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
|
||||||
description = "Coq proof assistant";
|
|
||||||
longDescription = ''
|
|
||||||
Coq is a formal proof management system. It provides a formal language
|
|
||||||
to write mathematical definitions, executable algorithms and theorems
|
|
||||||
together with an environment for semi-interactive development of
|
|
||||||
machine-checked proofs.
|
|
||||||
'';
|
|
||||||
homepage = "http://coq.inria.fr";
|
|
||||||
license = licenses.lgpl21;
|
|
||||||
branch = coq-version;
|
|
||||||
maintainers = with maintainers; [ roconnor thoughtpolice vbgl ];
|
|
||||||
platforms = platforms.unix;
|
|
||||||
};
|
|
||||||
}
|
|
@ -2,23 +2,23 @@
|
|||||||
# - The csdp program used for the Micromega tactic is statically referenced.
|
# - The csdp program used for the Micromega tactic is statically referenced.
|
||||||
# However, coq can build without csdp by setting it to null.
|
# However, coq can build without csdp by setting it to null.
|
||||||
# In this case some Micromega tactics will search the user's path for the csdp program and will fail if it is not found.
|
# In this case some Micromega tactics will search the user's path for the csdp program and will fail if it is not found.
|
||||||
# - The patch-level version can be specified through the `pl` argument to
|
# - The patch-level version can be specified through the `version` argument to
|
||||||
# the derivation; it defaults to the greatest.
|
# the derivation; it defaults to the greatest.
|
||||||
|
|
||||||
{ stdenv, fetchurl, writeText, pkgconfig
|
{ stdenv, fetchurl, writeText, pkgconfig
|
||||||
, ocaml, findlib, camlp5, ncurses
|
, ocaml, findlib, camlp5, ncurses
|
||||||
, lablgtk ? null, csdp ? null
|
, lablgtk ? null, csdp ? null
|
||||||
, pl ? "3"
|
, version ? "8.6"
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
version = "8.5pl${pl}";
|
|
||||||
sha256 = {
|
sha256 = {
|
||||||
"1" = "1w2xvm6w16khfn63bp95s25hnkn2ny3w0yqg3lq63gp11aqpbyjb";
|
"8.5pl1" = "1w2xvm6w16khfn63bp95s25hnkn2ny3w0yqg3lq63gp11aqpbyjb";
|
||||||
"2" = "0wyywia0darak2zmc5v0ra9rn0b9whwdfiahralm8v5za499s8w3";
|
"8.5pl2" = "0wyywia0darak2zmc5v0ra9rn0b9whwdfiahralm8v5za499s8w3";
|
||||||
"3" = "0fyk2a4fpifibq8y8jhx1891k55qnsnlygglch64sva0bph94nrh";
|
"8.5pl3" = "0fyk2a4fpifibq8y8jhx1891k55qnsnlygglch64sva0bph94nrh";
|
||||||
}."${pl}";
|
"8.6" = "1pw1xvy1657l1k69wrb911iqqflzhhp8wwsjvihbgc72r3skqg3f";
|
||||||
coq-version = "8.5";
|
}."${version}";
|
||||||
|
coq-version = builtins.substring 0 3 version;
|
||||||
buildIde = lablgtk != null;
|
buildIde = lablgtk != null;
|
||||||
ideFlags = if buildIde then "-lablgtkdir ${lablgtk}/lib/ocaml/*/site-lib/lablgtk2 -coqide opt" else "";
|
ideFlags = if buildIde then "-lablgtkdir ${lablgtk}/lib/ocaml/*/site-lib/lablgtk2 -coqide opt" else "";
|
||||||
csdpPatch = if csdp != null then ''
|
csdpPatch = if csdp != null then ''
|
@ -16977,11 +16977,12 @@ with pkgs;
|
|||||||
inherit (ocamlPackages_4_01_0) ocaml findlib lablgtk;
|
inherit (ocamlPackages_4_01_0) ocaml findlib lablgtk;
|
||||||
camlp5 = ocamlPackages_4_01_0.camlp5_transitional;
|
camlp5 = ocamlPackages_4_01_0.camlp5_transitional;
|
||||||
};
|
};
|
||||||
coq_8_5 = callPackage ../applications/science/logic/coq/8.5.nix {
|
coq_8_5 = callPackage ../applications/science/logic/coq {
|
||||||
|
version = "8.5pl3";
|
||||||
inherit (ocamlPackages) ocaml findlib lablgtk;
|
inherit (ocamlPackages) ocaml findlib lablgtk;
|
||||||
camlp5 = ocamlPackages.camlp5_transitional;
|
camlp5 = ocamlPackages.camlp5_transitional;
|
||||||
};
|
};
|
||||||
coq_8_6 = callPackage ../applications/science/logic/coq/8.6.nix {
|
coq_8_6 = callPackage ../applications/science/logic/coq {
|
||||||
inherit (ocamlPackages) ocaml findlib lablgtk;
|
inherit (ocamlPackages) ocaml findlib lablgtk;
|
||||||
camlp5 = ocamlPackages.camlp5_transitional;
|
camlp5 = ocamlPackages.camlp5_transitional;
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user