From f8d5a252ebfd7788040b4bf3a4df0f6d5463abb3 Mon Sep 17 00:00:00 2001 From: Brad Jorsch Date: Tue, 28 May 2024 14:33:52 -0400 Subject: [PATCH] constants: Fix type for `set_constant()` value (#37606) PHP's `define()` allows any of int|float|string|bool|array|null, so let's go with that to match. This fixes 57 Phan issues across the monorepo. --- Just as I was about to create this PR, #36968 changed it to `scalar`. Which fixed 54 of those 57 errors, but as it left out the possibility of array and null 3 were still left. --- projects/packages/constants/.phan/baseline.php | 5 +---- .../constants/changelog/fix-phan-issues-in-constants-pkg | 4 ++++ projects/packages/constants/src/class-constants.php | 4 ++-- 3 files changed, 7 insertions(+), 6 deletions(-) create mode 100644 projects/packages/constants/changelog/fix-phan-issues-in-constants-pkg diff --git a/projects/packages/constants/.phan/baseline.php b/projects/packages/constants/.phan/baseline.php index 52e0bc845738c..3df50068147ad 100644 --- a/projects/packages/constants/.phan/baseline.php +++ b/projects/packages/constants/.phan/baseline.php @@ -8,12 +8,9 @@ * (can be combined with --load-baseline) */ return [ - // # Issue statistics: - // PhanTypeMismatchArgumentProbablyReal : 3 occurrences - + // This baseline has no suppressions // Currently, file_suppressions and directory_suppressions are the only supported suppressions 'file_suppressions' => [ - 'tests/php/test-constants.php' => ['PhanTypeMismatchArgumentProbablyReal'], ], // 'directory_suppressions' => ['src/directory_name' => ['PhanIssueName1', 'PhanIssueName2']] can be manually added if needed. // (directory_suppressions will currently be ignored by subsequent calls to --save-baseline, but may be preserved in future Phan releases) diff --git a/projects/packages/constants/changelog/fix-phan-issues-in-constants-pkg b/projects/packages/constants/changelog/fix-phan-issues-in-constants-pkg new file mode 100644 index 0000000000000..d592e0686c904 --- /dev/null +++ b/projects/packages/constants/changelog/fix-phan-issues-in-constants-pkg @@ -0,0 +1,4 @@ +Significance: patch +Type: fixed + +Fix phpdoc type on `Constants::set_constant()` value parameter. diff --git a/projects/packages/constants/src/class-constants.php b/projects/packages/constants/src/class-constants.php index 3aca201c1b9f3..45768a941c66a 100644 --- a/projects/packages/constants/src/class-constants.php +++ b/projects/packages/constants/src/class-constants.php @@ -91,8 +91,8 @@ public static function get_constant( $name ) { /** * Sets the value of the "constant" within constants Manager. * - * @param string $name The name of the constant. - * @param scalar $value The value of the constant. + * @param string $name The name of the constant. + * @param int|float|string|bool|array|null $value The value of the constant. */ public static function set_constant( $name, $value ) { self::$set_constants[ $name ] = $value;