Address deprecation of ReflectionType::getClass().
This commit is contained in:
parent
5ec5bfb23c
commit
53b1677a4e
@ -525,7 +525,16 @@ class AutowirePass extends AbstractRecursivePass
|
|||||||
$methodArgumentsMetadata = [];
|
$methodArgumentsMetadata = [];
|
||||||
foreach ($method->getParameters() as $parameter) {
|
foreach ($method->getParameters() as $parameter) {
|
||||||
try {
|
try {
|
||||||
|
if (method_exists($parameter, 'getType')) {
|
||||||
|
$type = $parameter->getType();
|
||||||
|
if ($type && !$type->isBuiltin()) {
|
||||||
|
$class = new \ReflectionClass(method_exists($type, 'getName') ? $type->getName() : (string) $type);
|
||||||
|
} else {
|
||||||
|
$class = null;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
$class = $parameter->getClass();
|
$class = $parameter->getClass();
|
||||||
|
}
|
||||||
} catch (\ReflectionException $e) {
|
} catch (\ReflectionException $e) {
|
||||||
// type-hint is against a non-existent class
|
// type-hint is against a non-existent class
|
||||||
$class = false;
|
$class = false;
|
||||||
|
@ -136,7 +136,7 @@ class ControllerResolver implements ArgumentResolverInterface, ControllerResolve
|
|||||||
} else {
|
} else {
|
||||||
$arguments[] = $attributes[$param->name];
|
$arguments[] = $attributes[$param->name];
|
||||||
}
|
}
|
||||||
} elseif ($param->getClass() && $param->getClass()->isInstance($request)) {
|
} elseif ($this->typeMatchesRequestClass($param, $request)) {
|
||||||
$arguments[] = $request;
|
$arguments[] = $request;
|
||||||
} elseif ($param->isDefaultValueAvailable()) {
|
} elseif ($param->isDefaultValueAvailable()) {
|
||||||
$arguments[] = $param->getDefaultValue();
|
$arguments[] = $param->getDefaultValue();
|
||||||
@ -260,4 +260,22 @@ class ControllerResolver implements ArgumentResolverInterface, ControllerResolve
|
|||||||
|
|
||||||
return $message;
|
return $message;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
private function typeMatchesRequestClass(\ReflectionParameter $param, Request $request)
|
||||||
|
{
|
||||||
|
if (!method_exists($param, 'getType')) {
|
||||||
|
return $param->getClass() && $param->getClass()->isInstance($request);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!($type = $param->getType()) || $type->isBuiltin()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$class = new \ReflectionClass(method_exists($type, 'getName') ? $type->getName() : (string) $type);
|
||||||
|
|
||||||
|
return $class && $class->isInstance($request);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -146,7 +146,7 @@ class OptionsResolver implements Options
|
|||||||
$reflClosure = new \ReflectionFunction($value);
|
$reflClosure = new \ReflectionFunction($value);
|
||||||
$params = $reflClosure->getParameters();
|
$params = $reflClosure->getParameters();
|
||||||
|
|
||||||
if (isset($params[0]) && null !== ($class = $params[0]->getClass()) && Options::class === $class->name) {
|
if (isset($params[0]) && Options::class === $this->getParameterClassName($params[0])) {
|
||||||
// Initialize the option if no previous value exists
|
// Initialize the option if no previous value exists
|
||||||
if (!isset($this->defaults[$option])) {
|
if (!isset($this->defaults[$option])) {
|
||||||
$this->defaults[$option] = null;
|
$this->defaults[$option] = null;
|
||||||
@ -1066,4 +1066,20 @@ class OptionsResolver implements Options
|
|||||||
{
|
{
|
||||||
return (\function_exists($isFunction = 'is_'.$type) && $isFunction($value)) || $value instanceof $type;
|
return (\function_exists($isFunction = 'is_'.$type) && $isFunction($value)) || $value instanceof $type;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string|null
|
||||||
|
*/
|
||||||
|
private function getParameterClassName(\ReflectionParameter $parameter)
|
||||||
|
{
|
||||||
|
if (!method_exists($parameter, 'getType')) {
|
||||||
|
return ($class = $parameter->getClass()) ? $class->name : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!($type = $parameter->getType()) || $type->isBuiltin()) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return method_exists($type, 'getName') ? $type->getName() : (string) $type;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user