Opaqueproof
This module implements the handling of opaque proof terms. Opaque proof terms are special since:
opaque
proof terms holds an index into an opaque table.type 'a delayed_universes =
| PrivateMonomorphic of 'a | |
| PrivatePolymorphic of Univ.ContextSet.t | (* local constraints *) |
val empty_opaquetab : opaquetab
val create : Names.DirPath.t -> opaquetab -> opaque * opaquetab
type opaque_proofterm = Constr.t * unit delayed_universes
module HandleMap : CSig.MapS with type key = opaque_handle
Opaque terms are indexed by their library dirpath and an integer index. The two functions above activate this indirect storage, by telling how to retrieve terms.
val subst_opaque : Mod_subst.substitution -> opaque -> opaque
val discharge_opaque : Cooking.cooking_info -> opaque -> opaque
val repr_handle : opaque_handle -> int
val mem_handle : opaque_handle -> opaquetab -> bool
val repr : opaque -> Mod_subst.substitution list * Cooking.cooking_info list * Names.DirPath.t * opaque_handle