annotate tests/mini/bug9.d @ 715:30b42a283c8e

Removed TypeOpaque from DMD. Changed runtime functions taking opaque[] to void[]. Implemented proper type painting, to avoid "resizing" array casts in runtime calls that previously took opaque[]. Implemented dynamic arrays as first class types, this implements proper ABI for these types on x86. Added dwarf region end after call to assert function, fixes some problems with llvm not allowing this to be missing. Reverted change to WithStatement from rev [704] it breaks MiniD, mini/with2.d needs to be fixed some other way... Fixed tango bug 1339 in runtime, problem with _adReverseChar on invalid UTF-8. Disabled .bc generation in the compiler runtime part, genobj.d triggers some llvm bug when using debug info. the .o seems to work fine.
author Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
date Wed, 22 Oct 2008 14:55:33 +0200
parents 1bb99290e03a
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