[wp-trac] [WordPress Trac] #60725: class-wp-widget fatal error in PHP 8.2
WordPress Trac
noreply at wordpress.org
Thu Mar 7 16:09:17 UTC 2024
#60725: class-wp-widget fatal error in PHP 8.2
--------------------------+------------------------------
Reporter: markhowe | Owner: (none)
Type: defect (bug) | Status: new
Priority: normal | Milestone: Awaiting Review
Component: Widgets | Version: 6.4.3
Severity: normal | Resolution:
Keywords: | Focuses:
--------------------------+------------------------------
Changes (by sabernhardt):
* component: General => Widgets
Old description:
> PHP Fatal error: Uncaught ArgumentCountError: Too few arguments to
> function WP_Widget::__construct(), 0 passed in
> /nas/content/live/bishopslawdev1/wp-includes/class-wp-widget-factory.php
> on line 62 and at least 2 expected in /nas/content/live/bishopslawdev1
> /wp-includes/class-wp-widget.php:163
>
> This error seems to have been identified previously, but without pointing
> to the file where the source of the problem lies (i.e. class-wp-widget-
> factory.php ). A simple Google search shows that a number of people who
> are using a theme that makes use of the wp-widget class have seen this
> fatal error when they have tried to upgrade to PHP 8.
>
> Comparing the 'new $widget()' call in class-wp-widget-factory.php with
> the constructor in class-wp-widget.php shows clearly that the constructor
> expects at least two arguments, but that class-wp-widget-factory.php
> supplies none. The fix that has been suggested (and which works on PHP
> 8.2) is the following:
> public function register( $widget ) {
> if ( $widget instanceof WP_Widget ) {
> $this->widgets[ spl_object_hash( $widget ) ] = $widget;
> } else {
> // $this->widgets[ $widget ] = new $widget(); <---- the
> current line 62 ---------
> $this->widgets[ $widget ] = new $widget($widget, $widget); //
> fix for PHP 8
> }
> }
>
> Perhaps there is a more elegant solution, but this does work, and I have
> this version of the file running on a live server. Of course, each time I
> upgrade to the latest version of WordPress this file gets overwritten...
> So I would be very grateful if the current file could be made PHP 8
> ready.
New description:
`PHP Fatal error: Uncaught ArgumentCountError: Too few arguments to
function WP_Widget::__construct(), 0 passed in /.../wp-includes/class-wp-
widget-factory.php on line 62 and at least 2 expected in /.../wp-includes
/class-wp-widget.php:163`
This error seems to have been identified previously, but without pointing
to the file where the source of the problem lies (i.e. `class-wp-widget-
factory.php` ). A simple Google search shows that a number of people who
are using a theme that makes use of the wp-widget class have seen this
fatal error when they have tried to upgrade to PHP 8.
Comparing the `new $widget()` call in `class-wp-widget-factory.php` with
the constructor in `class-wp-widget.php` shows clearly that the
constructor expects at least two arguments, but that `class-wp-widget-
factory.php` supplies none. The fix that has been suggested (and which
works on PHP 8.2) is the following:
{{{
public function register( $widget ) {
if ( $widget instanceof WP_Widget ) {
$this->widgets[ spl_object_hash( $widget ) ] = $widget;
} else {
// $this->widgets[ $widget ] = new $widget(); <---- the
current line 62 ---------
$this->widgets[ $widget ] = new $widget($widget, $widget); //
fix for PHP 8
}
}
}}}
Perhaps there is a more elegant solution, but this does work, and I have
this version of the file running on a live server. Of course, each time I
upgrade to the latest version of WordPress this file gets overwritten...
So I would be very grateful if the current file could be made PHP 8 ready.
--
--
Ticket URL: <https://core.trac.wordpress.org/ticket/60725#comment:1>
WordPress Trac <https://core.trac.wordpress.org/>
WordPress publishing platform
More information about the wp-trac
mailing list