[infer][backend] removed the use of Summary.get_unsafe in the backend 2/2

Summary: Remove the remain uses of `Summary.get_unsafe`

Reviewed By: dulmarod

Differential Revision: D8648236

fbshipit-source-id: c6ca2dc
master
Jeremy Dubreil 7 years ago committed by Facebook Github Bot
parent 1ee0390f3c
commit 7d2b96b42f

@ -201,8 +201,6 @@ let get proc_name =
load_summary_to_spec_table proc_name
let get_unsafe proc_name = Option.value_exn (get proc_name)
(** Check if the procedure is from a library:
It's not defined, and there is no spec file for it. *)
let proc_is_library proc_attributes =

@ -84,9 +84,6 @@ val get_loc : t -> Location.t
val get_signature : t -> string
(** Return the signature of a procedure declaration as a string *)
val get_unsafe : Typ.Procname.t -> t
(** @deprecated Return the summary for the procedure name. Raises an exception when not found. *)
val get_status : t -> Status.t
(** Return the status (active v.s. inactive) of a procedure summary *)

@ -1137,11 +1137,9 @@ let update_summary tenv prev_summary specs phase res =
(** Analyze the procedure and return the resulting summary. *)
let analyze_proc exe_env tenv proc_cfg : Summary.t =
let analyze_proc summary exe_env tenv proc_cfg : Summary.t =
let proc_desc = ProcCfg.Exceptional.proc_desc proc_cfg in
let proc_name = Procdesc.get_proc_name proc_desc in
reset_global_values proc_desc ;
let summary = Summary.get_unsafe proc_name in
let go, get_results = perform_analysis_phase exe_env tenv summary proc_cfg in
let res = Timeout.exe_timeout go () in
let specs, phase = get_results () in
@ -1154,15 +1152,14 @@ let analyze_proc exe_env tenv proc_cfg : Summary.t =
(** Perform the transition from [FOOTPRINT] to [RE_EXECUTION] in spec table *)
let transition_footprint_re_exe tenv proc_name joined_pres =
let summary = Summary.get_unsafe proc_name in
let transition_footprint_re_exe summary tenv joined_pres : Summary.t =
let summary' =
if Config.only_footprint then
match summary.Summary.payloads.biabduction with
| Some ({phase= FOOTPRINT} as biabduction) ->
{ summary with
Summary.payloads=
{ summary.payloads with
{ summary.Summary.payloads with
Payloads.biabduction= Some {biabduction with BiabductionSummary.phase= RE_EXECUTION}
} }
| _ ->
@ -1182,12 +1179,12 @@ let transition_footprint_re_exe tenv proc_name joined_pres =
in
{summary with Summary.payloads}
in
Summary.add proc_name summary'
summary'
(** Perform phase transition from [FOOTPRINT] to [RE_EXECUTION] for
the procedures enabled after the analysis of [proc_name] *)
let perform_transition proc_cfg tenv proc_name =
let perform_transition proc_cfg tenv proc_name summary =
let transition summary =
(* disable exceptions for leaks and protect against any other errors *)
let joined_pres =
@ -1214,24 +1211,24 @@ let perform_transition proc_cfg tenv proc_name =
L.(debug Analysis Medium) "Error: %s %a@." err_str L.pp_ocaml_pos_opt error.ocaml_pos ;
[]
in
transition_footprint_re_exe tenv proc_name joined_pres
transition_footprint_re_exe summary tenv joined_pres
in
match Summary.get proc_name with
| Some summary
when BiabductionSummary.(summary.payloads.biabduction |> opt_get_phase |> equal_phase FOOTPRINT) ->
transition summary
| _ ->
()
if
let open BiabductionSummary in
summary.Summary.payloads.biabduction |> opt_get_phase |> equal_phase FOOTPRINT
then transition summary
else summary
let analyze_procedure_aux exe_env tenv proc_desc =
let analyze_procedure_aux summary exe_env tenv proc_desc : Summary.t =
let proc_name = Procdesc.get_proc_name proc_desc in
let proc_cfg = ProcCfg.Exceptional.from_pdesc proc_desc in
Preanal.do_preanalysis proc_desc tenv ;
let summaryfp = Config.run_in_footprint_mode (analyze_proc exe_env tenv) proc_cfg in
Summary.add proc_name summaryfp ;
perform_transition proc_cfg tenv proc_name ;
let summaryre = Config.run_in_re_execution_mode (analyze_proc exe_env tenv) proc_cfg in
let summaryfp =
Config.run_in_footprint_mode (analyze_proc summary exe_env tenv) proc_cfg
|> perform_transition proc_cfg tenv proc_name
in
let summaryre = Config.run_in_re_execution_mode (analyze_proc summaryfp exe_env tenv) proc_cfg in
let summary_compact =
match summaryre.Summary.payloads.biabduction with
| Some BiabductionSummary.({preposts} as biabduction) when Config.save_compact_summaries ->
@ -1254,9 +1251,7 @@ let analyze_procedure_aux exe_env tenv proc_desc =
let analyze_procedure {Callbacks.summary; proc_desc; tenv; exe_env} : Summary.t =
(* make sure models have been registered *)
BuiltinDefn.init () ;
let proc_name = Procdesc.get_proc_name proc_desc in
Summary.add proc_name summary ;
( try ignore (analyze_procedure_aux exe_env tenv proc_desc) with exn ->
IExn.reraise_if exn ~f:(fun () -> not (Exceptions.handle_exception exn)) ;
Reporting.log_error_deprecated proc_name exn ) ;
Summary.get_unsafe proc_name
try analyze_procedure_aux summary exe_env tenv proc_desc with exn ->
IExn.reraise_if exn ~f:(fun () -> not (Exceptions.handle_exception exn)) ;
Reporting.log_error summary exn ;
summary

Loading…
Cancel
Save