|
Revision 1512:09734fb929c0, 326 bytes
(checked in by Christian Kamm <kamm incasoftware de>, 3 years ago)
|
Make == for associative arrays test for equality, not identity.
_aaEq was added to runtime/internal/aaA.d which forwards to
TypeInfo?_AssociativeArray.equals in genobj.d. On the codegen side, DtoAAEquals
was added to gen/aa.cpp and is called from EqualExp::toElem in gen/toir.cpp.
I assume that the frontend will produce an error if == is used on associative
arrays of different type.
This fixes DMD bug 1429.
|
| Line | |
|---|
| 1 |
#ifndef LDC_GEN_AA_H |
|---|
| 2 |
#define LDC_GEN_AA_H |
|---|
| 3 |
|
|---|
| 4 |
DValue* DtoAAIndex(Loc& loc, Type* type, DValue* aa, DValue* key, bool lvalue); |
|---|
| 5 |
DValue* DtoAAIn(Loc& loc, Type* type, DValue* aa, DValue* key); |
|---|
| 6 |
void DtoAARemove(Loc& loc, DValue* aa, DValue* key); |
|---|
| 7 |
LLValue* DtoAAEquals(Loc& loc, TOK op, DValue* l, DValue* r); |
|---|
| 8 |
|
|---|
| 9 |
#endif // LDC_GEN_AA_H |
|---|