summaryrefslogtreecommitdiff
path: root/Test/dafny0/RefinementModificationChecking.dfy
blob: 052918d005d970d46f2a47c875c088044758e54e (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
47
48
49
50
51
52
53
54
55
56
57
// RUN: %dafny /compile:0 /print:"%t.print" /dprint:"%t.dprint" "%s" > "%t"
// RUN: %diff "%s.expect" "%t"

abstract module R1 {
  class HappyBay {
    var f: int;
    method m(y: set<int>) returns (r: int)
      modifies this;
    {
      var t := y;
    }
  }
}

module R2 refines R1 {
  class HappyBay {
    var g: nat;
    method m ...
    {
      ...;
      var x := 3;
      t := {1}; // error: previous local
      r := 3; // error: out parameter
      f := 4; // error: previously defined field
      x := 6; // fine: new local
      g := 34;// fine: new field
    }
  }
}

abstract module M0 {
  class C {
    method Init()
      modifies this;
    { }
    method InitWithSideEffects(c: C)
      modifies c;
    { }
    method mmm(arr: array<int>) {
      var a: C :| true;
      var b: C :| true;
    }
  }
}

module M1 refines M0 {
  class C {
    method mmm... {
      var a := new C;  // fine
      var b := new C.Init();  // fine
      var c := new C.InitWithSideEffects(b);  // error: modifies previous state
      if arr != null && 12 < arr.Length {
        arr[12] := 26;  // error: modifies previously defined state
      }
    }
  }
}