From acf647366ff18a0bd6a6bf0ed30567c3ce382b4c Mon Sep 17 00:00:00 2001 From: Sergei Predvoditelev Date: Fri, 18 Oct 2024 21:49:45 +0300 Subject: [PATCH] Improve psalm annotations in `ColumnDefinitionParser` --- src/Syntax/ColumnDefinitionParser.php | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/src/Syntax/ColumnDefinitionParser.php b/src/Syntax/ColumnDefinitionParser.php index 1800596bb..cc7329b87 100644 --- a/src/Syntax/ColumnDefinitionParser.php +++ b/src/Syntax/ColumnDefinitionParser.php @@ -4,8 +4,6 @@ namespace Yiisoft\Db\Syntax; -use Yiisoft\Db\Schema\Column\ColumnFactoryInterface; - use function explode; use function preg_match; use function preg_match_all; @@ -18,8 +16,6 @@ /** * Parses column definition string. For example, `string(255)` or `int unsigned`. - * - * @psalm-import-type ColumnInfo from ColumnFactoryInterface */ final class ColumnDefinitionParser { @@ -30,7 +26,14 @@ final class ColumnDefinitionParser * * @return array The column information. * - * @psalm-return ColumnInfo + * @psalm-return array{ + * enumValues?: list, + * extra?: string, + * scale?: int, + * size?: int, + * type: lowercase-string, + * unsigned?: bool, + * } */ public function parse(string $definition): array { @@ -49,10 +52,12 @@ public function parse(string $definition): array $extra = substr($definition, strlen($matches[0])); - /** @var ColumnInfo */ return $info + $this->extraInfo($extra); } + /** + * @psalm-return array{enumValues: list} + */ private function enumInfo(string $values): array { preg_match_all("/'([^']*)'/", $values, $matches); @@ -60,6 +65,9 @@ private function enumInfo(string $values): array return ['enumValues' => $matches[1]]; } + /** + * @psalm-return array{unsigned?: bool, extra?: string} + */ private function extraInfo(string $extra): array { if (empty($extra)) { @@ -80,6 +88,9 @@ private function extraInfo(string $extra): array return $info; } + /** + * @psalm-return array{size: int, scale?: int} + */ private function sizeInfo(string $size): array { $values = explode(',', $size);