Hello Lukas,
you still cannot ignore basic inheritance or reuse rules. Protocols have
to be respected -> E_FATAL, fix your code.
marcus
Wednesday, February 27, 2008, 1:49:58 PM, you wrote:
> On 26.02.2008, at 04:19, Gregory Beaver wrote:
>> My only objection is that this introduces two new keywords, trait and
>> instead. In addition, this can get very awkward if multiple traits
>> (more than 2) implement the same method name. I would prefer a simple
>> recycling of the "=" sign for both use cases (I'd also accept = for
>> override, "as" for alias).
>>
>> class Talker {
>> use A, B, C, D {
>> smallTalk = A::smallTalk; // this says that if B, C or D implement
>> smallTalk, it is ignored
>> talk = A::bigTalk;
>> }
>> }
> Well this is not just a different syntax, but an entirely different
> approach. In Stefan's proposal one had to explicitly handle every
> conflict manually. in your proposal you do not have to do this. As
> trait's specifically wanted to get away from automatic conflict
> resolution when things overlap, I think that Stefan's proposal makes
> more sense.
> BTW Stefan: Whats the syntax for when you want to override a trait
> method with one inside the class definition?
> I guess one would use "self::" like so:
> class Talker {
> use A, B {
> B::smallTalk instead A::smallTalk;
> self::bigTalk instead B::bigTalk, A::bigTalk;
> A::bigTalk as talk;
> }
> function smallTalk() {
> }
> }
> I also assume that we would mandate signature compatibility (which
> IMHO should only throw an E_STRICT and not a fatal like what we
> currently do for inheritance in PHP6)?
> regards,
> Lukas
Best regards,
Marcus
--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php