diff --git a/Makefile b/Makefile index 82b9dee58d892b0b5917c9acb32cbe357acac460..a6dd21611c1f9049e547d3086168c9563adcc9c0 100644 --- a/Makefile +++ b/Makefile @@ -1,7 +1,7 @@ PACKAGES=oUnit zarith ocamlgraph str #-package lablgtk2 -OPTIONS=-tag annot -no-sanitize -tag debug -use-ocamlfind -cflags -w,+a-4-9 -cflags -warn-error,+5+10+8 -cflag -bin-annot -j 8 +OPTIONS=-tag annot -no-sanitize -tag debug -use-ocamlfind -cflags -w,+a-4-9 -cflags -warn-error,+5+10+8+12 -cflag -bin-annot -j 8 #OPTIONS += -cflags -warn-error,+a DIRECTORIES=src src/util src/inputlang/altergo src/inputlang/dimacs_cnf src/inputlang/smtlib2 tests src/cmd fuzz OCAMLBUILD=ocamlbuild \ diff --git a/src/bool.ml b/src/bool.ml index 3f92f44d7f0a37a25cc844c7b50807f765359fc6..544df1b495a3261045c3e5b2be03fef7b11b4d6f 100644 --- a/src/bool.ml +++ b/src/bool.ml @@ -183,7 +183,7 @@ module Th = struct | None -> raise (Found (cl,b)) ) l - let bcp d l absorbent = + let _bcp d l absorbent = try let res = IArray.fold (fun acc cl -> let cl = Delayed.find d cl in @@ -750,20 +750,26 @@ module ConClause = struct let s = get_con s t c2 in GRequested s - let propacl t age cl rcl = - match cl, rcl with - | _true, cl | cl, _true when Cl.equal _true cl_true -> + let propacl t _age clo rcl = + match clo, rcl with + | (_true, cl) when Cl.equal _true cl_true -> ComputeConflict.set_dec_cho t dom cl chobool cl; GRequested (Cl.M.singleton cl true) - | _false, cl | cl, _false when Cl.equal _false cl_false -> + | (cl, _true) when Cl.equal _true cl_true -> + ComputeConflict.set_dec_cho t dom cl chobool cl; + GRequested (Cl.M.singleton cl true) + | (_false, cl) when Cl.equal _false cl_false -> + ComputeConflict.set_dec_cho t dom cl chobool cl; + GRequested (Cl.M.singleton cl false) + | (cl, _false) when Cl.equal _false cl_false -> ComputeConflict.set_dec_cho t dom cl chobool cl; GRequested (Cl.M.singleton cl false) | _ -> - let eq = !mk_permanent_equality (cl,rcl) in + let eq = !mk_permanent_equality (clo,rcl) in ComputeConflict.set_dec_cho t dom eq chobool eq; GRequested (Cl.M.singleton eq true) - let propasem t age sem v cl = + let propasem t _age sem v cl = (** TODO ty bool if sem is bool? *) let eq = !mk_permanent_equality (cl,new_permanent sem v (Cl.ty cl)) in ComputeConflict.set_dec_cho t dom eq chobool eq; diff --git a/src/uninterp.ml b/src/uninterp.ml index a9385beeba6f8fa5d295f92cd7157e0a445aceb4..6ca39048c93343a3e72f706ff4c1c291d190905e 100644 --- a/src/uninterp.ml +++ b/src/uninterp.ml @@ -301,8 +301,12 @@ module ExpSubst = struct let fty = Cl.ty f in let gty = Cl.ty g in let deps = Deps.empty in + let rl = get_sem t sem v in + let ty = match rl with CRepr -> assert false (* get_sem *) + | CMerge (rcl,_,_,_) -> Cl.ty rcl in let deps = - Equality.GenEquality.sem_def t deps age (get_sem t sem v) in + (** TODO separate the first Merge(UF) from the others(GenEquality)? *) + Equality.GenEquality.sem t deps age sem v rl ty in let deps = Equality.GenEquality.repr t deps age f (get_cl_repr t f) fty in let deps =