summaryrefslogtreecommitdiff
path: root/Test/hofs/ResolveError.dfy
blob: 3c0d7cd9814e2a3b8bf6bb223441533bea3f295e (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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
// RUN: %dafny /print:"%t.print" "%s" > "%t"
// RUN: %diff "%s.expect" "%t"


method ResolutionErrors() {
    var x;
    var g5 := x, y => (y, x);   // fail at resolution
    var g6 := x, (y => (y, x)); // fail at resolution
}

// cannot assign functions

class Apa {
  function f() : int {
    0
  }
}

method Nope3() {
  var apa := new Apa;
  apa.f := () => 2;
}

method RequiresFail(f : int -> int)
  // ok
  requires f(0) == 0;
  requires f.requires(0);
  requires f.reads(0) == {};

  // fail
  requires f(0) == true;
  requires f(1,2) == 0;
  requires f(true) == 0;
  requires f.requires(true);
  requires f.requires(1) == 0;
  requires f.requires(1,2);
  requires f.reads(true) == {};
  requires f.reads(1) == 0;
  requires f.reads(1,2) == {};
{
}

method Bogus()
{
  var f;
  f := x reads 1 => x;
  f := x requires 1 => x;
}

predicate method Bool()
{
  true
}

method Bla() {
  assert Bool;
}

method Pli(f : A -> B) requires f != null;
{
  var o : object;
  assert f != o;
}

method Underscores() {
  var u := _ => 0;
  var v := (_, _) => 0;
  var w := (_, _, _) => _;
}

module AritySituations {
  // In addition to testing type checking, these tests check that error messages
  //  print the types correctly
  function method F(x: int, b: bool): real    // F:  (int,bool) -> real
  function method G(pair: (int, bool)): real  // G:  ((int,bool)) -> real
  function method V(): real                   // V:  () -> real
  function method W(unit: ()): real           // W:  (()) -> real

  method M()
  {
    var f: (int, bool) -> real;
    var g: ((int, bool)) -> real;
    var h: (int, bool) -> real;
    f := F;
    g := G;
    h := G;  // error

    var f' := F;
    var g' := G;
  
    var s0 := P(F, 5);  // error: F takes 2 arguments, but P expect a function that takes 1
    var s1 := P(G, (2,true));  // fine

    var v: () -> real;
    var w: (()) -> real;
    v := V;
    w := W;
    var v': () -> real := V;
    var w': (()) -> real := W;
    var w'': ((((((())))))) -> real := W;
    v := W;  // error
    w := V;  // error
  }

  method P(r: T -> U, x: T) returns (u: U)
    requires r.requires(x);
  {
    u := r(x);
  }
}