Mercurial > projects > ldc
diff tests/mini/interface6.d @ 341:1bb99290e03a trunk
[svn r362] Started merging the old 'test' dir as well as the newer 'tangotests' dir into 'tests/mini' and 'tests/minicomplex'.
author | lindquist |
---|---|
date | Sun, 13 Jul 2008 02:51:19 +0200 |
parents | test/interface6.d@44a95ac7368a |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tests/mini/interface6.d Sun Jul 13 02:51:19 2008 +0200 @@ -0,0 +1,46 @@ +module interface6; + +extern(C) int printf(char*,...); + +interface I +{ + void Ifunc(); +} + +interface J +{ + void Jfunc(); +} + +class C : I,J +{ + int i; + int j; + void Ifunc() + { + i++; + } + void Jfunc() + { + j++; + } +} + +void main() +{ + C c = new C; + c.Ifunc(); + c.Jfunc(); + I i = c; + i.Ifunc(); + J j = c; + j.Jfunc(); + C c2 = cast(C)i; + c2.Ifunc(); + c2.Jfunc(); + C c3 = cast(C)j; + c3.Ifunc(); + c3.Jfunc(); + assert(c.i == 4); + assert(c.j == 4); +}