Skip to content

Difference between Instance and Static properties #3906

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Open
wants to merge 17 commits into
base: 2.1.x
Choose a base branch
from
Open
Prev Previous commit
Next Next commit
Solve deprecation
  • Loading branch information
VincentLanglet committed May 13, 2025
commit 2e344f6004f7e88e8991a815142b651097eee232
8 changes: 4 additions & 4 deletions src/Dependency/DependencyResolver.php
Original file line number Diff line number Diff line change
Expand Up @@ -253,7 +253,7 @@ public function resolveDependencies(Node $node, Scope $scope): NodeDependencies
}

if ($node->name instanceof Node\Identifier) {
$propertyReflection = $scope->getPropertyReflection($fetchedOnType, $node->name->toString());
$propertyReflection = $scope->getInstancePropertyReflection($fetchedOnType, $node->name->toString());
if ($propertyReflection !== null) {
$this->addClassToDependencies($propertyReflection->getDeclaringClass()->getName(), $dependenciesReflections);
}
Expand Down Expand Up @@ -369,13 +369,13 @@ public function resolveDependencies(Node $node, Scope $scope): NodeDependencies
$className = $scope->resolveName($node->class);
if ($this->reflectionProvider->hasClass($className)) {
$propertyClassReflection = $this->reflectionProvider->getClass($className);
if ($propertyClassReflection->hasProperty($node->name->toString())) {
$propertyReflection = $propertyClassReflection->getProperty($node->name->toString(), $scope);
if ($propertyClassReflection->hasStaticProperty($node->name->toString())) {
$propertyReflection = $propertyClassReflection->getStaticProperty($node->name->toString(), $scope);
$this->addClassToDependencies($propertyReflection->getDeclaringClass()->getName(), $dependenciesReflections);
}
}
} else {
$propertyReflection = $scope->getPropertyReflection($scope->getType($node->class), $node->name->toString());
$propertyReflection = $scope->getStaticPropertyReflection($scope->getType($node->class), $node->name->toString());
if ($propertyReflection !== null) {
$this->addClassToDependencies($propertyReflection->getDeclaringClass()->getName(), $dependenciesReflections);
}
Expand Down