File: phantom_option.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 (27 lines) | stat: -rw-r--r-- 493 bytes parent folder | download
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
default Order dec

$include <prelude.sail>

$option -lem_mwords

union phantom_option('a : Type, 'b : Int) = {
  SomeP : 'a,
  NoneP : unit
}

val f : forall ('a : Type) 'n. phantom_option('a, 'n) -> phantom_option('a, 'n + 32)

function f(opt) = match opt {
  SomeP(x) => SomeP(x),
  NoneP()  => NoneP()
}

val test : forall 'n, 'n > 0. int('n) -> phantom_option(bits(8 * 'n), 64)

function test(width) = {
  if 'n == 8 then {
    f(SomeP(sail_zeros(8 * width)))
  } else {
    NoneP()
  }
}