]> matita.cs.unibo.it Git - helm.git/commitdiff
dded missing catch for coercions
authorEnrico Tassi <enrico.tassi@inria.fr>
Mon, 14 Nov 2005 19:52:24 +0000 (19:52 +0000)
committerEnrico Tassi <enrico.tassi@inria.fr>
Mon, 14 Nov 2005 19:52:24 +0000 (19:52 +0000)
helm/ocaml/cic_unification/cicUnification.ml
helm/ocaml/cic_unification/coercGraph.ml

index ea0353182fee037aa0e04a43908705cd81358be3..9a87bc51bba07e6493a4666ae494a0fdce006a45 100644 (file)
@@ -594,11 +594,11 @@ debug_print (lazy ("restringo Meta n." ^ (string_of_int n) ^ "on variable n." ^
        if t1 = t2 then
          subst, metasenv,ugraph
        else
-        raise (UnificationFailure (lazy "6.2"))
-          (* (sprintf
+        raise (UnificationFailure (lazy 
+           (sprintf
              "Can't unify %s with %s because they are not convertible"
              (CicMetaSubst.ppterm subst t1) 
-             (CicMetaSubst.ppterm subst t2))) *)
+             (CicMetaSubst.ppterm subst t2))))
    | (C.Appl (C.Meta(i,l)::args),t2) when not(exists_a_meta args) ->
        let subst,metasenv,beta_expanded,ugraph1 =
          beta_expand_many 
index 2e69c648657646867879bebbdafd49148ea7212c..b3bc8d8b0e7ba5b94284102bfc4a68c9db1941bb 100644 (file)
@@ -67,13 +67,19 @@ let look_for_coercion src tgt =
  * (source, list of coercions to follow, target)
  *)
 let get_closure_coercions src tgt uri coercions =
+  let eq_carr s t = 
+    try
+      CoercDb.eq_carr s t
+    with
+    | CoercDb.EqCarrNotImplemented _ | CoercDb.EqCarrOnNonMetaClosed -> false
+  in
   match src,tgt with
   | CoercDb.Uri _, CoercDb.Uri _ ->
       let c_from_tgt = 
-        List.filter (fun (f,_,_) -> CoercDb.eq_carr f tgt) coercions 
+        List.filter (fun (f,_,_) -> eq_carr f tgt) coercions 
       in
       let c_to_src = 
-        List.filter (fun (_,t,_) -> CoercDb.eq_carr t src) coercions 
+        List.filter (fun (_,t,_) -> eq_carr t src) coercions 
       in
         (List.map (fun (_,t,u) -> src,[uri; u],t) c_from_tgt) @
         (List.map (fun (s,_,u) -> s,[u; uri],tgt) c_to_src) @