mirror of
https://github.com/danog/psalm.git
synced 2024-11-30 04:39:00 +01:00
Shuffle file analysis order for more even threaded workload distribution
This commit is contained in:
parent
d0a9bf24f8
commit
cd8534fb6c
@ -363,6 +363,29 @@ class Analyzer
|
|||||||
++$i;
|
++$i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
foreach ($process_file_paths as $pool_key => $file_paths) {
|
||||||
|
$count = count($file_paths);
|
||||||
|
$middle = intdiv($count, 4);
|
||||||
|
$remainder = $count % 4;
|
||||||
|
|
||||||
|
$new_file_paths = [];
|
||||||
|
|
||||||
|
for ($i = 0; $i < 4; $i++) {
|
||||||
|
for ($j = 0; $j < $middle; $j++) {
|
||||||
|
if ($j * 4 + $i < $count) {
|
||||||
|
$new_file_paths[] = $file_paths[$j * 4 + $i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($remainder) {
|
||||||
|
$new_file_paths[] = $file_paths[$middle * 4 + $remainder - 1];
|
||||||
|
$remainder--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$process_file_paths[$pool_key] = $new_file_paths;
|
||||||
|
}
|
||||||
|
|
||||||
// Run analysis one file at a time, splitting the set of
|
// Run analysis one file at a time, splitting the set of
|
||||||
// files up among a given number of child processes.
|
// files up among a given number of child processes.
|
||||||
$pool = new \Psalm\Internal\Fork\Pool(
|
$pool = new \Psalm\Internal\Fork\Pool(
|
||||||
|
Loading…
Reference in New Issue
Block a user