Section
Kernel implementation of sections.
val depth : 'a t -> int
Number of nested sections.
Open a new section with the provided universe polymorphic status. Sections can be nested, with the proviso that polymorphic sections cannot appear inside a monomorphic one. A custom data can be attached to this section, that will be returned by close_section
.
val close_section : 'a t -> 'a t option * section_entry list * Univ.ContextSet.t * 'a
Close the current section and returns the entries defined inside, the set of global monomorphic constraints added in this section, and the custom data provided at the opening of the section.
val push_local : Constr.named_declaration -> 'a t -> 'a t
Extend the current section with a local definition (cf. push_named).
val push_local_universe_context : Univ.UContext.t -> 'a t -> 'a t
Extend the current section with a local universe context. Assumes that the last opened section is polymorphic.
val push_constraints : Univ.ContextSet.t -> 'a t -> 'a t
Extend the current section with a global universe context. Assumes that the last opened section is monomorphic.
val push_global : Environ.env -> poly:bool -> section_entry -> 'a t -> 'a t
Push a global entry in this section.
val all_poly_univs : 'a t -> Univ.Level.t array
Returns all polymorphic universes, including those from previous sections. Earlier sections are earlier in the array.
NB: even if the array is empty there may be polymorphic constraints about monomorphic universes, which prevent declaring monomorphic globals.
val segment_of_constant : Names.Constant.t -> 'a t -> Cooking.cooking_info
Section segment at the time of the constant declaration
val segment_of_inductive : Names.MutInd.t -> 'a t -> Cooking.cooking_info
Section segment at the time of the inductive declaration
val is_in_section : Environ.env -> Names.GlobRef.t -> 'a t -> bool