1
0
mirror of https://github.com/danog/psalm.git synced 2024-12-15 02:47:02 +01:00
psalm/src/Psalm/Scanner/FileScanner.php

120 lines
2.4 KiB
PHP
Raw Normal View History

2018-01-21 18:44:46 +01:00
<?php
namespace Psalm\Scanner;
use PhpParser;
use PhpParser\NodeTraverser;
use Psalm\Codebase;
2018-01-21 18:44:46 +01:00
use Psalm\FileSource;
use Psalm\Storage\FileStorage;
use Psalm\Visitor\DependencyFinderVisitor;
class FileScanner implements FileSource
{
/**
* @var string
*/
public $file_path;
/**
* @var string
*/
public $file_name;
/**
* @var bool
*/
public $will_analyze;
/**
* @param string $file_path
* @param string $file_name
* @param bool $will_analyze
*/
public function __construct($file_path, $file_name, $will_analyze)
{
$this->file_path = $file_path;
$this->file_name = $file_name;
$this->will_analyze = $will_analyze;
}
/**
* @param array<mixed, PhpParser\Node> $stmts
2018-02-19 06:27:39 +01:00
* @param bool $storage_from_cache
* @param bool $debug_output
2018-01-21 18:44:46 +01:00
*
* @return void
*/
public function scan(
Codebase $codebase,
FileStorage $file_storage,
$storage_from_cache = false,
$debug_output = false
) {
if ((!$this->will_analyze || $file_storage->deep_scan)
&& $storage_from_cache
&& !$file_storage->has_trait
) {
2018-02-19 06:27:39 +01:00
return;
}
$stmts = $codebase->statements_provider->getStatementsForFile(
$file_storage->file_path,
$debug_output
);
if ($debug_output) {
if ($this->will_analyze) {
echo 'Deep scanning ' . $file_storage->file_path . PHP_EOL;
} else {
echo 'Scanning ' . $file_storage->file_path . PHP_EOL;
}
}
2018-01-21 18:44:46 +01:00
$traverser = new NodeTraverser();
$traverser->addVisitor(new DependencyFinderVisitor($codebase, $file_storage, $this));
2018-01-21 18:44:46 +01:00
$traverser->traverse($stmts);
$file_storage->deep_scan = $this->will_analyze;
2018-01-21 18:44:46 +01:00
}
/**
* @return string
*/
public function getFilePath()
{
return $this->file_path;
}
/**
* @return string
*/
public function getFileName()
{
return $this->file_name;
}
/**
* @return string
*/
public function getCheckedFilePath()
{
return $this->file_path;
}
/**
* @return string
*/
public function getCheckedFileName()
{
return $this->file_name;
}
/**
* @return \Psalm\Aliases
*/
public function getAliases()
{
return new \Psalm\Aliases();
}
2018-01-21 18:44:46 +01:00
}