Add a ty_children function to enumerate the children of any type

This commit is contained in:
Patrick Walton 2010-07-10 14:59:54 -07:00
parent b3cf793bd9
commit b172862d21
2 changed files with 26 additions and 1 deletions

View file

@ -1339,6 +1339,32 @@ and fmt_crate (ff:Format.formatter) (c:crate) : unit =
let (view,items) = c.node.crate_items in
fmt_mod_view ff view;
fmt_mod_items ff items
;;
let ty_children (ty:ty) : ty array =
let children_of_ty_tag ty_tag = Array.concat (htab_vals ty_tag) in
let children_of_ty_fn ty_fn =
let (ty_sig, _) = ty_fn in
let in_slots = ty_sig.sig_input_slots in
let slots = Array.append in_slots [| ty_sig.sig_output_slot |] in
arr_filter_some (Array.map (fun slot -> slot.slot_ty) slots)
in
match ty with
TY_tup tys -> tys
| TY_vec ty' | TY_chan ty' | TY_port ty' | TY_box ty' | TY_mutable ty'
| TY_constrained (ty', _) ->
[| ty' |]
| TY_rec fields -> Array.map snd fields
| TY_tag ty_tag -> children_of_ty_tag ty_tag
| TY_iso ty_iso -> children_of_ty_tag (ty_iso.iso_group.(ty_iso.iso_index))
| TY_fn ty_fn -> children_of_ty_fn ty_fn
| TY_obj (_, methods) ->
Array.concat (List.map children_of_ty_fn (htab_vals methods))
| TY_any | TY_nil | TY_bool | TY_mach _ | TY_int | TY_uint | TY_char
| TY_str | TY_idx _ | TY_task | TY_native _ | TY_param _
| TY_named _ | TY_type ->
[| |]
;;
let sprintf_expr = sprintf_fmt fmt_expr;;
let sprintf_name = sprintf_fmt fmt_name;;

View file

@ -341,7 +341,6 @@ let bool_of_option x =
Some _ -> true
| None -> false
(*
* Auxiliary stack functions.
*)