blob: 72c4fb658e311b8feb33688c14257dd79ff35183 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
// RUN: %boogie -noinfer -contractInfer -printAssignment -inlineDepth:1 "%s" > "%t"
// RUN: %diff "%s.expect" "%t"
var g: bool;
procedure foo()
modifies g;
ensures b0 ==> (!old(g) ==> old(g) == g);
{
call AcquireLock();
call ReleaseLock();
}
procedure AcquireLock()
modifies g;
ensures b1 ==> old(g) == g;
{
g := true;
}
procedure ReleaseLock()
modifies g;
ensures b2 ==> old(g) == g;
{
g := false;
}
procedure main()
modifies g;
{
g := false;
call foo();
assert !g;
}
const {:existential true} b0: bool;
const {:existential true} b1: bool;
const {:existential true } b2: bool;
|