summaryrefslogtreecommitdiff
path: root/Test/AbsHoudini/houd6.bpl
blob: 4279e4ce12c1fd0fa2eda435f4a4c2cb7cb577a5 (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
39
40
41
42
43
44
45
46
// RUN: %boogie -noinfer -contractInfer -printAssignment -abstractHoudini:IA[ConstantProp] "%s" > "%t"
// RUN: %diff "%s.expect" "%t"
function {:existential true} b1():bool;
function {:existential true} b2():bool;
function {:existential true} b3():bool;
function {:existential true} b4():bool;
function {:existential true} b5():bool;
function {:existential true} b6():bool;
function {:existential true} b7():bool;
function {:existential true} b8():bool;
function {:existential true} Assert(): bool;

var array:[int]int;

procedure foo (i:int)
requires b6() || i < 0;
requires b5() || i == 0;
requires b2() || i > 0;
ensures b3() || array[i] > 0;
modifies array;
ensures Assert() || (forall x:int :: {array[x]} x == i || array[x] == old(array)[x]);
{
    array[i] := 2 * i;
}

procedure bar (j:int) returns (result:int)
requires b8() || j < 0;
requires b7() || j == 0;
requires b4() || j > 0;
modifies array;
ensures Assert() || (forall x:int :: {array[x]} (x == j) || array[x] == old(array)[x]);
ensures b1() || array[j] == old(array)[j];
{
    call foo(j);
    result := array[j];	
}

var p:int;

procedure main() returns (result: int) 
modifies array;
{
  call result:= bar(p);
}

// expected assigment: Assert -> false, bi->true forall i