annotate run/function_02.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 c848807fdfcb
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
418
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
1 // $HeadURL$
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
2 // $Date$
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
3 // $Author$
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
4
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
5 // @author@ Benjamin Herr
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
6 // @date@ 2005-04-09
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
7
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
8 module dstress.run.function_02;
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
9
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
10 int status;
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
11
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
12 class Foo {
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
13 this(int i) {
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
14 this.i = i;
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
15 }
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
16
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
17 void f() {
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
18 assert(i==123);
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
19 status++;
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
20 }
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
21
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
22 int i;
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
23 }
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
24
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
25 int main() {
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
26 void function(Foo f) fg = cast(void function(Foo f)) &Foo.f;
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
27
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
28 assert(status==0);
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
29 fg(new Foo(123));
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
30 assert(status==1);
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
31
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
32 return 0;
c848807fdfcb pre recover 1/N
thomask
parents:
diff changeset
33 }