summaryrefslogtreecommitdiff
path: root/Source
diff options
context:
space:
mode:
authorGravatar wuestholz <unknown>2015-01-02 18:12:15 +0100
committerGravatar wuestholz <unknown>2015-01-02 18:12:15 +0100
commit83ce1429f2897d10e36ecbb49751429674302745 (patch)
tree4c0340f75ca9a64312df50e972c0ee2c08a4930e /Source
parentd3662f29ba04d5d36cce49bd90b937c0d3d29a44 (diff)
Added a test and a todo.
Diffstat (limited to 'Source')
-rw-r--r--Source/VCGeneration/Wlp.cs39
1 files changed, 24 insertions, 15 deletions
diff --git a/Source/VCGeneration/Wlp.cs b/Source/VCGeneration/Wlp.cs
index 24c36e3b..6f6326d1 100644
--- a/Source/VCGeneration/Wlp.cs
+++ b/Source/VCGeneration/Wlp.cs
@@ -109,18 +109,18 @@ namespace VC {
ctxt.Ctxt.BoogieExprTranslator.isPositiveContext = !ctxt.Ctxt.BoogieExprTranslator.isPositiveContext;
VCExprLetBinding LB = null;
- VCExpr A = null;
+ VCExpr VU = null;
if (ac.VerifiedUnder != null)
{
var V = gen.Variable(ctxt.FreshLetBindingName(), Microsoft.Boogie.Type.Bool);
LB = gen.LetBinding(V, C);
C = V;
- A = gen.ImpliesSimp(ctxt.Ctxt.BoogieExprTranslator.Translate(ac.VerifiedUnder), V);
+ VU = ctxt.Ctxt.BoogieExprTranslator.Translate(ac.VerifiedUnder);
}
+ VCExpr R = null;
if (CommandLineOptions.Clo.vcVariety == CommandLineOptions.VCVariety.Doomed) {
- var res = gen.Implies(C, N);
- return A != null ? gen.Let(gen.ImpliesSimp(A, res), LB) : res;
+ R = gen.Implies(C, N);
} else {
int id = ac.UniqueId;
if (ctxt.Label2absy != null) {
@@ -142,30 +142,39 @@ namespace VC {
Contract.Assert(false); throw new cce.UnreachableException(); // unexpected case
}
- // (MSchaef) Hack: This line might be useless, but at least it is not harmful
- // need to test it
- if (CommandLineOptions.Clo.vcVariety == CommandLineOptions.VCVariety.Doomed)
- return gen.Implies(C, N);
-
ctxt.AssertionCount++;
+
+ // TODO(wuestholz): Try to weaken the assertion instead of assuming the property that has already been verified:
+ // if (VU != null)
+ // {
+ // C = gen.OrSimp(VU, C);
+ // }
+
if (ctxt.ControlFlowVariableExpr == null) {
Contract.Assert(ctxt.Label2absy != null);
- var res = gen.AndSimp(gen.LabelNeg(cce.NonNull(id.ToString()), C), N);
- return A != null ? gen.Let(gen.ImpliesSimp(A, res), LB) : res;
+ R = gen.AndSimp(gen.LabelNeg(cce.NonNull(id.ToString()), C), N);
} else {
VCExpr controlFlowFunctionAppl = gen.ControlFlowFunctionApplication(ctxt.ControlFlowVariableExpr, gen.Integer(BigNum.FromInt(b.UniqueId)));
Contract.Assert(controlFlowFunctionAppl != null);
VCExpr assertFailure = gen.Eq(controlFlowFunctionAppl, gen.Integer(BigNum.FromInt(-ac.UniqueId)));
if (ctxt.Label2absy == null) {
- var res = gen.AndSimp(gen.Implies(assertFailure, C), N);
- return A != null ? gen.Let(gen.ImpliesSimp(A, res), LB) : res;
+ R = gen.AndSimp(gen.Implies(assertFailure, C), N);
} else {
- var res = gen.AndSimp(gen.LabelNeg(cce.NonNull(id.ToString()), gen.Implies(assertFailure, C)), N);
- return A != null ? gen.Let(gen.ImpliesSimp(A, res), LB) : res;
+ R = gen.AndSimp(gen.LabelNeg(cce.NonNull(id.ToString()), gen.Implies(assertFailure, C)), N);
}
}
}
+ if (VU != null)
+ {
+ R = gen.ImpliesSimp(gen.ImpliesSimp(VU, C), R);
+ }
+
+ if (LB != null)
+ {
+ R = gen.Let(R, LB);
+ }
+ return R;
} else if (cmd is AssumeCmd) {
AssumeCmd ac = (AssumeCmd)cmd;