On Saturday, 9 March 2024 at 16:00, Larry Garfield <la...@garfieldtech.com> wrote:
> I am still opposed to this. Logically, ceil/float/round should be returning > ints, not floats. Only returning ints if it was given an int is, er, kinda > pointless, as you'll just get back the value you passed in. (Because it's > already rounded/floored, etc.) So this doesn't get us any new type safety, > but does make the return type less consistent than it is today. That's a step > backwards. > > If there's some math reason that we cannot have those functions return int > (someone mentioned there was, but I don't really understand it and the RFC > does not explain it at all), then we should at least keep consistency in the > return type. "Sometimes I have to cast the return value before I can actually > use it in the obvious way, sometimes I don't" is not a good situation. > > --Larry Garfield There are plenty of values that are exactly representable as floating point numbers but not as integers. One short example: $v = 1e10 + 0.6; var_dump($v); var_dump(round($v)); Gives you accurate precision and proper rounding behaviour. 1e10 *cannot* be represented as an integer. So round *must* be able to return a float. Best regards, Gina P. Banyard