Le lun. 27 janv. 2020 à 10:19, Nikita Popov <nikita....@gmail.com> a écrit :

> On Wed, Jan 22, 2020 at 4:47 PM Nicolas Grekas <
> nicolas.grekas+...@gmail.com> wrote:
>
>> Hello everyone,
>>
>> as announced last week, I'm officially opening a discussion for adding a
>> "Stringable" interface to PHP 8.
>>
>> The RFC and its rationale are presented here as required:
>> https://wiki.php.net/rfc/stringable
>>
>> The patch is found on GitHub, where some discussions happened already, you
>> might be interested in having a look:
>> https://github.com/php/php-src/pull/5083
>>
>> TL;DR, I think we need an interface to allow passing objects with a
>> __toString() method in a type-safe way, using the string|Stringable type.
>> Here is the stub of the proposal:
>> interface Stringable { public function __toString(): string; }
>>
>> I invite everyone to review the RFC before commenting here as I tried to
>> sum up considerations that some already had before and that you might have
>> too.
>>
>> Cheers,
>> Nicolas
>>
>
> I'm wondering whether it could make sense to automatically implement this
> interface for all classes that define __toString(). Explicitly implementing
> the interface is useful for the transition period (where old PHP versions
> also need to be supported), but when considering only PHP 8 support, I
> think it may make sense to implicitly implement the interface. If the
> __toString() functionality also works fine without implementing the
> interface, and there's probably only going to be relatively few consumers
> of the Stringable type, it will likely be quite common that the interface
> will not get implemented...
>
> Automatically implementing interfaces based on implemented methods could
> also be a general language feature (see Go interfaces for example), but
> likely not one we're interested in having in it's full generality. In this
> particular case, it seems useful though.
>

This looks like a nice improvement to the proposal, it'd be OK on my side.

For the implementation, I might need your help to implement this logic,
especially for extensions, since I suppose we'd like them to also have this
behavior of implicitly declaring the return-type + interface when they
declare the method. Could you please help me achieve that?

Nicolas

Reply via email to