annotate test/classes9.d @ 314:8d98e42ece93 trunk

[svn r335] The basics of exception handling are in place. Still need to make sure calls are turned into invokes everywhere. (NewExpression for instance) Still some rough edges and corner cases to figure out. Needs testing!
author ChristianK
date Wed, 02 Jul 2008 22:20:18 +0200
parents 5880c12dba83
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
114
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
1 module classes9;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
2
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
3 class C
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
4 {
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
5 }
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
6
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
7 class D : C
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
8 {
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
9 }
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
10
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
11 class E
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
12 {
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
13 }
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
14
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
15 class F : E
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
16 {
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
17 }
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
18
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
19 void main()
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
20 {
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
21 {
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
22 D d = new D;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
23 {
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
24 C c = d;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
25 assert(c !is null);
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
26 D d2 = cast(D)c;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
27 assert(d2 !is null);
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
28 E e = cast(E)d;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
29 assert(e is null);
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
30 F f = cast(F)d;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
31 assert(f is null);
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
32 }
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
33 }
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
34 {
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
35 F f = new F;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
36 {
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
37 E e = f;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
38 assert(e !is null);
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
39 F f2 = cast(F)e;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
40 assert(f2 !is null);
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
41 C c = cast(C)f;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
42 assert(c is null);
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
43 D d2 = cast(D)f;
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
44 assert(d2 is null);
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
45 }
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
46 }
5880c12dba83 [svn r118] Fixed dynamic casts.
lindquist
parents:
diff changeset
47 }