From 843f3c3b239337209f7646c730f94827768846b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gr=C3=A9goire=20Paris?= Date: Sun, 13 Nov 2022 11:21:11 +0100 Subject: [PATCH] Make the code easier to statically analyse --- lib/Doctrine/ORM/Mapping/ClassMetadataInfo.php | 15 ++++++++++----- .../ORM/Mapping/Driver/DatabaseDriver.php | 2 +- lib/Doctrine/ORM/Query/Expr.php | 14 ++++++++------ lib/Doctrine/ORM/Query/Parser.php | 2 +- .../ORM/Tools/Console/Command/RunDqlCommand.php | 2 +- 5 files changed, 21 insertions(+), 14 deletions(-) diff --git a/lib/Doctrine/ORM/Mapping/ClassMetadataInfo.php b/lib/Doctrine/ORM/Mapping/ClassMetadataInfo.php index 955c3993f0a..9be1b0176bd 100644 --- a/lib/Doctrine/ORM/Mapping/ClassMetadataInfo.php +++ b/lib/Doctrine/ORM/Mapping/ClassMetadataInfo.php @@ -1574,9 +1574,9 @@ private function isTypedProperty(string $name): bool /** * Validates & completes the given field mapping based on typed property. * - * @param mixed[] $mapping The field mapping to validate & complete. + * @param array{fieldName: string, type?: mixed} $mapping The field mapping to validate & complete. * - * @return mixed[] The updated mapping. + * @return array{fieldName: string, enumType?: string, type?: mixed} The updated mapping. */ private function validateAndCompleteTypedFieldMapping(array $mapping): array { @@ -1631,7 +1631,7 @@ private function validateAndCompleteTypedFieldMapping(array $mapping): array /** * Validates & completes the basic mapping information based on typed property. * - * @param mixed[] $mapping The mapping. + * @param array{type: self::ONE_TO_ONE|self::MANY_TO_ONE|self::ONE_TO_MANY|self::MANY_TO_MANY, fieldName: string, targetEntity?: class-string} $mapping The mapping. * * @return mixed[] The updated mapping. */ @@ -1653,7 +1653,13 @@ private function validateAndCompleteTypedAssociationMapping(array $mapping): arr /** * Validates & completes the given field mapping. * - * @psalm-param array $mapping The field mapping to validate & complete. + * @psalm-param array{ + * fieldName?: string, + * columnName?: string, + * id?: bool, + * generated?: int, + * enumType?: class-string, + * } $mapping The field mapping to validate & complete. * * @return mixed[] The updated mapping. * @@ -1897,7 +1903,6 @@ protected function _validateAndCompleteAssociationMapping(array $mapping) * Validates & completes a one-to-one association mapping. * * @psalm-param array $mapping The mapping to validate & complete. - * @psalm-param array $mapping The mapping to validate & complete. * * @return mixed[] The validated & completed mapping. * @psalm-return array{isOwningSide: mixed, orphanRemoval: bool, isCascadeRemove: bool} diff --git a/lib/Doctrine/ORM/Mapping/Driver/DatabaseDriver.php b/lib/Doctrine/ORM/Mapping/Driver/DatabaseDriver.php index 952ed821656..bf9e27c87ea 100644 --- a/lib/Doctrine/ORM/Mapping/Driver/DatabaseDriver.php +++ b/lib/Doctrine/ORM/Mapping/Driver/DatabaseDriver.php @@ -66,7 +66,7 @@ class DatabaseDriver implements MappingDriver /** @var array|null */ private $tables = null; - /** @var mixed[] */ + /** @var array */ private $classToTableNames = []; /** @psalm-var array */ diff --git a/lib/Doctrine/ORM/Query/Expr.php b/lib/Doctrine/ORM/Query/Expr.php index d593782a135..6c29e8061ca 100644 --- a/lib/Doctrine/ORM/Query/Expr.php +++ b/lib/Doctrine/ORM/Query/Expr.php @@ -9,9 +9,9 @@ use function func_get_args; use function implode; use function is_bool; +use function is_float; +use function is_int; use function is_iterable; -use function is_numeric; -use function is_string; use function iterator_to_array; use function str_replace; @@ -608,7 +608,7 @@ public function length($x) /** * Creates a literal expression of the given argument. * - * @param mixed $literal Argument to be converted to literal. + * @param scalar $literal Argument to be converted to literal. * * @return Expr\Literal */ @@ -620,13 +620,15 @@ public function literal($literal) /** * Quotes a literal value, if necessary, according to the DQL syntax. * - * @param mixed $literal The literal value. + * @param scalar $literal The literal value. */ private function quoteLiteral($literal): string { - if (is_numeric($literal) && ! is_string($literal)) { + if (is_int($literal) || is_float($literal)) { return (string) $literal; - } elseif (is_bool($literal)) { + } + + if (is_bool($literal)) { return $literal ? 'true' : 'false'; } diff --git a/lib/Doctrine/ORM/Query/Parser.php b/lib/Doctrine/ORM/Query/Parser.php index 75f5b3051ad..14d2ae02c5e 100644 --- a/lib/Doctrine/ORM/Query/Parser.php +++ b/lib/Doctrine/ORM/Query/Parser.php @@ -685,7 +685,7 @@ private function processDeferredNewObjectExpressions(SelectStatement $AST): void $fromClassName = $AST->fromClause->identificationVariableDeclarations[0]->rangeVariableDeclaration->abstractSchemaName ?? null; // If the namespace is not given then assumes the first FROM entity namespace - if (! str_contains($className, '\\') && ! class_exists($className) && str_contains($fromClassName, '\\')) { + if (! str_contains($className, '\\') && ! class_exists($className) && is_string($fromClassName) && str_contains($fromClassName, '\\')) { $namespace = substr($fromClassName, 0, strrpos($fromClassName, '\\')); $fqcn = $namespace . '\\' . $className; diff --git a/lib/Doctrine/ORM/Tools/Console/Command/RunDqlCommand.php b/lib/Doctrine/ORM/Tools/Console/Command/RunDqlCommand.php index 90801d1defb..8a0701a71cb 100644 --- a/lib/Doctrine/ORM/Tools/Console/Command/RunDqlCommand.php +++ b/lib/Doctrine/ORM/Tools/Console/Command/RunDqlCommand.php @@ -66,7 +66,7 @@ protected function execute(InputInterface $input, OutputInterface $output) throw new LogicException("Option 'depth' must contain an integer value"); } - $hydrationModeName = $input->getOption('hydrate'); + $hydrationModeName = (string) $input->getOption('hydrate'); $hydrationMode = 'Doctrine\ORM\Query::HYDRATE_' . strtoupper(str_replace('-', '_', $hydrationModeName)); if (! defined($hydrationMode)) {