summaryrefslogtreecommitdiff
path: root/pretyping/coercion.mli
blob: 6cfd958b4636dff26850e7ca0999fa11f2716a9b (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
(************************************************************************)
(*         *   The Coq Proof Assistant / The Coq Development Team       *)
(*  v      *   INRIA, CNRS and contributors - Copyright 1999-2018       *)
(* <O___,, *       (see CREDITS file for the list of authors)           *)
(*   \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)         *)
(************************************************************************)

open Evd
open Names
open Environ
open EConstr
open Glob_term

(** {6 Coercions. } *)

(** [inh_app_fun resolve_tc env isevars j] coerces [j] to a function; i.e. it
    inserts a coercion into [j], if needed, in such a way it gets as
    type a product; it returns [j] if no coercion is applicable.
    resolve_tc=false disables resolving type classes (as the last
    resort before failing) *)
val inh_app_fun : bool ->
  env -> evar_map -> unsafe_judgment -> evar_map * unsafe_judgment

(** [inh_coerce_to_sort env isevars j] coerces [j] to a type; i.e. it
    inserts a coercion into [j], if needed, in such a way it gets as
    type a sort; it fails if no coercion is applicable *)
val inh_coerce_to_sort : ?loc:Loc.t ->
  env -> evar_map -> unsafe_judgment -> evar_map * unsafe_type_judgment

(** [inh_coerce_to_base env isevars j] coerces [j] to its base type; i.e. it
    inserts a coercion into [j], if needed, in such a way it gets as
    type its base type (the notion depends on the coercion system) *)
val inh_coerce_to_base : ?loc:Loc.t ->
  env -> evar_map -> unsafe_judgment -> evar_map * unsafe_judgment

(** [inh_coerce_to_prod env isevars t] coerces [t] to a product type *)
val inh_coerce_to_prod : ?loc:Loc.t ->
  env -> evar_map -> types -> evar_map * types

(** [inh_conv_coerce_to resolve_tc Loc.t env isevars j t] coerces [j] to an 
    object of type [t]; i.e. it inserts a coercion into [j], if needed, in such
    a way [t] and [j.uj_type] are convertible; it fails if no coercion is
    applicable. resolve_tc=false disables resolving type classes (as the last
    resort before failing) *)
val inh_conv_coerce_to : ?loc:Loc.t -> bool ->
  env -> evar_map -> unsafe_judgment -> types -> evar_map * unsafe_judgment

val inh_conv_coerce_rigid_to : ?loc:Loc.t -> bool ->
  env -> evar_map -> unsafe_judgment -> types -> evar_map * unsafe_judgment

(** [inh_conv_coerces_to loc env isevars t t'] checks if an object of type [t]
    is coercible to an object of type [t'] adding evar constraints if needed;
    it fails if no coercion exists *)
val inh_conv_coerces_to : ?loc:Loc.t ->
  env -> evar_map -> types -> types -> evar_map

(** [inh_pattern_coerce_to loc env isevars pat ind1 ind2] coerces the Cases
    pattern [pat] typed in [ind1] into a pattern typed in [ind2];
    raises [Not_found] if no coercion found *)
val inh_pattern_coerce_to :
  ?loc:Loc.t -> env -> cases_pattern -> inductive -> inductive -> cases_pattern