SerAPI is a library plus a set of command line tools aimed to improve the communication of third party tools with Coq.
As of today, SerAPI has been mostly replaced by coq-lsp
, except the
serlib
library which is actively used.
SerAPI has experimental status; while there are no protocol
stability guarantees, we got moderate experience with it and evolution
should be controlled. SerAPI have been used with success in several
research projects. Protocol-breaking changes are marked in the
changelog with (!)
.
Note that a likely side-effect of SerAPI being in maintenance mode is that few changes to the protocol will happen.
At the moment, Coq 8.19 is the current supported version. Older versions (Coq 8.6---8.18) work, however the protocol and feature sets do differ.
The supported way is to use the OPAM package manager. The
.github/workflows/ci.yml
file contains up to date install
instructions if you want to build SerAPI manually, see also the build
instructions file.
SerAPI was built to encode Coq native data types to/from S-Expressions, a widely used data and code format pioneered by the lisp programming language.
Since then, SerAPI has evolved to take advantage of other formats, and now provides experimental Python and JSON output formats too.
SerAPI does use Jane Street's excellent
sexplib library print and
parse S-exps; note that there is not really a S-exp standard, for more
details about some differences on how quoting happens in sexplib
,
please see issues #3 ,
#8 , and
#22 .
This is due to a historical limitation of the UNIX/Linux TTY API. See
#38. If you
communicate with SerAPI using a pipe this shouldn't be a problem.
Alternatively, you can use the ReadFile
experimental command.
Your OCaml path is not properly setup, see build instructions for more help.
Yes, see sercomp --help
TCoq provides some support for exporting Coq structures; the main differences with SerAPI is that SerAPI works against stock Coq and is maintained; it also provides a faithful, automatically generated printers.
A more detailed comparison is needed, in particular TCoq does provide some hooks that insert themselves in the proof execution, it is not clear that SerAPI can provide that.
For a more detailed discussion see #109
Yes, by using Coq's capabilities to that effect. Just issue the proper
(Cancel ...)
(Add ... ...)
sequence to simulate an update. This is
limited now to prefix-only incremental evaluation. It will be improved
in the future.
Yes, it does. Note however that asynchronous proof processing is still
in experimental status upstream. In particular, there are some issues
on Windows, and EditAt
may be inconvenient to use. We recommend not
using EditAt
and instead using the less powerful Cancel
for now.
We support only a limited set of coqtop
command line flags, in
particular -R
and -Q
for setting library paths. Unfortunately, due
to our command line parsing library, the format is slightly
different. See sertop --help
for a comprehensive list of flags.
SerAPI aims to be "command line flag free", with all the options for each document passed in the document creation call, so this will be the preferred method.
SerAPI exposes all core Coq datatypes. Tactics, AST, kernel terms and types are all serialized. SerAPI also provide an API to manipulate and query "Coq documents".
That's a very interesting question! The right answer is: countably many!
Logician jokes aside, the truth is that Coq features an extensible AST. While this gives great power to plugins, it means that consumers of the AST need to design their tools to support an open AST.
Coq's core parsing AST is called vernac_expr
. This type represents
the so-called "Coq vernaculars". Plugins can extend the "vernacular",
so you should be prepared to handle arbitrary content under the
VernacExtend
constructor. Such arbitrary content is called in Coq
terminology "generic arguments".
After parsing, a term will undergo two elaboration phases before it
will reach "kernel" form. The top-level parsing type for terms is
constr_expr
, which is then internalized to a glob_constr
. This
process will perform:
- Name resolution. Example
λ x : nat. x
is resolved toλ (x: Init.nat), Var 1
[using debruijn for bound variables]. - Notation interpretation. For example,
a + b
is desugared toNat.add a b
. - Implicit argument resolution. For example
fst a
is desugared to@fst _ _ a
[note the holes]. - Some desugaring of pattern-matching problems also takes place.
The next step is type inference (called pretyping in Coq, as "typing"
is used for the kernel-level type checking), which will turn a term
in glob_constr
form into a full-typed Constr.t
value. Constr.t
are the core terms manipulated by Coq's kernel and tactics.
When a generic argument is added to Coq's AST, we must also provide
the corresponding internalization and pretyping functions. To that
purpose, generic arguments have associated 3-levels, raw
, glb
, and
top
which correspond to parsing-level, internalized-level, and
kernel-level.
Thus, a generic argument of type foo
, may carry 3 different OCaml
types depending on the level the type is. This is used for example to
define the AST of LTAC tactics, where the expression pose s := foo
with foo
initially a constr_expr
will undergo interpretation and
inference up to a term with a fully elaborated foo
term.