rfc:fix_up_bcmath_number_class

This is an old revision of the document!


PHP RFC: Fix up BCMath Number Class / Change GMP bool cast behavior

Introduction

Regarding RFC: Support object type in BCMath, I received several comments and suggestions, so I created this RFC to respond to them.

Also, in those discussions, there were suggestions regarding the behavior of casting GMP classes to bool, and for procedural efficiency, I will combine these into one RFC. (Each vote will be taken separately.)

Proposal

This RFC makes several corrections and changes to the BcMath\Number class and proposes to override the first RFC.

Also proposes that when cast a GMP object to bool, change it so that 0 is false and everything else is true, like an int.

Details of the proposal regarding BCMath are as follows:

  1. Casting a Number object to bool makes it false if it is 0 and true otherwise.
  2. Of the six comparison methods comp(), eq(), gt(), gte(), lt(), lte(), remove five except comp().
  3. Remove format method.
  4. Fixed typo in stub.

bool cast

Change both GMP and BCMath to behave like int.

BCMath

More information about comparison methods

In fact, only need the comp() method to fulfill the functionality of the other five methods.

Adding methods later is easy, but removing them always involves a BC Break. Providing 6 methods from the start is obviously overkill, so will only provide comp().

By the way, the reason comp() is needed, and why comparison operators are underpowered, is to specify the scale to use for the comparison.

Remove format method

The optimal format varies greatly from country to country, and the signature proposed in the original RFC is insufficient. There are also opinions that such functionality should be implemented in Intl rather than BCMath.

If released in a half-finished state, BC Break will become a problem later, so this feature will be removed. If this functionality is really needed for this class, we can always consider adding it again.

Fixed typo in stub

This probably doesn't require an RFC per se, but I'll make it explicit to keep things clear.

public function pow(Number|string|int $exponent, int $minScale, ?int $scale = null, int $roundingMode = PHP_ROUND_HALF_UP): Number {}

I forgot to delete int $minScale in this signature. Correctly, it should look like this:

public function pow(Number|string|int $exponent, ?int $scale = null, int $roundingMode = PHP_ROUND_HALF_UP): Number {}

Backward Incompatible Changes

BCMath: None.

GMP: Code like if ($gmp) {} will behave differently. However, due to the nature of GMP, such codes are likely to be quite rare.

Proposed PHP Version(s)

next PHP 8.x (8.4)

RFC Impact

To SAPIs

None.

To Existing Extensions

BCMath: only BCMath

GMP: only GMP

To Opcache

None.

New Constants

None.

php.ini Defaults

None.

Open Issues

None.

Unaffected PHP Functionality

BCMath: nothing other than BCMath is affected.

GMP: nothing other than GMP is affected.

Future Scope

BCMath: Methods removed in this RFC may be considered for implementation again in the future. However, there are no specific plans at this time.

Proposed Voting Choices

As per the voting RFC a yes/no vote with a 2/3 majority is needed for this proposal to be accepted.

This RFC combines two RFCs into one for procedural efficiency, and the BCMath and GMP proposals will be voted on separately. This means that the two RFCs are completely independent and do not influence each other's voting results.

These are not second-round votes, so each requires a two-thirds majority vote to pass.

Patches and Tests

None.

Implementation

None.

References

Rejected Features

Some methods will be removed, but since this class has not been released yet, essentially no functionality will be removed.

rfc/fix_up_bcmath_number_class.1719760488.txt.gz · Last modified: 2024/06/30 15:14 by saki