view tests/caseFfi.ur @ 2174:ce312cad5ecd

Use correct OpenSSL thread safety macros on OS X (closes #209) Create an Autoconf test to determine if pthread_t is a pointer or scalar type, and use the appropriate CRYPTO_THREADID_set macro based on the result.
author Benjamin Barenblat <bbaren at mit.edu>
date Sun, 20 Sep 2015 17:46:07 -0400
parents 71bafe66dbe1
children
line wrap: on
line source
extern structure M : sig
        datatype t = A | B
        datatype u = C of t | D
end

val f = fn x => case x of M.A => M.B | M.B => M.A

val t2s = fn x => case x of M.A => "A" | M.B => "B"

val g = fn x => case x of M.C a => M.C (f a) | M.D => M.C M.A

val u2s = fn x => case x of M.C a => t2s a | M.D => "D"

val page = fn x => <html><body>
        {cdata (t2s x)}
</body></html>

val page2 = fn x => <html><body>
        {cdata (u2s x)}
</body></html>

val main : unit -> page = fn () => <html><body>
        <li><a link={page M.A}>A</a></li>
        <li><a link={page M.B}>B</a></li>
        <li><a link={page2 (M.C M.A)}>C A</a></li>
        <li><a link={page2 (M.C M.B)}>C B</a></li>
        <li><a link={page2 M.D}>D</a></li>
</body></html>