Errdesc.find_in_node_or_preds: got rid of ref

Reviewed By: jeremydubreil

Differential Revision: D8026982

fbshipit-source-id: d14dbd7
master
Mehdi Bouaziz 7 years ago committed by Facebook Github Bot
parent 0ba993fb68
commit 1cd1dc580d

@ -80,20 +80,25 @@ let explain_deallocate_constant_string s ra =
let verbose = Config.trace_error let verbose = Config.trace_error
let find_in_node_or_preds start_node f_node_instr = let find_in_node_or_preds =
let visited = ref Procdesc.NodeSet.empty in let rec find ~f visited nodes =
let rec find node = match nodes with
if Procdesc.NodeSet.mem node !visited then None | node :: nodes when not (Procdesc.NodeSet.mem node visited)
else ( -> (
visited := Procdesc.NodeSet.add node !visited ;
let instrs = Procdesc.Node.get_instrs node in let instrs = Procdesc.Node.get_instrs node in
match List.find_map ~f:(f_node_instr node) (List.rev instrs) with match List.find_map ~f:(f node) instrs with
| Some res -> | Some res ->
Some res Some res
| None -> | None ->
List.find_map ~f:find (Procdesc.Node.get_preds node) ) let nodes = Procdesc.Node.get_preds node |> List.rev_append nodes in
let visited = Procdesc.NodeSet.add node visited in
find ~f visited nodes )
| _ :: nodes ->
find ~f visited nodes
| _ ->
None
in in
find start_node fun start_node ~f -> find ~f Procdesc.NodeSet.empty [start_node]
(** Find the function call instruction used to initialize normal variable [id], (** Find the function call instruction used to initialize normal variable [id],
@ -106,7 +111,7 @@ let find_normal_variable_funcall (node: Procdesc.Node.t) (id: Ident.t)
| _ -> | _ ->
None None
in in
let res = find_in_node_or_preds node find_declaration in let res = find_in_node_or_preds node ~f:find_declaration in
if verbose && is_none res then ( if verbose && is_none res then (
L.d_str L.d_str
( "find_normal_variable_funcall could not find " ^ Ident.to_string id ^ " in node " ( "find_normal_variable_funcall could not find " ^ Ident.to_string id ^ " in node "
@ -123,7 +128,7 @@ let find_program_variable_assignment node pvar : (Procdesc.Node.t * Ident.t) opt
| _ -> | _ ->
None None
in in
find_in_node_or_preds node find_instr find_in_node_or_preds node ~f:find_instr
(** Special case for C++, where we translate code like (** Special case for C++, where we translate code like
@ -142,7 +147,7 @@ let find_struct_by_value_assignment node pvar =
| _ -> | _ ->
None None
in in
find_in_node_or_preds node find_instr find_in_node_or_preds node ~f:find_instr
else None else None
@ -154,7 +159,7 @@ let find_ident_assignment node id : (Procdesc.Node.t * Exp.t) option =
| _ -> | _ ->
None None
in in
find_in_node_or_preds node find_instr find_in_node_or_preds node ~f:find_instr
(** Find a boolean assignment to a temporary variable holding a boolean condition. (** Find a boolean assignment to a temporary variable holding a boolean condition.
@ -221,7 +226,7 @@ let rec find_normal_variable_load_ tenv (seen: Exp.Set.t) node id : DExp.t optio
| _ -> | _ ->
None None
in in
let res = find_in_node_or_preds node find_declaration in let res = find_in_node_or_preds node ~f:find_declaration in
if verbose && is_none res then ( if verbose && is_none res then (
L.d_str L.d_str
( "find_normal_variable_load could not find " ^ Ident.to_string id ^ " in node " ( "find_normal_variable_load could not find " ^ Ident.to_string id ^ " in node "

Loading…
Cancel
Save