Mercurial > projects > ldc
view tests/mini/classes13_bug239.d @ 1619:c61782a76dff
Merge DMD r304: refactor invariant => immutable
---
dmd/cast.c | 2 +-
dmd/declaration.c | 2 +-
dmd/declaration.h | 3 +--
dmd/doc.c | 2 +-
dmd/expression.c | 6 +++---
dmd/interpret.c | 4 ++--
dmd/mtype.c | 2 +-
dmd/mtype.h | 2 +-
dmd/parse.c | 4 ++--
dmd/struct.c | 2 +-
10 files changed, 14 insertions(+), 15 deletions(-)
author | Leandro Lucarella <llucax@gmail.com> |
---|---|
date | Wed, 06 Jan 2010 15:18:22 -0300 |
parents | 9d308feaec27 |
children |
line wrap: on
line source
extern(C) int printf(char*, ...); class A { bool Afoo = false; void foo() { Afoo = true; } } class B : A {} class C : B { bool Cfoo = false; void foo() { Cfoo = true; } } void main() { scope c1 = new C(); c1.foo(); assert(c1.Cfoo && !c1.Afoo); scope c2 = new C(); c2.B.foo(); assert(!c2.Cfoo && c2.Afoo); scope c3 = new C(); c3.A.foo(); assert(!c3.Cfoo && c3.Afoo); }