dynamic classes and duck typing

Walter Bright newshound1 at digitalmars.com
Mon Nov 30 22:33:40 PST 2009


Andrei Alexandrescu wrote:
> Bill Baxter wrote:
>> On Mon, Nov 30, 2009 at 7:12 PM, Walter Bright
>> <newshound1 at digitalmars.com> wrote:
>>> Bill Baxter wrote:
>>>> So we can overload on @property-ness?
>>> No.
>>>
>>>> I.e. this works
>>>>
>>>> struct S
>>>> {
>>>> @property
>>>> float x() { return 1.0f; }
>>>> float x() { return 2.0f; }
>>>> }
>>>>
>>>> void main()
>>>> {
>>>>    S  s;
>>>>    writefln("%s", s.x); // writes 1.0
>>>>    writefln("%s", s.x()); // writes 2.0
>>>> }
>>> That just looks wrong.
>>>
>>
>> Ok, so you can't have both dynamic properties and dynamic methods with
>> this.  One or the other, your pick.
>> Seems like an unfortunate limitation.
>>
>> --bb
> 
> It's a limitation similar to not having a field and a method share the 
> same name. It avoids a number of awkward questions such as figuring the 
> meaning of &s.x.

I agree. While the compiler currently doesn't check for mixing up 
properties and methods, I intend to make it do so. I can't see any 
justification for allowing it.



More information about the Digitalmars-d mailing list