forked from miking-lang/miking
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsymbs.mc
32 lines (27 loc) · 939 Bytes
/
symbs.mc
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
-- Miking is licensed under the MIT license.
-- Copyright (C) David Broman. See file LICENSE.txt
--
-- Test symbools
include "bool.mc"
mexpr
-- 'gensym()' generates a new unique symbol.
-- () -> Symbol
let x = gensym () in
let y = gensym () in
-- 'eqsym s1 s2' returns true if symbol 's1' and symbol 's2'
-- are the same symbol.
-- Symbol -> Symbol -> Bool
let neg = lam f. lam x. lam y. not (f x y) in
utest x with x using eqsym in
utest y with y using eqsym in
utest y with x using neg eqsym in
utest x with y using neg eqsym in
-- 'sym2hash s1' returns an integer representation of s1 that fulfills the
-- following criterion: eqsym a b => eqi (sym2hash a) (sym2hash b)
-- No guarantees are given for the opposite direction, but a best effort is
-- made to give 2 symbols different integer representation.
-- Symbol -> Int
let z = x in
utest sym2hash x with sym2hash x using eqi in
utest sym2hash x with sym2hash z using eqi in
()