summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorThomas Bauereiss2020-04-04 17:20:06 +0100
committerThomas Bauereiss2020-04-21 02:20:11 +0100
commite1a2b0d2a88e4797d714ad0cb941c3cbf019720b (patch)
treed4b70e68765ac6cb7c2795fdd313047185cafab0 /test
parent264ab693afa90a1e9fa842f5972f64dc7e06c492 (diff)
Tweak types of loop combinators for prover combinators
Split the variable (tuple) type into an input and output type. They are meant to be the same, but due to the way function types are instantiated, unification can fail in the case of existential types, as in the added test case (when trying to generate Lem definitions from it). The output of the loop will be checked against the expected type, though, due to a type annotation outside the loop added by the rewrite pass for variable updates.
Diffstat (limited to 'test')
-rw-r--r--test/typecheck/pass/floor_pow2.sail17
1 files changed, 17 insertions, 0 deletions
diff --git a/test/typecheck/pass/floor_pow2.sail b/test/typecheck/pass/floor_pow2.sail
new file mode 100644
index 00000000..fa8680cf
--- /dev/null
+++ b/test/typecheck/pass/floor_pow2.sail
@@ -0,0 +1,17 @@
+$include <arith.sail>
+
+val "pow2" : forall 'n, 'n >= 0. int('n) -> int(2 ^ 'n)
+
+val floor_pow2 : forall ('x : Int), 'x >= 0. int('x) -> int
+
+function floor_pow2 x = {
+ if x == 0 then {
+ return(0);
+ } else {
+ n : {'n, 'n >= 1. int('n)} = 1;
+ while x >= pow2(n) do {
+ n = n + 1
+ };
+ return(pow2(n - 1))
+ }
+}