From bf3995144139a90f3e173849b7bfa158b0efa201 Mon Sep 17 00:00:00 2001 From: Sergey Biryukov Date: Sat, 29 Jul 2017 20:34:26 +0000 Subject: [PATCH] Plugins: In `wp_star_rating()`, use explicit type casting for `$rating` to avoid a "non-numeric value encountered" warning in PHP 7.1. Clarify in the function DocBlock that `$rating` can be a float. Props afragen. Fixes #41484. git-svn-id: https://develop.svn.wordpress.org/trunk@41184 602fd350-edb4-49c9-b593-d223f7449a82 --- src/wp-admin/includes/template.php | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/src/wp-admin/includes/template.php b/src/wp-admin/includes/template.php index 32cdc0214e..8385c90670 100644 --- a/src/wp-admin/includes/template.php +++ b/src/wp-admin/includes/template.php @@ -2094,14 +2094,15 @@ function _local_storage_notice() { * @param array $args { * Optional. Array of star ratings arguments. * - * @type int $rating The rating to display, expressed in either a 0.5 rating increment, - * or percentage. Default 0. - * @type string $type Format that the $rating is in. Valid values are 'rating' (default), - * or, 'percent'. Default 'rating'. - * @type int $number The number of ratings that makes up this rating. Default 0. - * @type bool $echo Whether to echo the generated markup. False to return the markup instead - * of echoing it. Default true. + * @type int|float $rating The rating to display, expressed in either a 0.5 rating increment, + * or percentage. Default 0. + * @type string $type Format that the $rating is in. Valid values are 'rating' (default), + * or, 'percent'. Default 'rating'. + * @type int $number The number of ratings that makes up this rating. Default 0. + * @type bool $echo Whether to echo the generated markup. False to return the markup instead + * of echoing it. Default true. * } + * @return string Star rating HTML. */ function wp_star_rating( $args = array() ) { $defaults = array( @@ -2112,11 +2113,11 @@ function wp_star_rating( $args = array() ) { ); $r = wp_parse_args( $args, $defaults ); - // Non-english decimal places when the $rating is coming from a string - $rating = str_replace( ',', '.', $r['rating'] ); + // Non-English decimal places when the $rating is coming from a string + $rating = (float) str_replace( ',', '.', $r['rating'] ); // Convert Percentage to star rating, 0..5 in .5 increments - if ( 'percent' == $r['type'] ) { + if ( 'percent' === $r['type'] ) { $rating = round( $rating / 10, 0 ) / 2; }