Skip to content

Latest commit

 

History

History
130 lines (87 loc) · 4.84 KB

INSTALL.md

File metadata and controls

130 lines (87 loc) · 4.84 KB

Installation instructions

Installing with OPAM

The easiest way to get all packages is through opam. See Coq's opam documentation for installing an opam switch for Coq. See releases and Coq's Package Index for information on the available releases and opam packages.

To add the Coq repository to available opam packages, use:

# opam repo add coq-released https://coq.inria.fr/opam/released

To update the list of available packages at any point use:

# opam update

Then, simply issue:

# opam install coq-metacoq

MetaCoq is split into multiple packages that get all installed using the coq-metacoq meta-package:

  • coq-metacoq-utils for a general library used by all MetaCoq packages
  • coq-metacoq-common for definitions used both by Template-Coq and PCUIC packages
  • coq-metacoq-template for the Template Monad and quoting plugin
  • coq-metacoq-pcuic for the PCUIC metatheory development
  • coq-metacoq-template-pcuic for the verified Template-Coq <-> PCUIC translations
  • coq-metacoq-safechecker for the verified checker on PCUIC terms
  • coq-metacoq-safechecker-plugin for the extracted verified checker plugin
  • coq-metacoq-erasure for the verifed erasure from PCUIC to untyped lambda-calculus.
  • coq-metacoq-erasure-plugin for the extracted verifed erasure plugin
  • coq-metacoq-translations for example translations from type theory to type theory: e.g. variants of parametricity.
  • coq-metacoq-quotation for a quotation library, allowing to quote MetaCoq terms and typing derivations as MetaCoq terms, with a work-in-progress proof of Löb's theorem.

There are also .dev packages available in the extra-dev repository of Coq, to get those you will need to activate the following repositories:

opam repo add coq-core-dev https://coq.inria.fr/opam/core-dev
opam repo add coq-extra-dev https://coq.inria.fr/opam/extra-dev

Installing from source code

Requirements

To compile the library, you need:

  • The Coq version corrsponding to your branch (you can use the coq.dev package for the main branch).
  • OCaml (tested with 4.14.0)
  • Equations 1.3

The recommended way to build a development environment for MetaCoq is to have a dedicated opam switch (see below).

Getting the sources

To get the source code:

# git clone https://github.com/MetaCoq/metacoq.git
# git checkout -b coq-8.20 origin/coq-8.20
# git status

This checks that you are indeed on the coq-8.20 branch.

Setting up an opam switch

To setup a fresh opam installation, you might want to create a "switch" (an environment of opam packages) for Coq if you don't have one yet. You need to use opam 2 to obtain the right version of Equations.

# opam switch create coq.8.20 --packages="ocaml-variants.4.14.0+options,ocaml-option-flambda"
# eval $(opam env)

This creates the coq.8.20 switch which initially contains only the basic OCaml 4.13.1 compiler with the flambda option enabled, and puts you in the right environment (check with ocamlc -v).

Once in the right switch, you can install Coq and the Equations package using:

# opam install . --deps-only

If the commands are successful you should have coq available (check with `coqc -v**).

Remark: You can create a local switch for developing using (in the root directory of the sources):

# opam switch create . --packages="ocaml-variants.4.14.0+options,ocaml-option-flambda"

Or use opam switch link foo to link an existing opam switch foo with the sources directory.

Compiling from sources

Important: To compile locally without using opam, use ./configure.sh local at the root.

Then use:

  • make to compile the template-coq plugin, the pcuic development and the safechecker and erasure plugins, along with the test-suite, translations, examples and quotation libraries. You can also selectively build each target.

  • make install to install the plugins in Coq's user-contrib local library. Then the MetaCoq namespace can be used for Require Import statements, e.g. From MetaCoq.Template Require Import All..

  • make uninstall to undo the last line.

For faster development one can use:

  • make vos to compile vos files (bypassing proofs) for pcuic, safechecker and erasure. The template-coq library is still using the regular vo target to be able to construct the template-coq plugin. The safechecker and erasure ML plugins cannot be built using this mode.

  • make quick is a synonymous for make vos with the addition of a global Unset Universe Checking option, i.e. universes are not checked anywhere.