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

Prepopulate all object properties

This commit is contained in:
Matthew Brown 2016-06-27 10:46:27 -04:00
parent e4c590d7b7
commit bd694459f3

View File

@ -70,6 +70,8 @@ class ClassChecker implements StatementsSource
self::$_class_methods[$this->_absolute_class] = []; self::$_class_methods[$this->_absolute_class] = [];
$class_context = new Context();
foreach ($this->_class->stmts as $stmt) { foreach ($this->_class->stmts as $stmt) {
if ($stmt instanceof PhpParser\Node\Stmt\ClassMethod) { if ($stmt instanceof PhpParser\Node\Stmt\ClassMethod) {
$method_id = $this->_absolute_class . '::' . $stmt->name; $method_id = $this->_absolute_class . '::' . $stmt->name;
@ -115,7 +117,13 @@ class ClassChecker implements StatementsSource
if ($comment && $config->use_docblock_types) { if ($comment && $config->use_docblock_types) {
$type_in_comment = CommentChecker::getTypeFromComment($comment, null, $this); $type_in_comment = CommentChecker::getTypeFromComment($comment, null, $this);
} }
$this->_class_properties[$property->name] = $type_in_comment ? Type::parseString($type_in_comment) : Type::getMixed();
$property_type = $type_in_comment ? Type::parseString($type_in_comment) : Type::getMixed();
$this->_class_properties[$property->name] = $property_type;
if (!$stmt->isStatic()) {
$class_context->vars_in_scope['this->' . $property->name] = $property_type;
}
} }
} }
$leftover_stmts[] = $stmt; $leftover_stmts[] = $stmt;
@ -137,7 +145,7 @@ class ClassChecker implements StatementsSource
if ($check_statements) { if ($check_statements) {
// do the method checks after all class methods have been initialised // do the method checks after all class methods have been initialised
foreach ($method_checkers as $method_checker) { foreach ($method_checkers as $method_checker) {
$method_checker->check(new Context()); $method_checker->check(clone $class_context);
if (!$config->excludeIssueInFile(CodeInspector\Issue\InvalidReturnType::CLASS, $this->_file_name)) { if (!$config->excludeIssueInFile(CodeInspector\Issue\InvalidReturnType::CLASS, $this->_file_name)) {
$method_checker->checkReturnTypes(); $method_checker->checkReturnTypes();