annotate nocompile/bug_mtype_3154.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 774e02c900da
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
140
a33ad7189d21 1) news:// -> news:
thomask
parents: 111
diff changeset
1 // $HeadURL$
a33ad7189d21 1) news:// -> news:
thomask
parents: 111
diff changeset
2 // $Date$
a33ad7189d21 1) news:// -> news:
thomask
parents: 111
diff changeset
3 // $Author$
a33ad7189d21 1) news:// -> news:
thomask
parents: 111
diff changeset
4
111
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
5 // @author@ Daniel Horn <hellcatv@hotmail.com>
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
6 // @date@ 2004-04-30
140
a33ad7189d21 1) news:// -> news:
thomask
parents: 111
diff changeset
7 // @uri@ news:c6ullo$104s$1@digitaldaemon.com
1485
774e02c900da changed nntp: URLs to http: URLs
thomask
parents: 1383
diff changeset
8 // @uri@ http://www.digitalmars.com/pnews/read.php?server=news.digitalmars.com&group=digitalmars.D.bugs&artnum=48
111
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
9
338
1f6cf5ccfbc9 1) updated rules to dmd-0.119
thomask
parents: 140
diff changeset
10 // __DSTRESS_ELINE__ 51
1f6cf5ccfbc9 1) updated rules to dmd-0.119
thomask
parents: 140
diff changeset
11
111
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
12 module dstress.nocompile.bug_mtype_3154;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
13
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
14 struct vec(VALUE, int size){
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
15
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
16 enum {nvalues=1}
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
17
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
18 VALUE [size]f;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
19
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
20 VALUE* getAt(uint i) {
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
21 return i<size?&f[i]:&f[size-1];
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
22 }
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
23
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
24 VALUE opIndexAssign(uint i, VALUE v) {
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
25 return (*getAt(i))=v;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
26 }
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
27
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
28 VALUE opIndexAssign(uint i) {
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
29 return i<size?f[i]:f[size-1];
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
30 }
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
31
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
32 template T(zvec) {
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
33 zvec castTo() {
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
34 zvec ret;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
35 for (int i=max(ret.nvalues-1,size-1);i>=0;i--) {
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
36 ret[i]=this[i];
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
37 }
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
38 return ret;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
39 }
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
40 }
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
41 }
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
42
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
43 alias vec!(float,1) float1;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
44 alias vec!(float,4) float4;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
45
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
46 int main (char[][]args) {
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
47 float1 a;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
48 float4 b;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
49 b[0]=1,b[1]=2,b[2]=3,b[3]=4;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
50 a[1]=3;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
51 b=a.T(float4).castTo();// <-- taking out this line stops the error
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
52
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
53 return 0;
24da167d3f07 svn maintenance
thomask
parents: 85
diff changeset
54 }