annotate run/alias_04.d @ 1630:d0efa3ae5522 default tip

run/mini/naked_asm5: New x86_64 ABI passes the arguments in reverse order.
author David Nadlinger <code@klickverbot.at>
date Sat, 23 Apr 2011 22:57:32 +0200
parents ec5e144583ea
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
374
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
1 // $HeadURL$
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
2 // $Date$
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
3 // $Author$
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
4
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
5 module dstress.run.alias_04;
0
3269e4627918 init dstress
svnowner
parents:
diff changeset
6
3269e4627918 init dstress
svnowner
parents:
diff changeset
7 class A {
3269e4627918 init dstress
svnowner
parents:
diff changeset
8 int foo(int a) { return 1; }
3269e4627918 init dstress
svnowner
parents:
diff changeset
9 }
3269e4627918 init dstress
svnowner
parents:
diff changeset
10
3269e4627918 init dstress
svnowner
parents:
diff changeset
11 class B : A {
3269e4627918 init dstress
svnowner
parents:
diff changeset
12 int foo( int a, uint b ) { return 2; }
3269e4627918 init dstress
svnowner
parents:
diff changeset
13 }
3269e4627918 init dstress
svnowner
parents:
diff changeset
14
3269e4627918 init dstress
svnowner
parents:
diff changeset
15 class C : B {
3269e4627918 init dstress
svnowner
parents:
diff changeset
16 int foo( int a ) { return 3; }
3269e4627918 init dstress
svnowner
parents:
diff changeset
17 alias B.foo foo;
3269e4627918 init dstress
svnowner
parents:
diff changeset
18 }
3269e4627918 init dstress
svnowner
parents:
diff changeset
19
3269e4627918 init dstress
svnowner
parents:
diff changeset
20 class D : C {
3269e4627918 init dstress
svnowner
parents:
diff changeset
21 }
3269e4627918 init dstress
svnowner
parents:
diff changeset
22
3269e4627918 init dstress
svnowner
parents:
diff changeset
23
3269e4627918 init dstress
svnowner
parents:
diff changeset
24 int main(){
3269e4627918 init dstress
svnowner
parents:
diff changeset
25 D d = new D();
3269e4627918 init dstress
svnowner
parents:
diff changeset
26
1559
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 374
diff changeset
27 if(d.foo(1, 2u) != 2){
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 374
diff changeset
28 assert(0);
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 374
diff changeset
29 }
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 374
diff changeset
30 if(d.foo(1) != 3){
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 374
diff changeset
31 assert(0);
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 374
diff changeset
32 }
0
3269e4627918 init dstress
svnowner
parents:
diff changeset
33 return 0;
1
3414705c41ac removed CVS header
thomask
parents: 0
diff changeset
34 }