package rocq-runtime
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=051f7bf702ff0a3b370449728921e5a95e18bc2b31b8eb949d48422888c98af4
doc/rocq-runtime.boot/Boot/Env/index.html
Module Boot.Env
Source
Rocq runtime enviroment API.
This module provides functions for manipulation of Rocq's runtime enviroment, including the standard directories and support files.
This API is similar in spirit to findlib's or dune-sites API, see their documentation for more information:
- http://projects.camlcity.org/projects/dl/findlib-1.9.1/doc/ref-html/lib/index.html
- https://dune.readthedocs.io/en/stable/sites.html#sites
It is important that this library has a minimal dependency set.
The Rocq runtime enviroment needs to be properly initialized before use; we detail the rules below. It is recommended that applications requiring multiple accesses to the environment, do initialize it once and keep a ref to it. We don't forbid yet double initialization, (second time is a noop) but we may do so in the future. Rules for "coqlib" are:
- the
ROCQLIB
env variable will be used if set - if not, the existence of
theories/Init/Prelude.vo
will be checked, in the following order:
coqlibsuffix
given in configurecoqlib
given in configure
- if none of the above succeeds, the initialization will fail
- The
ROCQRUNTIMELIB
env variable is also used if set, if not, the location of the rocq-runtime files will be assumed to beROCQLIB/../rocq-runtime
, except ifROCQLIB/plugins
existsas in some developers layouts
, in which case we will setROCQRUNTIMELIB:=ROCQLIB
.
Note that set_coqlib
is used by some commands to process the -coqlib
option, as of now this sets both coqlib
and coqcorelib
; this part of the initialization will be eventually moved here.
The error handling policy of this module is simple for now: failing to initialize Rocq's env will produce a fatal error, and the application will exit with code 1. No error handling is thus required on the client yet.
This API is loosely inspired by Stdune.Path
, for now we keep it minimal, but at some point we may extend it.
Rocq runtime enviroment, including location of Rocq's stdlib
Internal, should be set automatically by passing cmdline args to init; note that this will set both coqlib
and corelib
for now.