Mercurial > projects > ldc
view tests/mini/s.d @ 1168:ab186e535e72
A different fix to #218 and DMD2682 that does not lead to constant folding regressions.
Fixes run/const_15, run/c/const_16_B.
The price is removing the lvalueness of struct literals. If it turns out too
much code depends on this behavior or we don't want to break with DMD, we
could keep struct literals as lvalues and instead convert struct literals used
as expression initializers into struct initializers.
author | Christian Kamm <kamm incasoftware de> |
---|---|
date | Sun, 29 Mar 2009 11:43:45 +0200 |
parents | d92acb81a583 |
children |
line wrap: on
line source
module s; interface Inter { void inter(); } interface Inter2 { void inter2(); } interface InterOne : Inter { void interOne(); } abstract class ClassAbstract : InterOne { abstract void inter(); abstract void interOne(); } class TheClassOne : ClassAbstract { void inter() { } void interOne() { } } class TheClassTwo : TheClassOne, Inter2 { long l; double d; void inter2() { } } extern(C) int printf(char*, ...); void main() { printf("classinfo test\n"); { auto c = new TheClassOne; { auto ci = c.classinfo; printf("ci = %.*s\n", ci.name.length, ci.name.ptr); printf("ci.interfaces.length = %lu\n", ci.interfaces.length); foreach (i, iface; ci.interfaces) printf("i[%d] = %.*s\n", i, iface.classinfo.name.length, iface.classinfo.name.ptr); } } { auto c = new TheClassTwo; { auto ci = c.classinfo; printf("ci = %.*s\n", ci.name.length, ci.name.ptr); printf("ci.interfaces.length = %lu\n", ci.interfaces.length); foreach (i, iface; ci.interfaces) printf("i[%d] = %.*s\n", i, iface.classinfo.name.length, iface.classinfo.name.ptr); } InterOne i = c; { auto ci = i.classinfo; printf("ci = %.*s\n", ci.name.length, ci.name.ptr); } auto i2 = cast(Inter2)c; { auto ci = i2.classinfo; printf("ci = %.*s\n", ci.name.length, ci.name.ptr); } auto o = cast(Object)i2; { auto ci = o.classinfo; printf("ci = %.*s\n", ci.name.length, ci.name.ptr); } } }