package coq-core

  1. Overview
  2. Docs
The Coq Proof Assistant -- Core Binaries and Tools

Install

dune-project
 Dependency

Authors

Maintainers

Sources

coq-8.19.1.tar.gz
md5=13d2793fc6413aac5168822313e4864e
sha512=ec8379df34ba6e72bcf0218c66fef248b0e4c5c436fb3f2d7dd83a2c5f349dd0874a67484fcf9c0df3e5d5937d7ae2b2a79274725595b4b0065a381f70769b42

doc/coq-core.kernel/Safe_typing/index.html

Module Safe_typingSource

Sourcetype vodigest =
  1. | Dvo_or_vi of Digest.t
  2. | Dvivo of Digest.t * Digest.t
Sourceval digest_match : actual:vodigest -> required:vodigest -> bool
Safe environments

Since we are now able to type terms, we can define an abstract type of safe environments, where objects are typed before being added.

We also provide functionality for modules : start_module, end_module, etc.

Sourcetype safe_environment
Sourcetype section_data
Sourceval empty_environment : safe_environment
Sourceval env_of_safe_env : safe_environment -> Environ.env
Sourceval sections_of_safe_env : safe_environment -> section_data Section.t option
Sourceval structure_body_of_safe_env : safe_environment -> Declarations.structure_body

The safe_environment state monad

Sourcetype safe_transformer0 = safe_environment -> safe_environment
Sourcetype 'a safe_transformer = safe_environment -> 'a * safe_environment
Stm machinery
Sourcetype private_constants
Sourceval empty_private_constants : private_constants
Sourceval is_empty_private_constants : private_constants -> bool

concat_private e1 e2 adds the constants of e1 to e2, i.e. constants in e1 must be more recent than those of e2.

Sourceval push_private_constants : Environ.env -> private_constants -> Environ.env

Push the constants in the environment if not already there.

Sourceval universes_of_private : private_constants -> Univ.ContextSet.t
Sourceval is_curmod_library : safe_environment -> bool
Sourceval is_joined_environment : safe_environment -> bool

Enriching a safe environment

Insertion of global axioms or definitions

Sourcetype global_declaration =
  1. | ConstantEntry : Entries.constant_entry -> global_declaration
  2. | OpaqueEntry : unit Entries.opaque_entry -> global_declaration
Sourcetype exported_opaque
Sourcetype exported_private_constant = Names.Constant.t * exported_opaque option

returns the main constant

Similar to add_constant but also returns a certificate

Delayed proofs
Sourcetype opaque_certificate

Witness that a delayed Qed hole has a proof. This datatype is marshallable but care must be taken to marshal it at the same time as the environment it is referring to, since fill_opaque relies on a shared pointer between the environment and the certificate.

Check that the provided proof is correct for the corresponding handle. This does not modify the environment. Call fill_opaque below for that.

Given an already checked proof for an opaque hole, actually fill it with the proof. This might fail if the current set of global universes is inconsistent with the one at the time of the call to check_opaque. Precondition: the underlying handle must exist and must not have been filled.

Sourceval is_filled_opaque : Opaqueproof.opaque_handle -> safe_environment -> bool

Check whether a handle was filled. It assumes that the handle was introduced in the opaque table and throws an anomaly otherwise.

Get the proof term that was checked by the kernel.

Inductive blocks

Adding an inductive type

Adding a module or a module type

Adding universe constraints

Sourceval push_context_set : strict:bool -> Univ.ContextSet.t -> safe_transformer0
Sourceval set_impredicative_set : bool -> safe_transformer0

Setting the type theory flavor

Sourceval set_indices_matter : bool -> safe_transformer0
Sourceval set_share_reduction : bool -> safe_transformer0
Sourceval set_check_guarded : bool -> safe_transformer0
Sourceval set_check_positive : bool -> safe_transformer0
Sourceval set_check_universes : bool -> safe_transformer0
Sourceval set_VM : bool -> safe_transformer0
Sourceval set_native_compiler : bool -> safe_transformer0
Sourceval set_allow_sprop : bool -> safe_transformer0
Interactive section functions
Sourceval open_section : safe_transformer0
Sourceval close_section : safe_transformer0
Sourceval sections_are_opened : safe_environment -> bool

Insertion of local declarations (Local or Variables)

Sourceval push_named_assum : (Names.Id.t * Constr.types) -> safe_transformer0
Sourceval push_section_context : UVars.UContext.t -> safe_transformer0

Add local universes to a polymorphic section

Interactive module functions
Sourceval module_num_parameters : safe_environment -> int list

returns the number of module (type) parameters following the nested module structure. The inner module (type) comes first in the list.

Sourceval module_is_modtype : safe_environment -> bool list

returns true if the module is a module type following the nested module structure. The inner module (type) comes first in the list. true means a module type, false a regular module

Sourceval allow_delayed_constants : bool ref

Traditional mode: check at end of module that no future was created.

The optional result type is given without its functorial part

Sourceval current_modpath : safe_environment -> Names.ModPath.t
Sourceval current_dirpath : safe_environment -> Names.DirPath.t
Libraries : loading and saving compilation units
Sourcetype compiled_library
Sourceval univs_of_library : compiled_library -> Univ.ContextSet.t
Safe typing judgments
Sourcetype judgment = private {
  1. jdg_env : safe_environment;
  2. jdg_val : Constr.constr;
  3. jdg_type : Constr.types;
}

The safe typing of a term returns a typing judgment.

Queries
Sourceval exists_objlabel : Names.Label.t -> safe_environment -> bool
Sourceval constant_of_delta_kn_senv : safe_environment -> Names.KerName.t -> Names.Constant.t
Sourceval mind_of_delta_kn_senv : safe_environment -> Names.KerName.t -> Names.MutInd.t
Retroknowledge / Native compiler
Sourceval register_inline : Names.Constant.t -> safe_transformer0