diff options
author | Unknown <qadeer@FAIZ-AHMED-FAIZ.redmond.corp.microsoft.com> | 2013-05-18 21:15:20 -0700 |
---|---|---|
committer | Unknown <qadeer@FAIZ-AHMED-FAIZ.redmond.corp.microsoft.com> | 2013-05-18 21:15:20 -0700 |
commit | 64d8963508ce048d00db3766f4ca597b792c1b95 (patch) | |
tree | 67801fe71cd2ceb7eb851833dd489751baa21ce2 /Test/og/linear-set.bpl | |
parent | 89b20adf23750478098578895fef9ca3b9170927 (diff) |
reworked the linear and og implementation based on available variables theory
Diffstat (limited to 'Test/og/linear-set.bpl')
-rw-r--r-- | Test/og/linear-set.bpl | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/Test/og/linear-set.bpl b/Test/og/linear-set.bpl index d188db3a..c2f792ef 100644 --- a/Test/og/linear-set.bpl +++ b/Test/og/linear-set.bpl @@ -19,6 +19,8 @@ var l: [X]bool; procedure Split({:linear "x"} xls: [X]bool) returns ({:linear "x"} xls1: [X]bool, {:linear "x"} xls2: [X]bool);
ensures xls == MapOr(xls1, xls2) && xls1 != None() && xls2 != None();
+procedure Allocate() returns ({:linear "tid"} xls: [X]bool);
+
procedure {:entrypoint} main({:linear "tid"} tidls': [X]bool, {:linear "x"} xls': [X]bool)
requires tidls' != None() && xls' == All();
{
@@ -28,18 +30,18 @@ requires tidls' != None() && xls' == All(); var {:linear "x"} xls1: [X]bool;
var {:linear "x"} xls2: [X]bool;
- havoc tidls, xls;
- assume tidls' == tidls && xls' == xls;
+ tidls := tidls';
+ xls := xls';
x := 42;
yield;
assert xls == All();
assert x == 42;
call xls1, xls2 := Split(xls);
- havoc lsChild;
+ call lsChild := Allocate();
assume (lsChild != None());
async call thread(lsChild, xls1);
- havoc lsChild;
+ call lsChild := Allocate();
assume (lsChild != None());
async call thread(lsChild, xls2);
}
@@ -50,8 +52,8 @@ requires tidls' != None() && xls' != None(); var {:linear "x"} xls: [X]bool;
var {:linear "tid"} tidls: [X]bool;
- havoc tidls, xls;
- assume tidls' == tidls && xls' == xls;
+ tidls := tidls';
+ xls := xls';
assume l == None();
l := tidls;
|