]> matita.cs.unibo.it Git - helm.git/blob - helm/software/components/ng_refiner/nCicCoercion.mli
Preparing for 0.5.9 release.
[helm.git] / helm / software / components / ng_refiner / nCicCoercion.mli
1 (*
2     ||M||  This file is part of HELM, an Hypertextual, Electronic        
3     ||A||  Library of Mathematics, developed at the Computer Science     
4     ||T||  Department, University of Bologna, Italy.                     
5     ||I||                                                                
6     ||T||  HELM is free software; you can redistribute it and/or         
7     ||A||  modify it under the terms of the GNU General Public License   
8     \   /  version 2 or (at your option) any later version.      
9      \ /   This software is distributed as is, NO WARRANTY.     
10       V_______________________________________________________________ *)
11
12 (* $Id: nCicRefiner.mli 9227 2008-11-21 16:00:06Z tassi $ *)
13
14 type db
15
16 val set_convert_term:
17  (UriManager.uri -> Cic.term -> NCic.term * NCic.obj list) -> unit
18
19 class type g_status =
20  object
21   inherit NCicUnifHint.g_status
22   method coerc_db: db
23  end
24
25 class status :
26  object ('self)
27   inherit NCicUnifHint.status
28   inherit g_status
29   method coerc_db: db
30   method set_coerc_db: db -> 'self
31   method set_coercion_status: #g_status -> 'self
32  end
33
34 val empty_db: db
35
36 (* index (\x.c ?? x ??): A -> B
37    index_coercion db c A B \arity_left(c ??x??) \position(x,??x??) 
38 *)
39 val index_coercion: 
40   #status as 'status -> string ->
41    NCic.term -> NCic.term -> NCic.term -> int -> int -> 'status
42
43   (* gets the old imperative coercion DB (list format) *)
44 val index_old_db: CoercDb.coerc_db -> (#status as 'status) -> 'status
45
46 val look_for_coercion:
47     #status ->
48     NCic.metasenv -> NCic.substitution -> NCic.context -> 
49     (* inferred type, expected type *)
50     NCic.term -> NCic.term -> 
51       (* name, enriched metasenv, new term, its type, metavriable to
52        * be unified with the old term *)
53       (string * NCic.metasenv * NCic.term * NCic.term * NCic.term) list
54
55 (* returns (coercion,arity,arg) *)
56 val match_coercion:
57  #status -> metasenv:NCic.metasenv -> subst:NCic.substitution ->
58   context:NCic.context -> NCic.term -> (NCic.term * int * int) option
59
60 val generate_dot_file: #status -> Format.formatter -> unit