]> matita.cs.unibo.it Git - helm.git/blob - helm/software/components/library/coercDb.mli
select honors the substitution
[helm.git] / helm / software / components / library / coercDb.mli
1 (* Copyright (C) 2000, HELM Team.
2  * 
3  * This file is part of HELM, an Hypertextual, Electronic
4  * Library of Mathematics, developed at the Computer Science
5  * Department, University of Bologna, Italy.
6  * 
7  * HELM is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License
9  * as published by the Free Software Foundation; either version 2
10  * of the License, or (at your option) any later version.
11  * 
12  * HELM is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with HELM; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
20  * MA  02111-1307, USA.
21  * 
22  * For details, see the HELM World-Wide-Web page,
23  * http://cs.unibo.it/helm/.
24  *)
25
26
27 type coerc_carr = private 
28   | Uri of UriManager.uri (* const, mutind, mutconstr *)
29   | Sort of Cic.sort (* Prop, Set, Type *) 
30   | Fun of int
31   | Dead
32 ;;
33   
34 val eq_carr: ?exact:bool -> coerc_carr -> coerc_carr -> bool
35 val string_of_carr: coerc_carr -> string
36
37 (* takes a term in whnf ~delta:false and a desired ariety *)
38 val coerc_carr_of_term: Cic.term -> int -> coerc_carr 
39
40 val to_list:
41   unit -> 
42     (coerc_carr * coerc_carr * (UriManager.uri * int * int) list) list
43
44 type coerc_db
45 val empty_coerc_db : coerc_db
46 val dump: unit -> coerc_db
47 val restore: coerc_db -> unit
48
49 (* src carr, tgt carr, uri, saturations, coerced position 
50  * invariant:
51  *   if the constant pointed by uri has n argments
52  *   n = coerced position + saturations + FunClass arity
53  *)
54
55 type saturations = int
56 type coerced_pos = int
57 type coercion_entry = 
58   coerc_carr * coerc_carr * UriManager.uri * saturations * coerced_pos
59 val add_coercion: coercion_entry -> unit
60 val remove_coercion: (coercion_entry -> bool) -> unit
61
62 val find_coercion: 
63   (coerc_carr * coerc_carr -> bool) -> (UriManager.uri * int) list 
64     
65 val is_a_coercion: Cic.term -> coercion_entry option
66
67 val prefer: UriManager.uri -> unit