diff options
author | qadeer <unknown> | 2014-12-26 00:56:32 -0800 |
---|---|---|
committer | qadeer <unknown> | 2014-12-26 00:56:32 -0800 |
commit | 71fc5f5b32a5939ad488d6070a6acaf4d7cb443a (patch) | |
tree | 582e3f32855f107bc0deb28127c7c5b081d64600 /Test/og/chris.bpl | |
parent | 84819ceb711f1ae83327e2006df9bb1003ccd65e (diff) |
strengthened type checking
cleaned up the generation of mover checks (based on example from Chris)
added two examples from Chris to regressions
Diffstat (limited to 'Test/og/chris.bpl')
-rw-r--r-- | Test/og/chris.bpl | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/Test/og/chris.bpl b/Test/og/chris.bpl new file mode 100644 index 00000000..b54292ef --- /dev/null +++ b/Test/og/chris.bpl @@ -0,0 +1,28 @@ +// RUN: %boogie -noinfer -typeEncoding:m -useArrayTheory "%s" > "%t"
+// RUN: %diff "%s.expect" "%t"
+var{:layer 1} x:int;
+
+procedure{:yields}{:layer 2} Havoc()
+ ensures{:atomic} |{ A: return true; }|;
+{
+ yield;
+}
+
+procedure{:yields}{:layer 1} Recover()
+ ensures{:atomic} |{ A: assert x == 5; return true; }|;
+{
+ yield;
+}
+
+procedure{:yields}{:layer 3} P()
+ ensures{:atomic} |{ A: return true; }|;
+ requires{:layer 2,3} x == 5;
+ ensures {:layer 2,3} x == 5;
+{
+
+ yield; assert{:layer 2,3} x == 5;
+ call Havoc();
+ yield; assert{:layer 3} x == 5;
+ call Recover();
+ yield; assert{:layer 2,3} x == 5;
+}
|