]> matita.cs.unibo.it Git - helm.git/blob - helm/software/components/library/coercDb.mli
fixed recursiveness check
[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 dump: unit -> coerc_db
46 val restore: coerc_db -> unit
47
48 (* src carr, tgt carr, uri, saturations, coerced position 
49  * invariant:
50  *   if the constant pointed by uri has n argments
51  *   n = coerced position + saturations + FunClass arity
52  *)
53
54 type saturations = int
55 type coerced_pos = int
56 type coercion_entry = 
57   coerc_carr * coerc_carr * UriManager.uri * saturations * coerced_pos
58 val add_coercion: coercion_entry -> unit
59 val remove_coercion: (coercion_entry -> bool) -> unit
60
61 val find_coercion: 
62   (coerc_carr * coerc_carr -> bool) -> (UriManager.uri * int) list 
63     
64 val is_a_coercion: Cic.term -> coercion_entry option