-
Notifications
You must be signed in to change notification settings - Fork 11.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[8.x] Add explicit @return
annotations in {@inheritdoc}
from vendors and add some missing #[\ReturnTypeWillChange]
#38819
Conversation
@return
annotations in {@inheritdoc}
from vendors and add some missing #[\ReturnTypeWillChange]
@return
annotations in {@inheritdoc}
from vendors and add some missing #[\ReturnTypeWillChange]
ecf8170
to
0e0e862
Compare
Can you target our |
0e0e862
to
39ba47f
Compare
39ba47f
to
520a802
Compare
Oh, didn't realize Laravel was using this type of branching strategy. PR rebased! |
Thanks. Yeh, it's only temporary. We'll be merging shortly. :) |
Thanks for the quick review and merge! 🚀 |
* Add ReturnTypeWillChange to SessionHandlerInterface usages * Bump commonmark * Fix getIterator * Use Symfony 5.4 components * Dev mockery * Mimic PHP 8.0 * Try removing symfony components * Mockery * Fix type errors in db tests (#38696) * Fix type errors in db tests * Apply fixes from StyleCI Co-authored-by: Taylor Otwell <[email protected]> * Additional DB test fixes (#38699) * More DB fixes (#38700) * PHP 8.1 prefer-lowest builds * Remove skipping PHP 8.1 builds * Bump PHPUnit * Revert "PHP 8.1 prefer-lowest builds" This reverts commit d5b01d2. * [8.x] Adds PHP 8.1 support to serializable closures (#38801) * Makes serializable closures work with PHP 8.1 * Apply fixes from StyleCI * Fixes PHP 7.3 tests * Refactors * Updates deprecated warning Co-authored-by: Dries Vints <[email protected]> * Fixes restoring properties * Update QueueServiceProvider.php Co-authored-by: Taylor Otwell <[email protected]> Co-authored-by: Dries Vints <[email protected]> Co-authored-by: Taylor Otwell <[email protected]> * Fix default value * Fix mb_strlen value * Adds `continue-on-error` for PHP 8.1 * [8.x] Add explicit `@return` annotations in `{@inheritdoc}` from vendors and add some missing `#[\ReturnTypeWillChange]` (#38819) * Add explicit `@return` to `{@inheritdoc}` PHPDoc * Use `return null;` when the return type is `null` * Skips PHP 8.1 failing tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Update SerializableClosure.php Co-authored-by: Graham Campbell <[email protected]> Co-authored-by: Taylor Otwell <[email protected]> Co-authored-by: Nuno Maduro <[email protected]> Co-authored-by: Taylor Otwell <[email protected]> Co-authored-by: Wouter J <[email protected]>
* Add ReturnTypeWillChange to SessionHandlerInterface usages * Bump commonmark * Fix getIterator * Use Symfony 5.4 components * Dev mockery * Mimic PHP 8.0 * Try removing symfony components * Mockery * Fix type errors in db tests (laravel#38696) * Fix type errors in db tests * Apply fixes from StyleCI Co-authored-by: Taylor Otwell <[email protected]> * Additional DB test fixes (laravel#38699) * More DB fixes (laravel#38700) * PHP 8.1 prefer-lowest builds * Remove skipping PHP 8.1 builds * Bump PHPUnit * Revert "PHP 8.1 prefer-lowest builds" This reverts commit d5b01d2. * [8.x] Adds PHP 8.1 support to serializable closures (laravel#38801) * Makes serializable closures work with PHP 8.1 * Apply fixes from StyleCI * Fixes PHP 7.3 tests * Refactors * Updates deprecated warning Co-authored-by: Dries Vints <[email protected]> * Fixes restoring properties * Update QueueServiceProvider.php Co-authored-by: Taylor Otwell <[email protected]> Co-authored-by: Dries Vints <[email protected]> Co-authored-by: Taylor Otwell <[email protected]> * Fix default value * Fix mb_strlen value * Adds `continue-on-error` for PHP 8.1 * [8.x] Add explicit `@return` annotations in `{@inheritdoc}` from vendors and add some missing `#[\ReturnTypeWillChange]` (laravel#38819) * Add explicit `@return` to `{@inheritdoc}` PHPDoc * Use `return null;` when the return type is `null` * Skips PHP 8.1 failing tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Skips some more PHP 8.1 related tests * Update SerializableClosure.php Co-authored-by: Graham Campbell <[email protected]> Co-authored-by: Taylor Otwell <[email protected]> Co-authored-by: Nuno Maduro <[email protected]> Co-authored-by: Taylor Otwell <[email protected]> Co-authored-by: Wouter J <[email protected]>
This PR introduces an
@return
annotation in PHPDoc blocks that reference{@inheritdoc}
from a vendor (i.e. noIlluminate
root namespace). This removes the need to rely on external knowledge to get some understanding of the annotations.Besides that, this also functions as an opt-out for the type deprecations triggered by Symfony as of 5.4. Their function is similar to the
#[\ReturnTypeWillChange]
attribute: tell static analysers that you know the return type of the parent can be converted to a real type at any release, but you don't want to add the real type yourself yet (I think you will probably add these in Laravel 9?).The type patcher script also discovered
some missing2 cases where#[\ReturnTypeWillChange]
attributes (causing deprecations on PHP 8.1) andreturn;
was used in combination with anull
return type. The latter produces a fatal error once the type is introduced (https://3v4l.org/bK7Vt)