On Sat, 11 Apr 2020 at 23:29, Gabriel Caruso <carusogabrie...@gmail.com> wrote:
> On Sat, 11 Apr 2020 at 22:40, Gabriel Caruso <carusogabrie...@gmail.com> > wrote: > >> On Tue, 7 Apr 2020 at 12:55, Claude Pache <claude.pa...@gmail.com> wrote: >> >>> >>> Le 5 avr. 2020 à 16:01, Gabriel Caruso <carusogabrie...@gmail.com> a >>> écrit : >>> >>> Hello, internals. >>> >>> Hereby you can find the RFC Document that I want to discuss as suggested >>> via https://externals.io/message/109416 and >>> https://externals.io/message/107990: >>> >>> https://wiki.php.net/rfc/magic-methods-signature >>> >>> Best regards, >>> >>> -- Gabriel Caruso >>> >>> >>> Hi, >>> >> >> Hello Claude, >> >> >>> >>> Regarding __construct(), etc. Since those methods are not supposed to >>> return anything, they ought to accept the `void` return pseudo-type in >>> their signature, which means exactly that: “do not return anything”. I >>> consider that the current behaviour (i.e., not accepting the `: void` >>> signature) as a bug, and was very surprised when I stumbled on it. >>> >>> >> I'll add to the RFC adding the possibility of typing the `__construct()` >> as `: void` as one of the changes. >> >> >>> ------------ >>> >>> Also, I raise the following question: >>> >>> Should omitted types be added implicitly? I.e., if I write: `function >>> __toString() { }` should the compiler interpret it as `function >>> __toString(): string { }` ? (Currently, it is not the case.) >>> >>> Doing so would raise BC concerns for some, uh, creative uses of magic >>> methods. On the other hand, that may help to add progressively type >>> informations on magic methods, since there is no need to synchronise >>> manually classes and subclasses (the compiler would do it automatically for >>> you). Concrete example here: https://3v4l.org/hTMvA >>> >>> >> This RFC does not cover analyzing the return of magic methods nor adding >> simplicity types. I'll add a note about it in the RFC. >> >> >>> —Claude >>> >> >> Thanks! >> > > Btw, the problem that you reported about incompatible signatures will be > fixed on PHP 8: https://3v4l.org/hTMvA/rfc#git-php-master. > > I've also added a test on the implementation ensuring the following: > https://3v4l.org/5010J/rfc#git-php-master. > > Thanks! > > -- Gabriel Caruso > RFC and implementation have been updated. I'll open it for voting this Friday (17-04-2020) if there's anything else to discuss. Best regards,