aboutsummaryrefslogtreecommitdiffhomepage
path: root/pretyping/pretyping.mli
blob: d07b83ebac643057f16dbf1f9ab5f8258ed1fa43 (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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
(************************************************************************)
(*  v      *   The Coq Proof Assistant  /  The Coq Development Team     *)
(* <O___,, * CNRS-Ecole Polytechnique-INRIA Futurs-Universite Paris Sud *)
(*   \VV/  **************************************************************)
(*    //   *      This file is distributed under the terms of the       *)
(*         *       GNU Lesser General Public License Version 2.1        *)
(************************************************************************)

(*i $Id$ i*)

(*i*)
open Names
open Sign
open Term
open Environ
open Evd
open Rawterm
open Evarutil
(*i*)

type typing_constraint = OfType of types option | IsType

(* Generic call to the interpreter from rawconstr to open_constr, leaving
   unresolved holes as evars and returning the typing contexts of
   these evars. Work as [understand_gen] for the rest. *)

val understand_tcc :
  evar_map -> env -> ?expected_type:types -> rawconstr -> open_constr

(* More general entry point with evars from ltac *)

type var_map = (identifier * unsafe_judgment) list
type unbound_ltac_var_map = (identifier * identifier option) list

(* Generic call to the interpreter from rawconstr to constr, failing
   unresolved holes in the rawterm cannot be instantiated.

   In [understand_ltac sigma env ltac_env constraint c],

   sigma : initial set of existential variables (typically dependent subgoals)
   ltac_env : partial substitution of variables (used for the tactic language)
   constraint : tell if interpreted as a possibly constrained term or a type 
*)

val understand_ltac :
  evar_map -> env -> var_map * unbound_ltac_var_map ->
    typing_constraint -> rawconstr -> evar_defs * constr

(* Standard call to get a constr from a rawconstr, resolving implicit args *)

val understand : evar_map -> env -> ?expected_type:Term.types ->
  rawconstr -> constr

(* Idem but the rawconstr is intended to be a type *)

val understand_type : evar_map -> env -> rawconstr -> constr

(* A generalization of the two previous case *)

val understand_gen : typing_constraint -> evar_map -> env -> 
  rawconstr -> constr

(* Idem but returns the judgment of the understood term *)

val understand_judgment : evar_map -> env -> rawconstr -> unsafe_judgment

(* To embed constr in rawconstr *)

val constr_in : constr -> Dyn.t
val constr_out : Dyn.t -> constr

(*i*)
(* Internal of Pretyping...
 * Unused outside, but useful for debugging
 *)
val pretype : 
  type_constraint -> env -> evar_defs ref -> 
    var_map * (identifier * identifier option) list ->
    rawconstr -> unsafe_judgment

val pretype_type : 
  val_constraint -> env -> evar_defs ref ->
    var_map * (identifier * identifier option) list ->
    rawconstr -> unsafe_type_judgment
(*i*)

val interp_sort : rawsort -> sorts

val interp_elimination_sort : rawsort -> sorts_family