[infer] randomise source files list in deterministic way

Reviewed By: jvillard

Differential Revision: D14801433

fbshipit-source-id: 5b0c49f01
master
Nikos Gorogiannis 6 years ago committed by Facebook Github Bot
parent f127d1ca9e
commit 70b7beac1c

@ -74,25 +74,34 @@ let main ~changed_files =
register_active_checkers () ; register_active_checkers () ;
if Config.reanalyze then Summary.reset_all ~filter:(Lazy.force Filtering.procedures_filter) () if Config.reanalyze then Summary.reset_all ~filter:(Lazy.force Filtering.procedures_filter) ()
else DB.Results_dir.clean_specs_dir () ; else DB.Results_dir.clean_specs_dir () ;
let all_source_files = let n_all_source_files = ref 0 in
SourceFiles.get_all ~filter:(Lazy.force Filtering.source_files_filter) () let n_source_files_to_analyze = ref 0 in
let filter sourcefile =
let result =
(Lazy.force Filtering.source_files_filter) sourcefile
&& source_file_should_be_analyzed ~changed_files sourcefile
in in
let source_files_to_analyze = incr n_all_source_files ;
List.filter ~f:(source_file_should_be_analyzed ~changed_files) all_source_files if result then incr n_source_files_to_analyze ;
result
in in
let n_source_files = List.length source_files_to_analyze in let source_files_to_analyze = SourceFiles.get_all ~filter () in
L.progress "Found %d%s source file%s to analyze in %s@." n_source_files L.progress "Found %d%s source file%s to analyze in %s@." !n_source_files_to_analyze
( if Config.reactive_mode || Option.is_some changed_files then ( if Config.reactive_mode || Option.is_some changed_files then
" (out of " ^ string_of_int (List.length all_source_files) ^ ")" " (out of " ^ string_of_int !n_all_source_files ^ ")"
else "" ) else "" )
(if Int.equal n_source_files 1 then "" else "s") (if Int.equal !n_source_files_to_analyze 1 then "" else "s")
Config.results_dir ; Config.results_dir ;
(* empty all caches to minimize the process heap to have less work to do when forking *) (* empty all caches to minimize the process heap to have less work to do when forking *)
clear_caches () ; clear_caches () ;
if Int.equal Config.jobs 1 then ( ( if Int.equal Config.jobs 1 then (
Tasks.run_sequentially ~f:analyze_source_file source_files_to_analyze ; Tasks.run_sequentially ~f:analyze_source_file source_files_to_analyze ;
L.progress "@\nAnalysis finished in %as@." Pp.elapsed_time () ) L.progress "@\nAnalysis finished in %as@." Pp.elapsed_time () )
else ( else
let source_files_to_analyze =
List.permute source_files_to_analyze
~random_state:(Random.State.make (Array.create ~len:1 0))
in
L.environment_info "Parallel jobs: %d@." Config.jobs ; L.environment_info "Parallel jobs: %d@." Config.jobs ;
(* Prepare tasks one cluster at a time while executing in parallel *) (* Prepare tasks one cluster at a time while executing in parallel *)
let runner = Tasks.Runner.create ~jobs:Config.jobs ~f:analyze_source_file in let runner = Tasks.Runner.create ~jobs:Config.jobs ~f:analyze_source_file in

Loading…
Cancel
Save