]> matita.cs.unibo.it Git - helm.git/blob - helm/software/components/ng_refiner/nCicUnification.mli
891c0738ecb9d9ee7b8e412c88526977918c562b
[helm.git] / helm / software / components / ng_refiner / nCicUnification.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$ *)
13
14 exception UnificationFailure of string Lazy.t;;
15 exception Uncertain of string Lazy.t;;
16 exception AssertFailure of string Lazy.t;;
17
18 val set_refiner_typeof:
19  (NRstatus.status ->
20    ?localise:(NCic.term -> Stdpp.location) ->
21    NCic.metasenv -> NCic.substitution -> NCic.context ->
22    NCic.term -> NCic.term option -> (* term, expected type *)
23      NCic.metasenv * NCic.substitution * NCic.term * NCic.term) -> unit
24
25 val unify :
26   #NRstatus.status ->
27   ?test_eq_only:bool -> (* default: false *)
28   NCic.metasenv -> NCic.substitution -> NCic.context -> 
29   NCic.term -> NCic.term ->
30    NCic.metasenv * NCic.substitution
31
32 (* this should be moved elsewhere *)
33 val fix_sorts: NCic.term -> NCic.term
34
35 (* 
36 exception UnificationFailure of string Lazy.t;;
37 exception Uncertain of string Lazy.t;;
38 exception AssertFailure of string Lazy.t;;
39
40 (* fo_unif metasenv context t1 t2                *)
41 (* unifies [t1] and [t2] in a context [context]. *)
42 (* Only the metavariables declared in [metasenv] *)
43 (* can be used in [t1] and [t2].                 *)
44 (* The returned substitution can be directly     *)
45 (* withouth first unwinding it.                  *)
46 val fo_unif :
47   Cic.metasenv -> Cic.context -> 
48     Cic.term -> Cic.term -> CicUniv.universe_graph -> 
49       Cic.substitution * Cic.metasenv * CicUniv.universe_graph
50
51 (* fo_unif_subst metasenv subst context t1 t2    *)
52 (* unifies [t1] and [t2] in a context [context]  *)
53 (* and with [subst] as the current substitution  *)
54 (* (i.e. unifies ([subst] [t1]) and              *)
55 (* ([subst] [t2]) in a context                   *)
56 (* ([subst] [context]) using the metasenv        *)
57 (* ([subst] [metasenv])                          *)
58 (* Only the metavariables declared in [metasenv] *)
59 (* can be used in [t1] and [t2].                 *)
60 (* [subst] and the substitution returned are not *)
61 (* unwinded.                                     *)
62 (*CSC: fare un tipo unione Unwinded o ToUnwind e fare gestire la
63  cosa all'apply_subst!!!*)
64 val fo_unif_subst :
65   Cic.substitution -> Cic.context -> Cic.metasenv -> 
66     Cic.term -> Cic.term -> CicUniv.universe_graph ->
67       Cic.substitution * Cic.metasenv * CicUniv.universe_graph
68
69       *)