On Fri, Jan 23, 2026 at 3:17 PM Alexandre Daubois <alex.daubois+php@gmail.com> wrote:
I understand the concern about legacy code. However, if code relies on
(int) "123abc"silently returning123, this represents a data
integrity issue that would benefit from being made explicit. The
deprecation period exists specifically to help identify and address
these cases.Does this behavior als affect parameters being passed in a non-strict fashion? Because then I don’t see a realistic migration path within the next decade for this application.
This behavior already exists and forbids such casts, see
https://3v4l.org/WQJPv#vnull.
Thanks for your reply!
I’ve given it a bit more thought and while I 100% agree with the reasons given, I’m still afraid this change is too big of an unknown break. I do not have voting power, so all I can give is my opinion.
As an alternative, what about this? It could be the best of both worlds where the new behavior is explicit:
$var = (int) '123test'; // still works, nothing changes, becomes an `(int) 123`
int $var = '123test'; // follows the proposed rules, errors because it's not a value that's a valid integer
int $var = '123'; // works because it's a valid integer format, becomes (int) 123
int $var = (int) '123test'; // becomes (int) 123, existing behavior
This way nothing breaks and the casting remains what it is, but we can still enforce correct types. I know the 3rd line might be controversial, but it makes it an opt-in instead of opt-out feature and errors can be thrown as of day 1.
Bonus:
int|null $var = '123test'; // could result in `null` instead of throwing, similar to the Enum tryFrom.
// could enable
MyEnum $foo = '123test';MyEnum|null $bar = '123test';
// translates to
$foo = MyEnum::from('123test');$bar = MyEnum::tryFrom('123test');
from and tryFrom could be taken as base for custom cast functions, but that’s probably a whole different can of worms.