summary refs log tree commit diff
path: root/doc/languages-frameworks/coq.section.md
diff options
context:
space:
mode:
authorStephen OBrien <wayofthepie@gmail.com>2020-11-27 08:07:30 +0000
committerStephen OBrien <wayofthepie@gmail.com>2020-11-27 08:13:55 +0000
commita7e9047db399b8162d9596b28b68976c34e0ebf6 (patch)
tree47adc92d33b860d25eacfb6e5be2c760fa9c2171 /doc/languages-frameworks/coq.section.md
parent4e5342cce40d5440c051fe6295c17a0fbb77efa6 (diff)
downloadnixpkgs-a7e9047db399b8162d9596b28b68976c34e0ebf6.tar
nixpkgs-a7e9047db399b8162d9596b28b68976c34e0ebf6.tar.gz
nixpkgs-a7e9047db399b8162d9596b28b68976c34e0ebf6.tar.bz2
nixpkgs-a7e9047db399b8162d9596b28b68976c34e0ebf6.tar.lz
nixpkgs-a7e9047db399b8162d9596b28b68976c34e0ebf6.tar.xz
nixpkgs-a7e9047db399b8162d9596b28b68976c34e0ebf6.tar.zst
nixpkgs-a7e9047db399b8162d9596b28b68976c34e0ebf6.zip
doc: convert coq to commonmark
Diffstat (limited to 'doc/languages-frameworks/coq.section.md')
-rw-r--r--doc/languages-frameworks/coq.section.md40
1 files changed, 40 insertions, 0 deletions
diff --git a/doc/languages-frameworks/coq.section.md b/doc/languages-frameworks/coq.section.md
new file mode 100644
index 00000000000..714e84efc8d
--- /dev/null
+++ b/doc/languages-frameworks/coq.section.md
@@ -0,0 +1,40 @@
+# Coq {#sec-language-coq}
+
+Coq libraries should be installed in `$(out)/lib/coq/${coq.coq-version}/user-contrib/`. Such directories are automatically added to the `$COQPATH` environment variable by the hook defined in the Coq derivation.
+
+Some extensions (plugins) might require OCaml and sometimes other OCaml packages. The `coq.ocamlPackages` attribute can be used to depend on the same package set Coq was built against.
+
+Coq libraries may be compatible with some specific versions of Coq only. The `compatibleCoqVersions` attribute is used to precisely select those versions of Coq that are compatible with this derivation.
+
+Here is a simple package example. It is a pure Coq library, thus it depends on Coq. It builds on the Mathematical Components library, thus it also takes `mathcomp` as `buildInputs`. Its `Makefile` has been generated using `coq_makefile` so we only have to set the `$COQLIB` variable at install time.
+
+```nix
+{ stdenv, fetchFromGitHub, coq, mathcomp }:
+
+stdenv.mkDerivation rec {
+  name = "coq${coq.coq-version}-multinomials-${version}";
+  version = "1.0";
+  src = fetchFromGitHub {
+    owner = "math-comp";
+    repo = "multinomials";
+    rev = version;
+    sha256 = "1qmbxp1h81cy3imh627pznmng0kvv37k4hrwi2faa101s6bcx55m";
+  };
+
+  buildInputs = [ coq ];
+  propagatedBuildInputs = [ mathcomp ];
+
+  installFlags = "COQLIB=$(out)/lib/coq/${coq.coq-version}/";
+
+  meta = {
+    description = "A Coq/SSReflect Library for Monoidal Rings and Multinomials";
+    inherit (src.meta) homepage;
+    license = stdenv.lib.licenses.cecill-b;
+    inherit (coq.meta) platforms;
+  };
+
+  passthru = {
+    compatibleCoqVersions = v: builtins.elem v [ "8.5" "8.6" "8.7" ];
+  };
+}
+```