annotate tests/mini/bug9.d @ 341:1bb99290e03a trunk

[svn r362] Started merging the old 'test' dir as well as the newer 'tangotests' dir into 'tests/mini' and 'tests/minicomplex'.
author lindquist
date Sun, 13 Jul 2008 02:51:19 +0200
parents test/bug9.d@d9d5d59873d8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
40
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
1 module bug9;
270
d9d5d59873d8 [svn r291] Fixed a bunch of the old Phobos tests to work with Tango.
lindquist
parents: 40
diff changeset
2 extern(C) int printf(char*, ...);
d9d5d59873d8 [svn r291] Fixed a bunch of the old Phobos tests to work with Tango.
lindquist
parents: 40
diff changeset
3
40
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
4 struct rgb
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
5 {
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
6 ubyte[3] values;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
7 rgb average(rgb other)
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
8 {
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
9 rgb res;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
10 foreach (id, ref v; res.values) v=(values[id]+other.values[id])/2;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
11 return res;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
12 }
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
13 void print()
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
14 {
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
15 printf("[%d,%d,%d]\n", values[0], values[1], values[2]);
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
16 }
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
17 }
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
18
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
19 void main()
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
20 {
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
21 rgb a,b;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
22 a.values[0] = 10;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
23 a.values[1] = 20;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
24 a.values[2] = 30;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
25 b.values[0] = 30;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
26 b.values[1] = 20;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
27 b.values[2] = 10;
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
28 rgb avg = a.average(b);
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
29 avg.print();
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
30 assert(avg.values[0] == 20);
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
31 assert(avg.values[1] == 20);
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
32 assert(avg.values[2] == 20);
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
33 }
8b0e809563df [svn r44] Lots of bug fixes.
lindquist
parents:
diff changeset
34