1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-22 05:41:20 +01:00

Scan preloaded stubs earlier

This should prevent Psalm from sometimes marking user-defined classes as
built-in.

Fixes vimeo/psalm#5126
Fixes vimeo/psalm#5626
This commit is contained in:
Bruce Weirdan 2021-07-31 23:05:15 +03:00
parent 7e137f5b95
commit 2562e37e60
No known key found for this signature in database
GPG Key ID: CFC3AAB181751B0D

View File

@ -582,6 +582,7 @@ class ProjectAnalyzer
|| $deleted_files === null || $deleted_files === null
|| count($diff_files) > 200 || count($diff_files) > 200
) { ) {
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->visitAutoloadFiles(); $this->visitAutoloadFiles();
$this->codebase->scanner->addFilesToShallowScan($this->extra_files); $this->codebase->scanner->addFilesToShallowScan($this->extra_files);
@ -590,8 +591,6 @@ class ProjectAnalyzer
$this->config->initializePlugins($this); $this->config->initializePlugins($this);
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->codebase->scanFiles($this->threads); $this->codebase->scanFiles($this->threads);
$this->codebase->infer_types_from_usage = true; $this->codebase->infer_types_from_usage = true;
@ -608,14 +607,13 @@ class ProjectAnalyzer
$file_list = array_diff($file_list, $deleted_files); $file_list = array_diff($file_list, $deleted_files);
if ($file_list) { if ($file_list) {
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->visitAutoloadFiles(); $this->visitAutoloadFiles();
$this->checkDiffFilesWithConfig($this->config, $file_list); $this->checkDiffFilesWithConfig($this->config, $file_list);
$this->config->initializePlugins($this); $this->config->initializePlugins($this);
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->codebase->scanFiles($this->threads); $this->codebase->scanFiles($this->threads);
} else { } else {
$diff_no_files = true; $diff_no_files = true;
@ -989,14 +987,14 @@ class ProjectAnalyzer
{ {
$this->file_reference_provider->loadReferenceCache(); $this->file_reference_provider->loadReferenceCache();
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->checkDirWithConfig($dir_name, $this->config, true); $this->checkDirWithConfig($dir_name, $this->config, true);
$this->progress->startScanningFiles(); $this->progress->startScanningFiles();
$this->config->initializePlugins($this); $this->config->initializePlugins($this);
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->codebase->scanFiles($this->threads); $this->codebase->scanFiles($this->threads);
$this->config->visitStubFiles($this->codebase, $this->progress); $this->config->visitStubFiles($this->codebase, $this->progress);
@ -1116,6 +1114,8 @@ class ProjectAnalyzer
{ {
$this->progress->debug('Checking ' . $file_path . "\n"); $this->progress->debug('Checking ' . $file_path . "\n");
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->config->hide_external_errors = $this->config->isInProjectDirs($file_path); $this->config->hide_external_errors = $this->config->isInProjectDirs($file_path);
$this->codebase->addFilesToAnalyze([$file_path => $file_path]); $this->codebase->addFilesToAnalyze([$file_path => $file_path]);
@ -1126,8 +1126,6 @@ class ProjectAnalyzer
$this->config->initializePlugins($this); $this->config->initializePlugins($this);
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->codebase->scanFiles($this->threads); $this->codebase->scanFiles($this->threads);
$this->config->visitStubFiles($this->codebase, $this->progress); $this->config->visitStubFiles($this->codebase, $this->progress);
@ -1147,6 +1145,7 @@ class ProjectAnalyzer
*/ */
public function checkPaths(array $paths_to_check): void public function checkPaths(array $paths_to_check): void
{ {
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->visitAutoloadFiles(); $this->visitAutoloadFiles();
$this->codebase->scanner->addFilesToShallowScan($this->extra_files); $this->codebase->scanner->addFilesToShallowScan($this->extra_files);
@ -1168,7 +1167,6 @@ class ProjectAnalyzer
$this->config->initializePlugins($this); $this->config->initializePlugins($this);
$this->config->visitPreloadedStubFiles($this->codebase, $this->progress);
$this->codebase->scanFiles($this->threads); $this->codebase->scanFiles($this->threads);