Hey Marc,

On 18.3.2024 08:53:01, Marc Bennewitz wrote:
Hi Bob,

On 17.03.24 14:59, Bob Weinand wrote:
On 17.3.2024 13:23:04, Marc Bennewitz wrote:
Hello internals,

I have opened the vote for the "Rounding Integers as int" RFC:
https://wiki.php.net/rfc/integer-rounding

Do to Easter weekend the vote will run for two weeks and two days until Tue the 2nd of April 2024.

Best regards,

Marc Bennewitz

Hey Marc,

I've voted no; it should be just changed without any force_float parameter. Just always return int when possible (and the input was int). If users wish to have the old behaviour, they should just explicitly cast via (float).

The effective BC break of that would be quite small if some things which return float today now would return int. I cannot imagine many cases where this would actually be unwanted. And as said, explicit (float) casts are always possible.

I also dislike force_float, as it cannot just be added to a function in any code which shall be backwards compatible to 8.3 and older. It would just emit Uncaught Error: Unknown named parameter $force_float.

Changing the return type from float to int is a non trivial quite hard to find behavior change.

Imaging code like this:

$x = 800;
$y = 800;
round($x/$y) === 1.0;

This will return false instead of true especially because we teach users to use strict comparison.
Such behavior change should be done in a major version.

I see, here we disagree:
- Strict comparison should be avoided when working with numbers. Strict comparisons are generally for strings and booleans.
- There's no reason to artificially wait years here.

With the additional parameter it's possible to opt-in into the new behavior already in 8.4 while in PHP 9.0 the default behavior will change but previously opted in code does not need to get touched again.

Just changing the behavior means waiting for PHP 9.0 without a way to opt-in in 8.4 already. If you are not interested in opting in in 8.4 already you can just ignore the additional argument as this will be the default in 9.0.
I'm not interested in having an additional parameter I have to carry forward for quite some years.
To mimic the previous behavior in a fully BC way it's as simple as explicitly casting the value to float.

I would rather have preferred to see a static analysis solution how often round()ed results are compared strictly, assess the actual BC impact and possibly encourage tools like Rector to recognize such patterns.


Bob

Regards,
Marc

Bob

Reply via email to