forked from CakeML/cakeml
-
Notifications
You must be signed in to change notification settings - Fork 0
/
cfSyntax.sml
58 lines (47 loc) · 2.01 KB
/
cfSyntax.sml
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
(*
Helper functions for syntax from cfTheory.
*)
structure cfSyntax :> cfSyntax = struct
open Abbrev
local
open HolKernel boolLib bossLib cfTheory
fun make5 tm (a,b,c,d,e) =
list_mk_icomb (tm, [a, b, c, d, e])
fun dest5 c e tm =
case with_exn strip_comb tm e of
(t, [t1, t2, t3, t4, t5]) =>
if same_const t c then (t1, t2, t3, t4, t5) else raise e
| _ => raise e
fun make6 tm (a,b,c,d,e,f) =
list_mk_icomb (tm, [a, b, c, d, e, f])
fun dest6 c e tm =
case with_exn strip_comb tm e of
(t, [t1, t2, t3, t4, t5, t6]) =>
if same_const t c then (t1, t2, t3, t4, t5, t6) else raise e
| _ => raise e
fun make8 tm (a,b,c,d,e,f,g,h) =
list_mk_icomb (tm, [a, b, c, d, e, f, g, h])
fun dest8 c e tm =
case with_exn strip_comb tm e of
(t, [t1, t2, t3, t4, t5, t6, t7, t8]) =>
if same_const t c then (t1, t2, t3, t4, t5, t6, t7, t8) else raise e
| _ => raise e
val s4 = HolKernel.syntax_fns4 "cf"
val s5 = HolKernel.syntax_fns {n = 5, make = make5, dest = dest5} "cf"
val s6 = HolKernel.syntax_fns {n = 6, make = make6, dest = dest6} "cf"
val s8 = HolKernel.syntax_fns {n = 8, make = make8, dest = dest8} "cf"
in
val (cf_let_tm, mk_cf_let, dest_cf_let, is_cf_let) = s6 "cf_let"
val (cf_lit_tm, mk_cf_lit, dest_cf_lit, is_cf_lit) = s4 "cf_lit"
val (cf_con_tm, mk_cf_con, dest_cf_con, is_cf_con) = s5 "cf_con"
val (cf_var_tm, mk_cf_var, dest_cf_var, is_cf_var) = s4 "cf_var"
val (cf_fun_tm, mk_cf_fun, dest_cf_fun, is_cf_fun) = s8 "cf_fun"
val (cf_fun_rec_tm, mk_cf_fun_rec, dest_cf_fun_rec, is_cf_fun_rec) = s6 "cf_fun_rec"
val (cf_app_tm, mk_cf_app, dest_cf_app, is_cf_app) = s6 "cf_app"
val (cf_log_tm, mk_cf_log, dest_cf_log, is_cf_log) = s6 "cf_log"
val (cf_if_tm, mk_cf_if, dest_cf_if, is_cf_if) = s6 "cf_if"
val (cf_match_tm, mk_cf_match, dest_cf_match, is_cf_match) = s5 "cf_match"
val (cf_handle_tm, mk_cf_handle, dest_cf_handle, is_cf_handle) = s5 "cf_handle"
val (cf_raise_tm, mk_cf_raise, dest_cf_raise, is_cf_raise) = s4 "cf_raise"
end
end