mirror of
https://github.com/danog/psalm.git
synced 2024-12-13 17:57:37 +01:00
20351c6667
`\Psalm\Internal\Clause::$hash` basically holds a hash on arbitrary input literals, used for later comparison. Using `json_encode` fails when dealing with non-UTF8 literals, which has been replaced by plain PHP `serialize`. Resolves: #7771
77 lines
1.8 KiB
PHP
77 lines
1.8 KiB
PHP
<?php
|
|
|
|
namespace Psalm\Internal\Analyzer;
|
|
|
|
use PhpParser\Node\Stmt\Trait_;
|
|
use Psalm\Aliases;
|
|
use Psalm\Context;
|
|
|
|
use function assert;
|
|
|
|
/**
|
|
* @internal
|
|
*/
|
|
class TraitAnalyzer extends ClassLikeAnalyzer
|
|
{
|
|
/**
|
|
* @var Aliases
|
|
*/
|
|
private $aliases;
|
|
|
|
public function __construct(
|
|
Trait_ $class,
|
|
SourceAnalyzer $source,
|
|
string $fq_class_name,
|
|
Aliases $aliases
|
|
) {
|
|
$this->source = $source;
|
|
$this->file_analyzer = $source->getFileAnalyzer();
|
|
$this->aliases = $source->getAliases();
|
|
$this->class = $class;
|
|
$this->fq_class_name = $fq_class_name;
|
|
$codebase = $source->getCodebase();
|
|
$this->storage = $codebase->classlike_storage_provider->get($fq_class_name);
|
|
$this->aliases = $aliases;
|
|
}
|
|
|
|
public function getNamespace(): ?string
|
|
{
|
|
return $this->aliases->namespace;
|
|
}
|
|
|
|
public function getAliases(): Aliases
|
|
{
|
|
return $this->aliases;
|
|
}
|
|
|
|
/**
|
|
* @return array<lowercase-string, string>
|
|
*/
|
|
public function getAliasedClassesFlipped(): array
|
|
{
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* @return array<string, string>
|
|
*/
|
|
public function getAliasedClassesFlippedReplaceable(): array
|
|
{
|
|
return [];
|
|
}
|
|
|
|
public static function analyze(StatementsAnalyzer $statements_analyzer, Trait_ $stmt, Context $context): void
|
|
{
|
|
assert($stmt->name !== null);
|
|
$storage = $statements_analyzer->getCodebase()->classlike_storage_provider->get($stmt->name->name);
|
|
AttributesAnalyzer::analyze(
|
|
$statements_analyzer,
|
|
$context,
|
|
$storage,
|
|
$stmt->attrGroups,
|
|
AttributesAnalyzer::TARGET_CLASS,
|
|
$storage->suppressed_issues + $statements_analyzer->getSuppressedIssues()
|
|
);
|
|
}
|
|
}
|