annotate run/opIdentity_01.d @ 1383:52c9e86b6486

@url@ -> @uri@
author thomask
date Sun, 04 Mar 2007 13:07:35 +0000
parents 7e8e5013a030
children d3a3e0c251d8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
236
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
1 // $HeadURL$
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
2 // $Date$
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
3 // $Author$
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
4
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
5 // @author@ teqDruid <me@teqdruid.com>
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
6 // @date@ 2005-01-12
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
7 // @uri@ news:pan.2005.01.12.13.20.54.546749@teqdruid.com
1383
52c9e86b6486 @url@ -> @uri@
thomask
parents: 1086
diff changeset
8 // @uri@ nntp://news.digitalmars.com/digitalmars.D.bugs/2676
236
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
9
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
10 module dstress.run.opIdentity_01;
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
11
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
12 interface I {
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
13 I parent();
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
14 void parent(I i);
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
15 void addChild(I i);
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
16 }
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
17
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
18 interface J : I {
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
19 }
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
20
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
21 class A : I {
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
22 private I myParent;
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
23
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
24 void addChild(I i) {
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
25 i.parent = this;
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
26 }
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
27
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
28 I parent() {
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
29 return myParent;
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
30 }
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
31
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
32 void parent(I parent) {
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
33 myParent = parent;
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
34 }
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
35 }
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
36
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
37 class B : A, J {
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
38 }
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
39
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
40 int main() {
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
41 J a = new B;
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
42 J b = new B;
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
43 a.addChild(b);
1086
7e8e5013a030 gdc-0.19 review
thomask
parents: 570
diff changeset
44 if(!(b.parent is a)){
7e8e5013a030 gdc-0.19 review
thomask
parents: 570
diff changeset
45 assert(0);
7e8e5013a030 gdc-0.19 review
thomask
parents: 570
diff changeset
46 }
236
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
47 return 0;
f842e680b6fb opIdentity for inherited interfaces
thomask
parents:
diff changeset
48 }