Mercurial > projects > ldc
view tests/minicomplex/vararg2.d @ 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 | 1bb99290e03a |
children |
line wrap: on
line source
module tangotests.vararg2; extern(C) int printf(char*, ...); import tango.core.Vararg; void main() { func(0xf00, 1, " ", 2, " ", 3, "\n", 0.3, "\n"); } void func(int foo, ...) { foreach(t; _arguments) { if (t == typeid(char[])) { char[] str = va_arg!(char[])(_argptr); printf("%.*s", str.length, str.ptr); } else if (t == typeid(int)) { printf("%d", va_arg!(int)(_argptr)); } else if (t == typeid(float)) { printf("%f", va_arg!(float)(_argptr)); } else if (t == typeid(double)) { printf("%f", va_arg!(double)(_argptr)); } else if (t == typeid(real)) { printf("%f", va_arg!(real)(_argptr)); } else { assert(0, "not int"); } } }