Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions framework/helpers/BaseHtml.php
Original file line number Diff line number Diff line change
Expand Up @@ -2316,6 +2316,12 @@
$value = $value->getPrimaryKey(false);

return is_array($value) ? json_encode($value) : $value;
} elseif (version_compare(PHP_VERSION, '8.1.0') >= 0) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this necessary?

$var instanceof \Undefined\Class\Fqcn – it's correct expression in PHP

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I basically reused the same code snippet used on yii\db\Command around line 380 which includes the PHP version check before checking for the enum type. Trying to be consistent with that.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we should use PHP_VERSION_ID >= 80100 in both places - it should be more efficient and consistent with other places.

if ($value instanceof \BackedEnum) {

Check failure on line 2320 in framework/helpers/BaseHtml.php

View workflow job for this annotation

GitHub Actions / PHP 7.4-PHPStan

Class BackedEnum not found.
$value = $value->value;

Check failure on line 2321 in framework/helpers/BaseHtml.php

View workflow job for this annotation

GitHub Actions / PHP 7.4-PHPStan

Access to property $value on an unknown class BackedEnum.
} elseif ($value instanceof \UnitEnum) {

Check failure on line 2322 in framework/helpers/BaseHtml.php

View workflow job for this annotation

GitHub Actions / PHP 7.4-PHPStan

Class UnitEnum not found.
$value = $value->name;

Check failure on line 2323 in framework/helpers/BaseHtml.php

View workflow job for this annotation

GitHub Actions / PHP 7.4-PHPStan

Access to property $name on an unknown class UnitEnum.
}
}

return $value;
Expand Down
7 changes: 7 additions & 0 deletions framework/validators/RangeValidator.php
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,13 @@
{
$range = [];
foreach ($this->range as $value) {
if (version_compare(PHP_VERSION, '8.1.0') >= 0) {
if ($value instanceof \BackedEnum) {

Check failure on line 128 in framework/validators/RangeValidator.php

View workflow job for this annotation

GitHub Actions / PHP 7.4-PHPStan

Class BackedEnum not found.
$value = $value->value;

Check failure on line 129 in framework/validators/RangeValidator.php

View workflow job for this annotation

GitHub Actions / PHP 7.4-PHPStan

Access to property $value on an unknown class BackedEnum.
} elseif ($value instanceof \UnitEnum) {

Check failure on line 130 in framework/validators/RangeValidator.php

View workflow job for this annotation

GitHub Actions / PHP 7.4-PHPStan

Class UnitEnum not found.
$value = $value->name;

Check failure on line 131 in framework/validators/RangeValidator.php

View workflow job for this annotation

GitHub Actions / PHP 7.4-PHPStan

Access to property $name on an unknown class UnitEnum.
}
}

Check failure on line 133 in framework/validators/RangeValidator.php

View workflow job for this annotation

GitHub Actions / PHP 8.4-PHP_CodeSniffer

Whitespace found at end of line
$range[] = (string) $value;
}
$options = [
Expand Down
Loading