Module Impargs
Implicit Arguments
val make_implicit_args : bool -> unitval make_strict_implicit_args : bool -> unitval make_strongly_strict_implicit_args : bool -> unitval make_reversible_pattern_implicit_args : bool -> unitval make_contextual_implicit_args : bool -> unitval make_maximal_implicit_args : bool -> unitval is_implicit_args : unit -> boolval is_strict_implicit_args : unit -> boolval is_strongly_strict_implicit_args : unit -> boolval is_reversible_pattern_implicit_args : unit -> boolval is_contextual_implicit_args : unit -> boolval is_maximal_implicit_args : unit -> boolval with_implicit_protection : ('a -> 'b) -> 'a -> 'b
...
type argument_position=|Conclusion|Hyp of inttype implicit_explanation=|DepRigid of argument_positionmeans that the implicit argument can be found by unification along a rigid path (we do not print the arguments of this kind if there is enough arguments to infer them)
|DepFlex of argument_positionmeans that the implicit argument can be found by unification along a collapsible path only (e.g. as x in (P x) where P is another argument) (we do (defensively) print the arguments of this kind)
|DepFlexAndRigid of argument_position * argument_positionmeans that the least argument from which the implicit argument can be inferred is following a collapsible path but there is a greater argument from where the implicit argument is inferable following a rigid path (useful to know how to print a partial application)
|Manualmeans the argument has been explicitly set as implicit.
We remember various information about why an argument is inferable as implicit
type implicit_status= (Names.Id.t * implicit_explanation * (maximal_insertion * force_inference)) optionNone= Not implicit
type implicit_side_conditiontype implicits_list= implicit_side_condition * implicit_status list
val is_status_implicit : implicit_status -> boolval is_inferable_implicit : bool -> int -> implicit_status -> boolval name_of_implicit : implicit_status -> Names.Id.tval maximal_insertion_of : implicit_status -> boolval force_inference_of : implicit_status -> boolval positions_of_implicits : implicits_list -> int list
type manual_implicits= (Names.Name.t * bool) option CAst.t list
val compute_implicits_with_manual : Environ.env -> Evd.evar_map -> EConstr.types -> bool -> manual_implicits -> implicit_status listval compute_implicits_names : Environ.env -> Evd.evar_map -> EConstr.types -> Names.Name.t list
Computation of implicits (done using the global environment).
val declare_var_implicits : Names.variable -> impl:Glob_term.binding_kind -> unitval declare_constant_implicits : Names.Constant.t -> unitval declare_mib_implicits : Names.MutInd.t -> unitval declare_implicits : bool -> Names.GlobRef.t -> unit
val declare_manual_implicits : bool -> Names.GlobRef.t -> ?enriching:bool -> manual_implicits -> unit
val maybe_declare_manual_implicits : bool -> Names.GlobRef.t -> ?enriching:bool -> manual_implicits -> unit
val set_implicits : bool -> Names.GlobRef.t -> implicit_kind list list -> unitset_implicits local ref lManual declaration of implicit arguments. `l` is a list of possible sequences of implicit statuses.
val implicits_of_global : Names.GlobRef.t -> implicits_list listval extract_impargs_data : implicits_list list -> ((int * int) option * implicit_status list) listval make_implicits_list : implicit_status list -> implicits_list listval drop_first_implicits : int -> implicits_list -> implicits_listval projection_implicits : Environ.env -> Names.Projection.t -> implicit_status list -> implicit_status listval select_impargs_size : int -> implicits_list list -> implicit_status listval select_stronger_impargs : implicits_list list -> implicit_status list