annotate run/function_02.d @ 1619:bebc7472a832

Fix #7.
author Christian Kamm <kamm incasoftware de>
date Sat, 07 Nov 2009 18:55:30 +0100
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 }