Idris2/tests/chez/chez010/CB.idr

40 lines
1.2 KiB
Idris

libcb : String -> String
libcb f = "C:" ++ f ++", libcb"
%foreign libcb "add"
add : Int -> Int -> Int
%foreign libcb "applyIntFn"
prim__applyIntFn : Int -> Int -> (Int -> Int -> PrimIO Int) -> PrimIO Int
%foreign libcb "applyCharFn"
prim__applyCharFn : Char -> Int -> (Char -> Int -> PrimIO Char) -> PrimIO Char
%foreign libcb "applyIntFnPure"
applyIntFnPure : Int -> Int -> (Int -> Int -> Int) -> Int
applyIntFn : HasIO io => Int -> Int -> (Int -> Int -> IO Int) -> io Int
applyIntFn x y fn
= primIO $ prim__applyIntFn x y (\a, b => toPrim (fn a b))
applyCharFn : HasIO io => Char -> Int -> (Char -> Int -> IO Char) -> io Char
applyCharFn x y fn
= primIO $ prim__applyCharFn x y (\a, b => toPrim (fn a b))
cb : Int -> Int -> IO Int
cb x y
= do putStrLn $ "In callback with " ++ show (x, y)
pure (x + y)
main : IO ()
main
= do printLn (add 4 5)
res <- applyIntFn (add 4 5) 6 (\x, y => do putStrLn "In callback"
pure (x * 2 + y))
printLn res
res <- applyIntFn 1 2 cb
printLn res
printLn (applyIntFnPure 5 4 (\x, y => x + y))
res <- applyCharFn 'a' 10 (\x, y => pure (cast (cast x + y)))
printLn res