Make objects.opEquals a template?
Jonathan M Davis via Digitalmars-d
digitalmars-d at puremagic.com
Mon Jul 13 02:26:31 PDT 2015
On Monday, 13 July 2015 at 09:13:06 UTC, Yuxuan Shui wrote:
> On Monday, 13 July 2015 at 09:10:41 UTC, ketmar wrote:
>> On Mon, 13 Jul 2015 06:49:09 +0000, Yuxuan Shui wrote:
>>
>>> The main reason here is to use '==' in @safe code:
>>>
>>> class A {
>>> override @safe bool opEquals(Object o) {
>>> return cast(A)o !is null;
>>> }
>>> }
>>> @safe void main() {
>>> A a = new A;
>>> A b = new A;
>>> a == b;
>>> }
>>>
>>> This doesn't compile in current D, because objects.opEquals
>>> takes two Object, and Object.opEquals is not @safe.
>>>
>>> Why can't we have a template objects.opEquals?
>>>
>>> auto opEquals(T, S)(T a, S b) { ... }
>>
>> 'case templates can't be virtual functions, so the following
>> will not work:
>>
>> bool cmp (Object a, Object b) { return a.opQeuals(b); }
>>
>> MyObj a, b;
>>
>> cmp(a, b);
>
> What do you mean by virtual function? objects.opEquals is not a
> member function.
Currently, Object has a function named opEquals which _is_ a
member function, and it is largely the reason, why opEquals on
classes cannot be @safe - or pure, or nothrow - or even
technically, const (though there's a hack in the free function,
opEquals which casts away const to make const Objects comparable,
which is a pretty dangerous thing to do in reality). Now, there
is a free function called opEquals that calls the opEquals on a
class object, and as I described in another post in this thread,
it's supposed to be templatized at some point, but templatizing
wouldn't allow you to have == be @safe, pure, or nothrow. For
that to work, opEquals on the class itself must have those
attributes, and to do that, opEquals needs to be removed from
Object (as I described in that other post).
- Jonathan M Davis
More information about the Digitalmars-d
mailing list