Mercurial > projects > ldc
view gen/abi-generic.h @ 1512:09734fb929c0
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.
author | Christian Kamm <kamm incasoftware de> |
---|---|
date | Sun, 21 Jun 2009 19:05:24 +0200 |
parents | 34f2fd925de3 |
children |
line wrap: on
line source
#ifndef LDC_GEN_ABI_GENERIC #define LDC_GEN_ABI_GENERIC #include "gen/llvmhelpers.h" #include "gen/tollvm.h" #include "gen/structs.h" /// Removes padding fields for (non-union-containing!) structs struct RemoveStructPadding : ABIRewrite { /// get a rewritten value back to its original form virtual LLValue* get(Type* dty, DValue* v) { LLValue* lval = DtoAlloca(dty, ".rewritetmp"); // Make sure the padding is zero, so struct comparisons work. // TODO: Only do this if there's padding, and/or only initialize padding. DtoMemSetZero(lval, DtoConstSize_t(getTypePaddedSize(DtoType(dty)))); DtoPaddedStruct(dty, v->getRVal(), lval); return lval; } /// get a rewritten value back to its original form and store result in provided lvalue /// this one is optional and defaults to calling the one above virtual void getL(Type* dty, DValue* v, llvm::Value* lval) { DtoPaddedStruct(dty, v->getRVal(), lval); } /// put out rewritten value virtual LLValue* put(Type* dty, DValue* v) { return DtoUnpaddedStruct(dty, v->getRVal()); } /// return the transformed type for this rewrite virtual const LLType* type(Type* dty, const LLType* t) { return DtoUnpaddedStructType(dty); } }; #endif