diff options
| author | Graydon Hoare <[email protected]> | 2010-06-24 19:21:40 -0700 |
|---|---|---|
| committer | Graydon Hoare <[email protected]> | 2010-06-24 19:21:40 -0700 |
| commit | 72c6c60d80cdfe63af5046a1a98549f0515734f2 (patch) | |
| tree | 6e2691b393b095badc6ff4f309a9ca18263599e5 /src/boot/me/transutil.ml | |
| parent | Factor out some trans bits. (diff) | |
| download | rust-72c6c60d80cdfe63af5046a1a98549f0515734f2.tar.xz rust-72c6c60d80cdfe63af5046a1a98549f0515734f2.zip | |
Add intrinsic calling convention.
Diffstat (limited to 'src/boot/me/transutil.ml')
| -rw-r--r-- | src/boot/me/transutil.ml | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/boot/me/transutil.ml b/src/boot/me/transutil.ml index c430e034..7a6f9b8e 100644 --- a/src/boot/me/transutil.ml +++ b/src/boot/me/transutil.ml @@ -225,6 +225,28 @@ let iter_rec_slots (Array.map snd entries) f curr_iso ;; +let intrinsic_name (cx:ctxt) (fnid:node_id) : string = + match Hashtbl.find cx.ctxt_all_item_names fnid with + Ast.NAME_base (Ast.BASE_ident id) -> id + | Ast.NAME_base (Ast.BASE_app (id, _)) -> id + | Ast.NAME_ext (_, Ast.COMP_ident id) -> id + | Ast.NAME_ext (_, Ast.COMP_app (id, _)) -> id + | _ -> err (Some fnid) "unexpected name for intrinsic fn" +;; + +let fn_is_intrinsic (cx:ctxt) (fnid:node_id) : bool = + let (_, conv) = Hashtbl.find cx.ctxt_required_items fnid in + conv = CONV_intrinsic +;; + +let lval_is_intrinsic (cx:ctxt) (lval:Ast.lval) : bool = + let item = lval_item cx lval in + match item.node.Ast.decl_item with + Ast.MOD_ITEM_fn _ + when Hashtbl.mem cx.ctxt_required_items item.id -> + fn_is_intrinsic cx item.id + | _ -> false +;; |