(************************************************************************) (* v * The Coq Proof Assistant / The Coq Development Team *) (* evar -> evar_info -> evar_map val dom : evar_map -> evar list val map : evar_map -> evar -> evar_info val rmv : evar_map -> evar -> evar_map val remap : evar_map -> evar -> evar_info -> evar_map val in_dom : evar_map -> evar -> bool val to_list : evar_map -> (evar * evar_info) list val define : evar_map -> evar -> constr -> evar_map val is_evar : evar_map -> evar -> bool val is_defined : evar_map -> evar -> bool val evar_body : evar_info -> evar_body val evar_env : evar_info -> Environ.env val string_of_existential : evar -> string val existential_of_int : int -> evar (*s [existential_value sigma ev] raises [NotInstantiatedEvar] if [ev] has no body and [Not_found] if it does not exist in [sigma] *) exception NotInstantiatedEvar val existential_value : evar_map -> existential -> constr val existential_type : evar_map -> existential -> types val existential_opt_value : evar_map -> existential -> constr option (*************************) (* constr with holes *) type open_constr = evar_map * constr (*************************) (* The type constructor ['a sigma] adds an evar map to an object of type ['a] *) type 'a sigma = { it : 'a ; sigma : evar_map} val sig_it : 'a sigma -> 'a val sig_sig : 'a sigma -> evar_map (*************************) (* Meta map *) module Metaset : Set.S with type elt = metavariable val meta_exists : (metavariable -> bool) -> Metaset.t -> bool module Metamap : Map.S with type key = metavariable val metamap_in_dom : metavariable -> 'a Metamap.t -> bool val metamap_to_list : 'a Metamap.t -> (metavariable * 'a) list val metamap_inv : 'a Metamap.t -> 'a -> metavariable list type 'a freelisted = { rebus : 'a; freemetas : Metaset.t } val mk_freelisted : constr -> constr freelisted val map_fl : ('a -> 'b) -> 'a freelisted -> 'b freelisted type clbinding = | Cltyp of constr freelisted | Clval of constr freelisted * constr freelisted val map_clb : (constr -> constr) -> clbinding -> clbinding type meta_map = clbinding Metamap.t (*************************) (* Unification state *) type hole_kind = | ImplicitArg of global_reference * (int * identifier option) | BinderType of name | QuestionMark | CasesType | InternalHole | TomatchTypeParameter of inductive * int type conv_pb = | CONV | CUMUL type evar_defs val evars_of : evar_defs -> evar_map val metas_of : evar_defs -> meta_map val mk_evar_defs : evar_map * meta_map -> evar_defs (* the same with empty meta map: *) val create_evar_defs : evar_map -> evar_defs val evars_reset_evd : evar_map -> evar_defs -> evar_defs val reset_evd : evar_map * meta_map -> evar_defs -> evar_defs val evar_source : existential_key -> evar_defs -> loc * hole_kind type evar_constraint = conv_pb * constr * constr val add_conv_pb : evar_constraint -> evar_defs -> evar_defs val evar_declare : named_context -> evar -> types -> ?src:loc * hole_kind -> evar_defs -> evar_defs val evar_define : evar -> constr -> evar_defs -> evar_defs val is_defined_evar : evar_defs -> existential -> bool val is_undefined_evar : evar_defs -> constr -> bool val get_conv_pbs : evar_defs -> (evar_constraint -> bool) -> evar_defs * evar_constraint list val meta_defined : evar_defs -> metavariable -> bool val meta_fvalue : evar_defs -> metavariable -> constr freelisted val meta_ftype : evar_defs -> metavariable -> constr freelisted val meta_declare : metavariable -> types -> evar_defs -> evar_defs val meta_assign : metavariable -> constr -> evar_defs -> evar_defs val meta_merge : evar_defs -> evar_defs -> evar_defs