remove recursive call in try/with

Reviewed By: jeremydubreil

Differential Revision: D3224391

fb-gh-sync-id: a2da993
fbshipit-source-id: a2da993
master
Sam Blackshear 9 years ago committed by Facebook Github Bot 1
parent 0737b9231d
commit 46fc0bb1dc

@ -36,32 +36,28 @@ let java_proc_name_with_class_method pn_java class_with_path method_name =
Procname.java_get_method pn_java = method_name Procname.java_get_method pn_java = method_name
with _ -> false) with _ -> false)
(** get the superclasses of [typ]. does not include [typ] itself *) let get_direct_supers tenv = function
let strict_supertype_iter tenv f_typ orig_struct_typ =
let get_direct_supers = function
| { Sil.csu = Csu.Class _; superclasses } -> | { Sil.csu = Csu.Class _; superclasses } ->
IList.map (Tenv.lookup tenv) superclasses IList.map (Tenv.lookup tenv) superclasses
|> IList.flatten_options |> IList.flatten_options
| _ -> | _ ->
[] in []
(** get the superclasses of [typ]. does not include [typ] itself *)
let strict_supertype_iter tenv f_typ orig_struct_typ =
let rec get_supers_rec struct_typ = let rec get_supers_rec struct_typ =
let direct_supers = get_direct_supers struct_typ in let direct_supers = get_direct_supers tenv struct_typ in
IList.iter f_typ direct_supers; IList.iter f_typ direct_supers;
IList.iter get_supers_rec direct_supers in IList.iter get_supers_rec direct_supers in
get_supers_rec orig_struct_typ get_supers_rec orig_struct_typ
exception Found_supertype_match
(** Return [true] if [f_typ] evaluates to true on a strict supertype of [orig_struct_typ] *) (** Return [true] if [f_typ] evaluates to true on a strict supertype of [orig_struct_typ] *)
let strict_supertype_exists tenv f_typ orig_struct_typ = let strict_supertype_exists tenv f_typ orig_struct_typ =
let wrapped_f_typ struct_typ = let rec get_supers_rec struct_typ =
if f_typ struct_typ let direct_supers = get_direct_supers tenv struct_typ in
then raise Found_supertype_match in IList.exists f_typ direct_supers ||
try IList.exists get_supers_rec direct_supers in
strict_supertype_iter tenv wrapped_f_typ orig_struct_typ; get_supers_rec orig_struct_typ
false
with Found_supertype_match ->
true
let is_immediate_subtype this_type super_type_name = let is_immediate_subtype this_type super_type_name =
IList.exists (Typename.equal super_type_name) this_type.Sil.superclasses IList.exists (Typename.equal super_type_name) this_type.Sil.superclasses

Loading…
Cancel
Save