1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295
|
(************************************************************************)
(* * The Rocq Prover / The Rocq Development Team *)
(* v * Copyright INRIA, CNRS and contributors *)
(* <O___,, * (see version control and CREDITS file for authors & dates) *)
(* \VV/ **************************************************************)
(* // * This file is distributed under the terms of the *)
(* * GNU Lesser General Public License Version 2.1 *)
(* * (see LICENSE file for the text of the license) *)
(************************************************************************)
(** This file defines universe unification states which are part of evarmaps.
Most of the API below is reexported in {!Evd}. Consider using higher-level
primitives when needed. *)
open Names
open Univ
open Sorts
type universes_entry =
| Monomorphic_entry of Univ.ContextSet.t
| Polymorphic_entry of UVars.UContext.t
exception UniversesDiffer
type t
(** Type of universe unification states. They allow the incremental building of
universe constraints during an interactive proof. *)
(** {5 Constructors} *)
(** Different ways to create a new universe state *)
val empty : t
val make : qualities:QVar.Set.t -> UGraph.t -> t
[@@ocaml.deprecated "(8.13) Use from_env"]
val make_with_initial_binders : qualities:QVar.Set.t -> UGraph.t -> lident list -> t
[@@ocaml.deprecated "(8.13) Use from_env"]
val from_env : ?binders:lident list -> Environ.env -> t
(** Main entry point at the beginning of a declaration declaring the
binding names as rigid universes. *)
val of_names : (UnivNames.universe_binders * UnivNames.rev_binders) -> t
(** Main entry point when only names matter, e.g. for printing. *)
val of_context_set : UnivGen.sort_context_set -> t
(** Main entry point when starting from the instance of a global
reference, e.g. when building a scheme. *)
(** Misc *)
val is_empty : t -> bool
val union : t -> t -> t
(** {5 Projections and other destructors} *)
val context_set : t -> Univ.ContextSet.t
(** The local context of the state, i.e. a set of bound variables together
with their associated constraints. *)
val sort_context_set : t -> UnivGen.sort_context_set
type universe_opt_subst = UnivFlex.t
(* Reexport because UnivSubst is private *)
val subst : t -> UnivFlex.t
(** The local universes that are unification variables *)
val nf_universes : t -> Constr.t -> Constr.t
(** Apply the local substitution [subst] *)
val ugraph : t -> UGraph.t
(** The current graph extended with the local constraints *)
val is_algebraic : Level.t -> t -> bool
(** Can this universe be instantiated with an algebraic
universe (ie it appears in inferred types only). *)
val constraints : t -> Univ.Constraints.t
(** Shorthand for {!context_set} composed with {!ContextSet.constraints}. *)
val context : t -> UVars.UContext.t
(** Shorthand for {!context_set} with {!Context_set.to_context}. *)
type named_universes_entry = universes_entry * UnivNames.universe_binders
val univ_entry : poly:bool -> t -> named_universes_entry
(** Pick from {!context} or {!context_set} based on [poly]. *)
val universe_binders : t -> UnivNames.universe_binders
(** Return local names of universes. *)
val compute_instance_binders : t -> UVars.Instance.t -> UVars.bound_names
val nf_qvar : t -> QVar.t -> Quality.t
(** Returns the normal form of the sort variable. *)
val nf_quality : t -> Quality.t -> Quality.t
val nf_instance : t -> UVars.Instance.t -> UVars.Instance.t
val nf_level : t -> Level.t -> Level.t
(** Must not be allowed to be algebraic *)
val nf_universe : t -> Universe.t -> Universe.t
val nf_sort : t -> Sorts.t -> Sorts.t
(** Returns the normal form of the sort. *)
val nf_relevance : t -> relevance -> relevance
(** Returns the normal form of the relevance. *)
(** {5 Constraints handling} *)
val add_constraints : t -> Univ.Constraints.t -> t
(**
@raise UniversesDiffer when universes differ
*)
val add_universe_constraints : t -> UnivProblem.Set.t -> t
(**
@raise UniversesDiffer when universes differ
*)
val check_qconstraints : t -> QConstraints.t -> bool
val check_universe_constraints : t -> UnivProblem.Set.t -> bool
val add_quconstraints : t -> QUConstraints.t -> t
(** {5 Names} *)
val quality_of_name : t -> Id.t -> Sorts.QVar.t
val universe_of_name : t -> Id.t -> Univ.Level.t
(** Retrieve the universe associated to the name. *)
val name_level : Univ.Level.t -> Id.t -> t -> t
(** Gives a name to the level (making it a binder).
Asserts the name is not already used by a level *)
(** {5 Unification} *)
(** [restrict_universe_context (univs,csts) keep] restricts [univs] to
the universes in [keep]. The constraints [csts] are adjusted so
that transitive constraints between remaining universes (those in
[keep] and those not in [univs]) are preserved. *)
val restrict_universe_context : ContextSet.t -> Level.Set.t -> ContextSet.t
(** [restrict uctx ctx] restricts the local universes of [uctx] to
[ctx] extended by local named universes and side effect universes
(from [demote_seff_univs]). Transitive constraints between retained
universes are preserved. *)
val restrict : t -> Univ.Level.Set.t -> t
(** [restrict_even_binders uctx ctx] restricts the local universes of [uctx] to
[ctx] extended by side effect universes
(from [demote_seff_univs]). Transitive constraints between retained
universes are preserved. *)
val restrict_even_binders : t -> Univ.Level.Set.t -> t
type rigid =
| UnivRigid
| UnivFlexible of bool (** Is substitution by an algebraic ok? *)
val univ_rigid : rigid
val univ_flexible : rigid
val univ_flexible_alg : rigid
val merge : ?loc:Loc.t -> sideff:bool -> rigid -> t -> Univ.ContextSet.t -> t
val merge_sort_variables : ?loc:Loc.t -> sideff:bool -> t -> QVar.Set.t -> t
val merge_sort_context : ?loc:Loc.t -> sideff:bool -> rigid -> t -> UnivGen.sort_context_set -> t
val demote_global_univs : Univ.ContextSet.t -> t -> t
(** After declaring global universes, call this if you want to keep using the UState.
Removes from the uctx_local part of the UState the universes
that are present in the input constraint set (supposedly the global ones),
and adds any new universes and constraints to the UGraph part of the UState.
*)
val demote_global_univ_entry : universes_entry -> t -> t
(** After declaring a global, call this with its universe entry
if you want to keep using the ustate instead of restarting it
with [from_env (Global.env())] or using the slow
[update_sigma_univs _ (Environ.universes (Global/env()))].
Equivalently:
- In the monomorphic case, call [demote_global_univs] on the contextset.
- In the polymorphic case, do nothing.
*)
val emit_side_effects : Safe_typing.private_constants -> t -> t
(** Calls [demote_global_univs] for the private constant universes. *)
val new_sort_variable : ?loc:Loc.t -> ?name:Id.t -> t -> t * QVar.t
(** Declare a new local sort. *)
val new_univ_variable : ?loc:Loc.t -> rigid -> Id.t option -> t -> t * Univ.Level.t
(** Declare a new local universe; use rigid if a global or bound
universe; use flexible for a universe existential variable; use
univ_flexible_alg for a universe existential variable allowed to
be instantiated with an algebraic universe *)
val add_forgotten_univ : t -> Univ.Level.t -> t
(** Don't use this, it only exists for funind *)
val make_nonalgebraic_variable : t -> Univ.Level.t -> t
(** cf UnivFlex *)
val make_flexible_nonalgebraic : t -> t
(** cf UnivFlex *)
val normalize_variables : t -> t
val constrain_variables : Univ.Level.Set.t -> t -> t
val fix_undefined_variables : t -> t
(** cf UnivFlex *)
(** Universe minimization *)
val minimize : t -> t
val collapse_above_prop_sort_variables : to_prop:bool -> t -> t
val collapse_sort_variables : ?except:QVar.Set.t -> t -> t
type ('a, 'b, 'c) gen_universe_decl = {
univdecl_qualities : 'a;
univdecl_extensible_qualities : bool;
univdecl_instance : 'b; (* Declared universes *)
univdecl_extensible_instance : bool; (* Can new universes be added *)
univdecl_constraints : 'c; (* Declared constraints *)
univdecl_extensible_constraints : bool (* Can new constraints be added *) }
type universe_decl =
(QVar.t list, Level.t list, Univ.Constraints.t) gen_universe_decl
val default_univ_decl : universe_decl
(** [check_univ_decl ctx decl]
If non extensible in [decl], check that the local universes (resp.
universe constraints) in [ctx] are implied by [decl].
Return a [universes_entry] containing the local
universes of [ctx] and their constraints.
When polymorphic, the universes corresponding to
[decl.univdecl_instance] come first in the order defined by that
list. *)
val check_univ_decl : poly:bool -> t -> universe_decl -> named_universes_entry
val check_univ_decl_rev : t -> universe_decl -> t * UVars.UContext.t
val check_uctx_impl : fail:(Pp.t -> unit) -> t -> t -> unit
val check_mono_univ_decl : t -> universe_decl -> Univ.ContextSet.t
val check_template_univ_decl : t -> template_qvars:QVar.Set.t -> universe_decl -> Univ.ContextSet.t
(** {5 TODO: Document me} *)
val update_sigma_univs : t -> UGraph.t -> t
(** {5 Pretty-printing} *)
val pr_uctx_level : t -> Univ.Level.t -> Pp.t
val pr_uctx_qvar : t -> Sorts.QVar.t -> Pp.t
val qualid_of_level : t -> Univ.Level.t -> Libnames.qualid option
(** Only looks in the local names, not in the nametab. *)
val id_of_level : t -> Univ.Level.t -> Id.t option
val id_of_qvar : t -> Sorts.QVar.t -> Id.t option
val is_rigid_qvar : t -> Sorts.QVar.t -> bool
val pr_weak : (Univ.Level.t -> Pp.t) -> t -> Pp.t
val pr : t -> Pp.t
val pr_sort_opt_subst : t -> Pp.t
module Internal :
sig
val reboot : Environ.env -> t -> t
(** Madness-inducing hack dedicated to the handling of universes of Program.
DO NOT USE OUTSIDE OF DEDICATED AREA. *)
end
|