fix(php): Fix double to bool casting (use Z_DVAL_P: -0.0 -> false) #24072
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Updates the
IS_DOUBLE
branch to useZ_DVAL_P(from)
instead ofZ_LVAL_P(from)
. The old code was reading from the integer slot, which isn’t defined for doubles and could return garbage.The new logic follows PHP's own casting rules: 0.0 and -0.0 are
false
, everything else (1.5, INF, -INF, NAN) istrue
.Added a PHPT test that fails with the old code but passes with this change.
No API changes, just correctness and consistency with PHP itself.