annotate tests/mini/compile_delegatetuple.d @ 920:545f54041d91

Implemented proper support for naked asm using llvm module level asm. Still not 100% complete, but already 1000 times better that what we had before. Don's BignumX86 implementation from Tango (when turned into a standalone unittest) seems to fully work with no changes, and great performance :) Fixed align N; in asm blocks. Fixed inreg parameter passing on x86 for ref/out params. Removed support for lazy initialization of function local static variables, I have no idea why I ever implemented this, it's not in the D spec, and DMD doesn't support it :P Some of the global variable related changes might cause minor regressions, but they should be easily fixable.
author Tomas Lindquist Olsen <tomas.l.olsen@gmail.com>
date Tue, 03 Feb 2009 08:54:57 +0100
parents cd7da2ba14d1
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
772
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
1 alias char[] string;
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
2 template Unstatic(T) { alias T Unstatic; }
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
3 template Unstatic(T: T[]) { alias T[] Unstatic; }
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
4 template StupleMembers(T...) {
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
5 static if (T.length) {
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
6 const int id=T[0..$-1].length;
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
7 const string str=StupleMembers!(T[0..$-1]).str~"Unstatic!(T["~id.stringof~"]) _"~id.stringof~"; ";
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
8 } else const string str="";
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
9 }
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
10
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
11 struct Stuple(T...) {
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
12 mixin(StupleMembers!(T).str);
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
13 }
cd7da2ba14d1 Fix bug reported by downs. Related to delegate types within tuple template parameters.
Christian Kamm <kamm incasoftware de>
parents:
diff changeset
14 Stuple!(string, void delegate(float)) foo;