blob: d28732941d6b974a71b031e24ca6ff424a7d958c (
plain)
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
|
(*i $Id$ i*)
(*i*)
open Names
open Sign
open Term
open Environ
open Evd
open Rawterm
open Evarutil
(*i*)
type meta_map = (int * unsafe_judgment) list
type var_map = (identifier * unsafe_judgment) list
(* Generic call to the interpreter from rawconstr to constr, failing
unresolved holes in the rawterm cannot be instantiated.
In [understand_gen sigma env varmap metamap typopt raw],
sigma : initial set of existential variables (typically dependent subgoals)
varmap : partial subtitution of variables (used for the tactic language)
metamap : partial subtitution of meta (used for the tactic language)
typopt : is not None, this is the expected type for raw (used to define evars)
*)
val understand_gen :
'a evar_map -> env -> var_map -> meta_map
-> expected_type:(constr option) -> rawconstr -> constr
(* Generic call to the interpreter from rawconstr to constr, turning
unresolved holes into metas. Returns also the typing context of
these metas. Work as [understand_gen] for the rest. *)
val understand_gen_tcc :
'a evar_map -> env -> var_map -> meta_map
-> constr option -> rawconstr -> (int * constr) list * constr
(* Standard call to get a constr from a rawconstr, resolving implicit args *)
val understand : 'a evar_map -> env -> rawconstr -> constr
(* Idem but the rawconstr is intended to be a type *)
val understand_type : 'a evar_map -> env -> rawconstr -> constr
(* Idem but returns the judgment of the understood term *)
val understand_judgment : 'a evar_map -> env -> rawconstr -> unsafe_judgment
(* Idem but returns the judgment of the understood type *)
val understand_type_judgment : 'a evar_map -> env -> rawconstr
-> unsafe_type_judgment
(*i*)
(* Internal of Pretyping...
* Unused outside, but useful for debugging
*)
val pretype :
type_constraint -> env -> 'a evar_defs ->
(identifier * unsafe_judgment) list -> (int * unsafe_judgment) list ->
rawconstr -> unsafe_judgment
val pretype_type :
val_constraint -> env -> 'a evar_defs ->
(identifier * unsafe_judgment) list -> (int * unsafe_judgment) list ->
rawconstr -> unsafe_type_judgment
(*i*)
|