mirror of
https://github.com/danog/psalm.git
synced 2025-01-22 13:51:54 +01:00
5a14e4b1cf
* Revert "Revert "Implement better progress"" This reverts commit 4302596654235194e28bb2fa52867d9b52ccd0b1. * Revert "Revert "Implement dots progress bar"" This reverts commit e41733d789c6971d9c8ba9e4e8a4584888fd6a8a. * Revert "Revert "Switch to VoidProgress by default"" This reverts commit 304ffeb0a30bc650634c0a0715c84ca7b3a8ecd0. * Revert "Revert "Pass success flag to progress"" This reverts commit 62a690ee4eb192065bac0934202923aeb472b89e. * Improve socket communication * Use an underscore * Add means to disable progress * Add extra newline before progress bar
68 lines
1.9 KiB
PHP
68 lines
1.9 KiB
PHP
<?php
|
|
namespace Psalm\Examples\Template;
|
|
|
|
use PhpParser;
|
|
use Psalm;
|
|
use Psalm\Checker\CommentChecker;
|
|
use Psalm\Codebase;
|
|
use Psalm\DocComment;
|
|
use Psalm\Progress\Progress;
|
|
use Psalm\Storage\FileStorage;
|
|
|
|
class TemplateScanner extends Psalm\Internal\Scanner\FileScanner
|
|
{
|
|
const VIEW_CLASS = 'Your\\View\\Class';
|
|
|
|
/**
|
|
* @param bool $storage_from_cache
|
|
*
|
|
* @return void
|
|
*/
|
|
public function scan(
|
|
Codebase $codebase,
|
|
FileStorage $file_storage,
|
|
$storage_from_cache = false,
|
|
Progress $progress = null
|
|
) {
|
|
$stmts = $codebase->statements_provider->getStatementsForFile(
|
|
$file_storage->file_path,
|
|
$progress
|
|
);
|
|
|
|
if (empty($stmts)) {
|
|
return;
|
|
}
|
|
|
|
$first_stmt = $stmts[0];
|
|
|
|
if (($first_stmt instanceof PhpParser\Node\Stmt\Nop) && ($doc_comment = $first_stmt->getDocComment())) {
|
|
$comment_block = DocComment::parse(trim($doc_comment->getText()));
|
|
|
|
if (isset($comment_block['specials']['variablesfrom'])) {
|
|
$variables_from = trim($comment_block['specials']['variablesfrom'][0]);
|
|
|
|
$first_line_regex = '/([A-Za-z\\\0-9]+::[a-z_A-Z]+)(\s+weak)?/';
|
|
|
|
$matches = [];
|
|
|
|
if (!preg_match($first_line_regex, $variables_from, $matches)) {
|
|
throw new \InvalidArgumentException('Could not interpret doc comment correctly');
|
|
}
|
|
|
|
/** @psalm-suppress MixedArgument */
|
|
list($fq_class_name) = explode('::', $matches[1]);
|
|
|
|
$codebase->scanner->queueClassLikeForScanning(
|
|
$fq_class_name,
|
|
$this->file_path,
|
|
true
|
|
);
|
|
}
|
|
}
|
|
|
|
$codebase->scanner->queueClassLikeForScanning(self::VIEW_CLASS, $this->file_path);
|
|
|
|
parent::scan($codebase, $file_storage, $storage_from_cache, $progress);
|
|
}
|
|
}
|