Skip to content

Commit

Permalink
YoastCS rules: verify return type annotations
Browse files Browse the repository at this point in the history
This sniff:
* Disallows plain `array` type annotations. These should always be made specific.
* Flags missing type annotations.

Optionally the sniff can enforce PHP native type declarations instead of annotations in a docblock.

This functionality has been **disabled** for the following reasons:
* Adding type declarations without using `strict_types` leads to bugs as the original (scalar) data will be juggled by PHP, even if the original data was never correct to start with. The loss of the type information of the original data passed, means that the function can no longer discern whether the input is invalid/incorrect.
    Think: a function expecting an integer, but being passed `false`. This will be juggled to `0`, while it should have been flagged as unusable input.
* Adding `strict_types` in the context of WP is a no-no to begin with as it can cause fatal errors (= white screen of death) when the exceptions are not caught and they generally are not caught and WP doesn't have a native exception handler in place either.
* Adding `strict_types` is useless anyway as it is only enforced for files containing such a declaration, which means that parameters passed to a function call from an external source which doesn't have the `strict_types` declaration (callback called from WP) will still be juggled, which again leads to bugs.
* Adding type declarations in functions hooked into WP filters is especially dangerous due to the loss of type info.

All in all, with the type system offered by PHP as-is, adding PHP native type declarations is next to useless unless you have full control of all code + the environment the code is being run on, which for the Yoast code is just not the case (with the exception of Platform).

Related to 303

Impact on Yoast packages:

| Plugin/Tool       | Errors/Warnings |
|-------------------|-----------------|
| PHPUnit Polyfills | 22
| WP Test Utils     | 9
| YoastCS           | --
| WHIP              | 5
| Yoast Test Helper | 21
| Duplicate Post    | 44
| Yst ACF           | 5
| Yst WooCommerce   | 48
| Yst News          | 22
| Yst Local         | 132
| Yst Video         | 237
| Yst Premium       | 269
| Yst Free          | 1066
  • Loading branch information
jrfnl committed Dec 14, 2023
1 parent f982b95 commit e5eb7c0
Showing 1 changed file with 18 additions and 0 deletions.
18 changes: 18 additions & 0 deletions Yoast/ruleset.xml
Original file line number Diff line number Diff line change
Expand Up @@ -369,6 +369,24 @@
<exclude name="SlevomatCodingStandard.TypeHints.ParameterTypeHint.MissingNativeTypeHint"/>
</rule>

<!-- Check return type information, but don't enforce native type declarations. -->
<rule ref="SlevomatCodingStandard.TypeHints.ReturnTypeHint">
<properties>
<!-- PHP 8.0+. -->
<property name="enableStaticTypeHint" value="false"/>
<property name="enableMixedTypeHint" value="false"/>
<property name="enableUnionTypeHint" value="false"/>
<!-- PHP 8.1+. -->
<property name="enableIntersectionTypeHint" value="false"/>
<property name="enableNeverTypeHint" value="false"/>
<!-- PHP 8.2+. -->
<property name="enableStandaloneNullTrueFalseTypeHints" value="false"/>
</properties>

<exclude name="SlevomatCodingStandard.TypeHints.ReturnTypeHint.MissingNativeTypeHint"/>
<exclude name="SlevomatCodingStandard.TypeHints.ReturnTypeHint.UselessAnnotation"/>
</rule>

<!-- CS: don't allow "// end class" comments and the likes. -->
<rule ref="PSR12.Classes.ClosingBrace"/>

Expand Down

0 comments on commit e5eb7c0

Please sign in to comment.