mirror of
https://github.com/danog/psalm.git
synced 2024-11-26 20:34:47 +01:00
Move var docblocks within function
This commit is contained in:
parent
dc5a5bcd9d
commit
909e02d441
23
src/Psalm/CodeLocation/DocblockTypeLocation.php
Normal file
23
src/Psalm/CodeLocation/DocblockTypeLocation.php
Normal file
@ -0,0 +1,23 @@
|
||||
<?php
|
||||
namespace Psalm\CodeLocation;
|
||||
|
||||
use PhpParser;
|
||||
|
||||
class DocblockTypeLocation extends \Psalm\CodeLocation
|
||||
{
|
||||
public function __construct(
|
||||
\Psalm\FileSource $file_source,
|
||||
int $file_start,
|
||||
int $file_end,
|
||||
int $line_number
|
||||
) {
|
||||
$this->file_start = $file_start;
|
||||
$this->file_end = $file_end;
|
||||
$this->file_path = $file_source->getFilePath();
|
||||
$this->file_name = $file_source->getFileName();
|
||||
$this->single_line = false;
|
||||
|
||||
$this->preview_start = $this->file_start;
|
||||
$this->line_number = $line_number;
|
||||
}
|
||||
}
|
@ -36,9 +36,7 @@ class CommentAnalyzer
|
||||
FileSource $source,
|
||||
Aliases $aliases,
|
||||
array $template_type_map = null,
|
||||
?array $type_aliases = null,
|
||||
?Codebase $codebase = null,
|
||||
?string $calling_method_id = null
|
||||
?array $type_aliases = null
|
||||
) {
|
||||
$var_id = null;
|
||||
|
||||
@ -66,6 +64,9 @@ class CommentAnalyzer
|
||||
continue;
|
||||
}
|
||||
|
||||
$type_start = null;
|
||||
$type_end = null;
|
||||
|
||||
$line_parts = self::splitDocLine($var_line);
|
||||
|
||||
if ($line_parts && $line_parts[0]) {
|
||||
@ -73,6 +74,11 @@ class CommentAnalyzer
|
||||
throw new IncorrectDocblockException('Misplaced variable');
|
||||
}
|
||||
|
||||
if (($start_offset = strpos($comment->getText(), $line_parts[0])) !== false) {
|
||||
$type_start = $start_offset + $comment->getFilePos();
|
||||
$type_end = $type_start + strlen($line_parts[0]);
|
||||
}
|
||||
|
||||
try {
|
||||
$var_type_tokens = Type::fixUpLocalType(
|
||||
$line_parts[0],
|
||||
@ -118,6 +124,8 @@ class CommentAnalyzer
|
||||
$var_comment->original_type = $original_type;
|
||||
$var_comment->var_id = $var_id;
|
||||
$var_comment->line_number = $var_line_number;
|
||||
$var_comment->type_start = $type_start;
|
||||
$var_comment->type_end = $type_end;
|
||||
$var_comment->deprecated = isset($comments['specials']['deprecated']);
|
||||
$var_comment->internal = isset($comments['specials']['internal']);
|
||||
if (isset($comments['specials']['psalm-internal'])) {
|
||||
|
@ -52,11 +52,7 @@ class ForeachAnalyzer
|
||||
$var_comments = CommentAnalyzer::getTypeFromComment(
|
||||
$doc_comment,
|
||||
$statements_analyzer->getSource(),
|
||||
$statements_analyzer->getSource()->getAliases(),
|
||||
null,
|
||||
null,
|
||||
$codebase,
|
||||
$context->calling_method_id
|
||||
$statements_analyzer->getSource()->getAliases()
|
||||
);
|
||||
} catch (DocblockParseException $e) {
|
||||
if (IssueBuffer::accepts(
|
||||
|
@ -80,9 +80,7 @@ class AssignmentAnalyzer
|
||||
$statements_analyzer->getSource(),
|
||||
$statements_analyzer->getAliases(),
|
||||
$template_type_map,
|
||||
$file_storage->type_aliases,
|
||||
$codebase,
|
||||
$context->calling_method_id
|
||||
$file_storage->type_aliases
|
||||
);
|
||||
} catch (IncorrectDocblockException $e) {
|
||||
if (IssueBuffer::accepts(
|
||||
@ -122,6 +120,25 @@ class AssignmentAnalyzer
|
||||
$statements_analyzer->getSuppressedIssues()
|
||||
);
|
||||
|
||||
if ($codebase->method_migrations
|
||||
&& $context->calling_method_id
|
||||
&& isset($codebase->method_migrations[strtolower($context->calling_method_id)])
|
||||
&& $var_comment->type_start
|
||||
&& $var_comment->type_end
|
||||
&& $var_comment->line_number
|
||||
&& $var_comment_type->hasNamedObject()
|
||||
) {
|
||||
$destination_method_id = $codebase->method_migrations[strtolower($context->calling_method_id)];
|
||||
|
||||
$codebase->classlikes->airliftDocblockType(
|
||||
$var_comment_type,
|
||||
explode('::', $destination_method_id)[0],
|
||||
$statements_analyzer->getFilePath(),
|
||||
$var_comment->type_start,
|
||||
$var_comment->type_end
|
||||
);
|
||||
}
|
||||
|
||||
if (!$var_comment->var_id || $var_comment->var_id === $var_id) {
|
||||
$comment_type = $var_comment_type;
|
||||
continue;
|
||||
|
@ -1371,11 +1371,7 @@ class ExpressionAnalyzer
|
||||
$var_comments = CommentAnalyzer::getTypeFromComment(
|
||||
$doc_comment,
|
||||
$statements_analyzer,
|
||||
$statements_analyzer->getAliases(),
|
||||
null,
|
||||
null,
|
||||
$codebase,
|
||||
$context->calling_method_id
|
||||
$statements_analyzer->getAliases()
|
||||
);
|
||||
} catch (DocblockParseException $e) {
|
||||
if (IssueBuffer::accepts(
|
||||
|
@ -52,11 +52,7 @@ class ReturnAnalyzer
|
||||
$var_comments = CommentAnalyzer::getTypeFromComment(
|
||||
$doc_comment,
|
||||
$source,
|
||||
$source->getAliases(),
|
||||
null,
|
||||
null,
|
||||
$codebase,
|
||||
$context->calling_method_id
|
||||
$source->getAliases()
|
||||
);
|
||||
} catch (DocblockParseException $e) {
|
||||
if (IssueBuffer::accepts(
|
||||
@ -78,6 +74,25 @@ class ReturnAnalyzer
|
||||
$statements_analyzer->getParentFQCLN()
|
||||
);
|
||||
|
||||
if ($codebase->method_migrations
|
||||
&& $context->calling_method_id
|
||||
&& isset($codebase->method_migrations[strtolower($context->calling_method_id)])
|
||||
&& $var_comment->type_start
|
||||
&& $var_comment->type_end
|
||||
&& $var_comment->line_number
|
||||
&& $comment_type->hasNamedObject()
|
||||
) {
|
||||
$destination_method_id = $codebase->method_migrations[strtolower($context->calling_method_id)];
|
||||
|
||||
$codebase->classlikes->airliftDocblockType(
|
||||
$comment_type,
|
||||
explode('::', $destination_method_id)[0],
|
||||
$statements_analyzer->getFilePath(),
|
||||
$var_comment->type_start,
|
||||
$var_comment->type_end
|
||||
);
|
||||
}
|
||||
|
||||
if (!$var_comment->var_id) {
|
||||
$var_comment_type = $comment_type;
|
||||
continue;
|
||||
|
@ -910,10 +910,7 @@ class StatementsAnalyzer extends SourceAnalyzer implements StatementsSource
|
||||
$doc_comment,
|
||||
$this->getSource(),
|
||||
$this->getAliases(),
|
||||
$this->getTemplateTypeMap(),
|
||||
null,
|
||||
$codebase,
|
||||
$context->calling_method_id
|
||||
$this->getTemplateTypeMap()
|
||||
);
|
||||
} catch (\Psalm\Exception\IncorrectDocblockException $e) {
|
||||
if (IssueBuffer::accepts(
|
||||
@ -953,6 +950,25 @@ class StatementsAnalyzer extends SourceAnalyzer implements StatementsSource
|
||||
$this->getSuppressedIssues()
|
||||
);
|
||||
|
||||
if ($codebase->method_migrations
|
||||
&& $context->calling_method_id
|
||||
&& isset($codebase->method_migrations[strtolower($context->calling_method_id)])
|
||||
&& $var_comment->type_start
|
||||
&& $var_comment->type_end
|
||||
&& $var_comment->line_number
|
||||
&& $var_comment_type->hasNamedObject()
|
||||
) {
|
||||
$destination_method_id = $codebase->method_migrations[strtolower($context->calling_method_id)];
|
||||
|
||||
$codebase->classlikes->airliftDocblockType(
|
||||
$var_comment_type,
|
||||
explode('::', $destination_method_id)[0],
|
||||
$this->getFilePath(),
|
||||
$var_comment->type_start,
|
||||
$var_comment->type_end
|
||||
);
|
||||
}
|
||||
|
||||
if (!$var_comment->var_id || $var_comment->var_id === $var_id) {
|
||||
$comment_type = $var_comment_type;
|
||||
continue;
|
||||
|
@ -820,6 +820,41 @@ class ClassLikes
|
||||
);
|
||||
}
|
||||
|
||||
public function airliftDocblockType(
|
||||
Type\Union $type,
|
||||
string $destination_fq_class_name,
|
||||
string $source_file_path,
|
||||
int $source_start,
|
||||
int $source_end
|
||||
) : void {
|
||||
$project_analyzer = \Psalm\Internal\Analyzer\ProjectAnalyzer::getInstance();
|
||||
$codebase = $project_analyzer->getCodebase();
|
||||
|
||||
$destination_class_storage = $codebase->classlike_storage_provider->get($destination_fq_class_name);
|
||||
|
||||
if (!$destination_class_storage->aliases) {
|
||||
throw new \UnexpectedValueException('Aliases should not be null');
|
||||
}
|
||||
|
||||
$file_manipulations = [];
|
||||
|
||||
$file_manipulations[] = new \Psalm\FileManipulation(
|
||||
$source_start,
|
||||
$source_end,
|
||||
$type->toNamespacedString(
|
||||
$destination_class_storage->aliases->namespace,
|
||||
$destination_class_storage->aliases->uses_flipped,
|
||||
$destination_class_storage->name,
|
||||
false
|
||||
)
|
||||
);
|
||||
|
||||
FileManipulationBuffer::add(
|
||||
$source_file_path,
|
||||
$file_manipulations
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $class_name
|
||||
* @param mixed $visibility
|
||||
|
@ -28,6 +28,16 @@ class VarDocblockComment
|
||||
*/
|
||||
public $line_number;
|
||||
|
||||
/**
|
||||
* @var int|null
|
||||
*/
|
||||
public $type_start;
|
||||
|
||||
/**
|
||||
* @var int|null
|
||||
*/
|
||||
public $type_end;
|
||||
|
||||
/**
|
||||
* Whether or not the property is deprecated
|
||||
*
|
||||
|
@ -2601,16 +2601,17 @@ class ReflectorVisitor extends PhpParser\NodeVisitorAbstract implements PhpParse
|
||||
|
||||
$property_storage->type = null;
|
||||
} else {
|
||||
if ($var_comment && $var_comment->line_number) {
|
||||
$doc_var_location = new CodeLocation(
|
||||
if ($var_comment
|
||||
&& $var_comment->type_start
|
||||
&& $var_comment->type_end
|
||||
&& $var_comment->line_number
|
||||
) {
|
||||
$doc_var_location = new CodeLocation\DocblockTypeLocation(
|
||||
$this->file_scanner,
|
||||
$stmt,
|
||||
null,
|
||||
false,
|
||||
CodeLocation::VAR_TYPE,
|
||||
$var_comment->original_type
|
||||
$var_comment->type_start,
|
||||
$var_comment->type_end,
|
||||
$var_comment->line_number
|
||||
);
|
||||
$doc_var_location->setCommentLine($var_comment->line_number);
|
||||
}
|
||||
|
||||
if ($doc_var_group_type) {
|
||||
|
Loading…
Reference in New Issue
Block a user