summaryrefslogtreecommitdiff
path: root/Test/og/linear-set2.bpl
diff options
context:
space:
mode:
authorGravatar qadeer <unknown>2014-11-14 22:18:15 -0800
committerGravatar qadeer <unknown>2014-11-14 22:18:15 -0800
commit72d74c23e9c5cc1903f2646af6a7d778cfde53f3 (patch)
tree42b738427237ff44692051f028fb92a427c3cd1b /Test/og/linear-set2.bpl
parent0339351e985c455e7ecf290be54aa5361fe7ae8f (diff)
renamed :phase to :layer
Diffstat (limited to 'Test/og/linear-set2.bpl')
-rw-r--r--Test/og/linear-set2.bpl30
1 files changed, 15 insertions, 15 deletions
diff --git a/Test/og/linear-set2.bpl b/Test/og/linear-set2.bpl
index 11d24605..93ede868 100644
--- a/Test/og/linear-set2.bpl
+++ b/Test/og/linear-set2.bpl
@@ -20,8 +20,8 @@ function {:inline} {:linear "x"} XCollector(xs: [X]bool) : [X]bool
xs
}
-var {:phase 1} x: int;
-var {:phase 1} l: X;
+var {:layer 1} x: int;
+var {:layer 1} l: X;
const nil: X;
procedure Split({:linear_in "x"} xls: [X]bool) returns ({:linear "x"} xls1: [X]bool, {:linear "x"} xls2: [X]bool);
@@ -30,17 +30,17 @@ ensures xls == MapOr(xls1, xls2) && xls1 != None() && xls2 != None();
procedure Allocate() returns ({:linear "tid"} xls: X);
ensures xls != nil;
-procedure {:yields} {:phase 0,1} Set(v: int);
+procedure {:yields} {:layer 0,1} Set(v: int);
ensures {:atomic} |{A: x := v; return true; }|;
-procedure {:yields} {:phase 0,1} Lock(tidls: X);
+procedure {:yields} {:layer 0,1} Lock(tidls: X);
ensures {:atomic} |{A: assume l == nil; l := tidls; return true; }|;
-procedure {:yields} {:phase 0,1} Unlock();
+procedure {:yields} {:layer 0,1} Unlock();
ensures {:atomic} |{A: l := nil; return true; }|;
-procedure {:yields} {:phase 1} main({:linear_in "tid"} tidls': X, {:linear_in "x"} xls': [X]bool)
-requires {:phase 1} tidls' != nil && xls' == All();
+procedure {:yields} {:layer 1} main({:linear_in "tid"} tidls': X, {:linear_in "x"} xls': [X]bool)
+requires {:layer 1} tidls' != nil && xls' == All();
{
var {:linear "tid"} tidls: X;
var {:linear "x"} xls: [X]bool;
@@ -54,8 +54,8 @@ requires {:phase 1} tidls' != nil && xls' == All();
yield;
call Set(42);
yield;
- assert {:phase 1} xls == All();
- assert {:phase 1} x == 42;
+ assert {:layer 1} xls == All();
+ assert {:layer 1} x == 42;
call xls1, xls2 := Split(xls);
call lsChild := Allocate();
yield;
@@ -66,8 +66,8 @@ requires {:phase 1} tidls' != nil && xls' == All();
yield;
}
-procedure {:yields} {:phase 1} thread({:linear_in "tid"} tidls': X, {:linear_in "x"} xls': [X]bool)
-requires {:phase 1} tidls' != nil && xls' != None();
+procedure {:yields} {:layer 1} thread({:linear_in "tid"} tidls': X, {:linear_in "x"} xls': [X]bool)
+requires {:layer 1} tidls' != nil && xls' != None();
{
var {:linear "x"} xls: [X]bool;
var {:linear "tid"} tidls: X;
@@ -78,13 +78,13 @@ requires {:phase 1} tidls' != nil && xls' != None();
yield;
call Lock(tidls);
yield;
- assert {:phase 1} tidls != nil && xls != None();
+ assert {:layer 1} tidls != nil && xls != None();
call Set(0);
yield;
- assert {:phase 1} tidls != nil && xls != None();
- assert {:phase 1} x == 0;
+ assert {:layer 1} tidls != nil && xls != None();
+ assert {:layer 1} x == 0;
yield;
- assert {:phase 1} tidls != nil && xls != None();
+ assert {:layer 1} tidls != nil && xls != None();
call Unlock();
yield;
}