diff options
author | Dan Rosén <danr@chalmers.se> | 2014-08-11 14:57:27 -0700 |
---|---|---|
committer | Dan Rosén <danr@chalmers.se> | 2014-08-11 14:57:27 -0700 |
commit | 4cbe4583b329a39dee2b4b456758cafbe7e2fa79 (patch) | |
tree | 6bb2377f06036fd41d939d168365d4e47cc7a327 /Test/hofs/Naked.dfy | |
parent | c377658acba5472b6d0c1e1452ce4c4c8f1fc28e (diff) |
Add higher-order-functions and some other goodies
* The reads clause now needs to be self framing.
* The requires clause now needs to be framed by the reads clause.
* There are one-shot lambdas, with a single arrow, but they will probably be
removed.
* There is a {:heapQuantifier} attribute to quantifiers, but they will
probably be removed.
* Add smart handling of type variables
* Add < and > for datatype & type parameter
Diffstat (limited to 'Test/hofs/Naked.dfy')
-rw-r--r-- | Test/hofs/Naked.dfy | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/Test/hofs/Naked.dfy b/Test/hofs/Naked.dfy new file mode 100644 index 00000000..17aa828a --- /dev/null +++ b/Test/hofs/Naked.dfy @@ -0,0 +1,51 @@ +// RUN: %dafny /compile:0 "%s" > "%t" +// RUN: %diff "%s.expect" "%t" + +module Functions { + function f(x: nat): nat + { + if x == 0 then 0 else + if var b: bool :| true; b then + var h := f; + h(x-1) + else + (f)(x-1) + } + + function f1(x: nat): nat { if x == 0 then 0 else f2(x - 1) } + + function f2(x: nat): nat { if x == 0 then 0 else (f1)(x - 1) } +} + +module Requires { + function t(x: nat): nat + requires !t.requires(x); + { x } + + function g(x: nat): nat + requires !(g).requires(x); + { x } + + function g2(x: int): int { h(x) } + + function h(x: int): int + requires !g2.requires(x); + { x } +} + +module Reads { + function t(x: nat): nat + reads t.reads(x); + { x } + + function g(x: nat): nat + reads (g).reads(x); + { x } + + function g2(x: int): int { h(x) } + + function h(x: int): int + reads g2.reads(x); + { x } +} + |