summaryrefslogtreecommitdiff
path: root/src/cloconv.sml
diff options
context:
space:
mode:
authorGravatar Adam Chlipala <adamc@hcoop.net>2008-06-22 10:17:34 -0400
committerGravatar Adam Chlipala <adamc@hcoop.net>2008-06-22 10:17:34 -0400
commitd60f854fc35ce30fb698f3d8e87b88938001fdaf (patch)
tree993aecf3c64b1e472749ccc4cc3d9ffa6dd2ed3e /src/cloconv.sml
parentf3ddf9922b90bdd45ca5b1c33c72ff316d5440eb (diff)
FFI through cloconv
Diffstat (limited to 'src/cloconv.sml')
-rw-r--r--src/cloconv.sml11
1 files changed, 8 insertions, 3 deletions
diff --git a/src/cloconv.sml b/src/cloconv.sml
index 5c26312a..98f86e5b 100644
--- a/src/cloconv.sml
+++ b/src/cloconv.sml
@@ -69,7 +69,7 @@ fun ccTyp (t, loc) =
L.TFun (t1, t2) => (L'.TFun (ccTyp t1, ccTyp t2), loc)
| L.TRecord xts => (L'.TRecord (map (fn (x, t) => (x, ccTyp t)) xts), loc)
| L.TNamed n => (L'.TNamed n, loc)
- | L.TFfi _ => raise Fail "Cloconv TFfi"
+ | L.TFfi mx => (L'.TFfi mx, loc)
structure Ds :> sig
type t
@@ -111,8 +111,13 @@ fun ccExp env ((e, loc), D) =
L.EPrim p => ((L'.EPrim p, loc), D)
| L.ERel n => ((L'.ERel n, loc), Ds.used (D, n))
| L.ENamed n => ((L'.ENamed n, loc), D)
- | L.EFfi _ => raise Fail "Cloconv EFfi"
- | L.EFfiApp _ => raise Fail "Cloconv EFfiApp"
+ | L.EFfi mx => ((L'.EFfi mx, loc), D)
+ | L.EFfiApp (m, x, es) =>
+ let
+ val (es, D) = ListUtil.foldlMap (ccExp env) D es
+ in
+ ((L'.EFfiApp (m, x, es), loc), D)
+ end
| L.EApp (e1, e2) =>
let
val (e1, D) = ccExp env (e1, D)