else
false,ugraph
| (C.Appl l1, C.Appl l2) ->
+ let b, ugraph =
+ aux test_equality_only context (List.hd l1) (List.hd l2) ugraph
+ in
+ if not b then false, ugraph
+ else
(try
List.fold_right2
(fun x y (b,ugraph) ->
if b then
- aux test_equality_only context x y ugraph
+ aux true context x y ugraph
else
- false,ugraph) l1 l2 (true,ugraph)
+ false,ugraph) (List.tl l1) (List.tl l2) (true,ugraph)
with
Invalid_argument _ -> false,ugraph
)
let t2' = whd ?delta:(Some true) ?subst:(Some subst) context t2 in
debug t1' [t2'] "POSTWHD";
*)
-let rec convert_machines ugraph =
+let rec convert_machines test_equality_only ugraph =
function
[] -> true,ugraph
| ((k1,env1,ens1,h1,s1),(k2,env2,ens2,h2,s2))::tl ->
in
match problems with
None -> false,ugraph
- | Some problems -> convert_machines ugraph problems
+ | Some problems -> convert_machines true ugraph problems
else
res
in
- convert_machines ugraph
+ convert_machines test_equality_only ugraph
[R.reduce ~delta:true ~subst context (0,[],[],t1,[]),
R.reduce ~delta:true ~subst context (0,[],[],t2,[])]
(*prerr_endline ("POSTWH: " ^ CicPp.ppterm t1' ^ " <===> " ^ CicPp.ppterm t2');*)