]> matita.cs.unibo.it Git - helm.git/blob - helm/software/components/ng_refiner/nCicUnification.mli
c442306d7a9c4517d3e363ca9a6d25a4d7923af3
[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 val delift_type_wrt_terms:
36   #NRstatus.status -> 
37   NCic.metasenv -> NCic.substitution -> NCic.context -> 
38   NCic.term -> NCic.term list ->
39    NCic.metasenv * NCic.substitution * NCic.term
40