File: existentials4.sail

package info (click to toggle)
sail-ocaml 0.19.1%2Bdfsg5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 18,008 kB
  • sloc: ml: 75,941; ansic: 8,848; python: 1,342; exp: 560; sh: 474; makefile: 218; cpp: 36
file content (20 lines) | stat: -rw-r--r-- 563 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
default Order dec
$include <prelude.sail>
$include <generic_equality.sail>

union ast = {
  Foo : {'n, 'n in {16,32}. (int, int, int('n), bits('n))},
  Bar : (int, int, {'n, 'n in {16,32}. (int('n), bits('n))}),
}

val foo : forall 'n, 'n in {16,32}. (int, int, int('n), bits('n)) -> int
function foo(i,j,n,v) = i + j + unsigned(v)

val bar : forall 'n, 'n in {16,32}. (int, int, (int('n), bits('n))) -> int
function bar(i,j,(n,v)) = i + j + unsigned(v)

function exec(x : ast) -> int =
  match x {
  Foo(i,j,n,v) => foo(i,j,n,v),
  Bar(i,j,x) => bar(i,j,x),
  }