From bb8ba0e7a4482522c4233b0ddc33eea10c286d00 Mon Sep 17 00:00:00 2001 From: Varun Arora Date: Mon, 26 Feb 2018 05:17:01 -0800 Subject: [PATCH] [reporting] remove ProcAttributes dependency from EventLogger Summary: - EventLogger no longer depends on ProcAttributes - This allows for other backend classes which are used by ProcAttributes to log in the future without creating a cyclic dependency structure Reviewed By: dulmarod Differential Revision: D7082444 fbshipit-source-id: f32a6e2 --- infer/src/backend/InferPrint.ml | 15 ++++++++------- infer/src/base/EventLogger.ml | 5 ++--- infer/src/base/EventLogger.mli | 2 +- 3 files changed, 11 insertions(+), 11 deletions(-) diff --git a/infer/src/backend/InferPrint.ml b/infer/src/backend/InferPrint.ml index 95a6846a8..325d8293b 100644 --- a/infer/src/backend/InferPrint.ml +++ b/infer/src/backend/InferPrint.ml @@ -520,6 +520,9 @@ module StatsLogs = struct let num_preposts = match summary.payload.preposts with Some preposts -> List.length preposts | None -> 0 in + let clang_method_kind = + ProcAttributes.string_of_clang_method_kind (Specs.get_attributes summary).clang_method_kind + in let proc_name = Specs.get_proc_name summary in let lang = Typ.Procname.get_language proc_name in let stats = @@ -528,9 +531,7 @@ module StatsLogs = struct ; analysis_status= summary.stats.stats_failure ; analysis_total_nodes= Specs.get_proc_desc summary |> Procdesc.get_nodes_num ; clang_method_kind= - ( if Language.equal lang Language.Clang then - Some (Specs.get_attributes summary).clang_method_kind - else None ) + (match lang with Language.Clang -> Some clang_method_kind | _ -> None) ; lang= Language.to_explicit_string lang ; method_location= Specs.get_loc summary ; method_name= Typ.Procname.to_string proc_name @@ -664,11 +665,11 @@ let get_outfile outfile = let pp_issue_in_format (format_kind, (outfile_opt: Utils.outfile option)) error_filter {Issue.proc_name; proc_location; err_key; err_data} = match format_kind with - | Csv -> - L.(die InternalError) "Printing issues in a CSV format is not implemented" | Json -> let outf = get_outfile outfile_opt in IssuesJson.pp_issue outf.fmt error_filter proc_name (Some proc_location) err_key err_data + | Csv -> + L.(die InternalError) "Printing issues in a CSV format is not implemented" | Tests -> L.(die InternalError) "Printing issues as tests is not implemented" | Logs -> @@ -871,14 +872,14 @@ let register_perf_stats_report () = PerfStats.register_report_at_exit stats_file +(** Although the out_file is an Option type, the None option is strictly meant for the + logs format_kind, and all other formats should contain an outfile value. *) let mk_format format_kind fname = Option.value_map ~f:(fun out_file -> [(format_kind, Some out_file)]) ~default:[] (Utils.create_outfile fname) -(** Although the out_file is an Option type, the None option is strictly meant for the - logs format_kind, and all other formats should contain an outfile value. *) let init_issues_format_list report_json = let json_format = Option.value_map ~f:(mk_format Json) ~default:[] report_json in let tests_format = Option.value_map ~f:(mk_format Tests) ~default:[] Config.issues_tests in diff --git a/infer/src/base/EventLogger.ml b/infer/src/base/EventLogger.ml index 68892dec5..f1bbce7ed 100644 --- a/infer/src/base/EventLogger.ml +++ b/infer/src/base/EventLogger.ml @@ -75,7 +75,7 @@ type analysis_stats = { analysis_nodes_visited: int ; analysis_status: SymOp.failure_kind option ; analysis_total_nodes: int - ; clang_method_kind: ProcAttributes.clang_method_kind option + ; clang_method_kind: string option ; lang: string ; method_location: Location.t ; method_name: string @@ -90,8 +90,7 @@ let create_analysis_stats_row base record = (Option.value_map record.analysis_status ~default:"OK" ~f:(fun stats_failure -> SymOp.failure_kind_to_string stats_failure )) |> add_int ~key:"analysis_total_nodes" ~data:record.analysis_total_nodes - |> add_string_opt ~key:"clang_method_kind" - ~data:(Option.map record.clang_method_kind ~f:ProcAttributes.string_of_clang_method_kind) + |> add_string_opt ~key:"clang_method_kind" ~data:record.clang_method_kind |> add_string ~key:"lang" ~data:record.lang |> add_string ~key:"method_location" ~data: diff --git a/infer/src/base/EventLogger.mli b/infer/src/base/EventLogger.mli index 7d2f507b1..6d3245a49 100644 --- a/infer/src/base/EventLogger.mli +++ b/infer/src/base/EventLogger.mli @@ -11,7 +11,7 @@ type analysis_stats = { analysis_nodes_visited: int ; analysis_status: SymOp.failure_kind option ; analysis_total_nodes: int - ; clang_method_kind: ProcAttributes.clang_method_kind option + ; clang_method_kind: string option ; lang: string ; method_location: Location.t ; method_name: string