annotate run/align_08.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 ec5e144583ea
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
363
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
1 // $HeadURL$
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
2 // $Date$
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
3 // $Author$
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
4
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
5 // @author@ Ben Hinkle <bhinkle@mathworks.com>
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
6 // @date@ 2005-03-23
1489
b8c0195059d9 changed nntp: URLs to http: URLs
thomask
parents: 363
diff changeset
7 // @uri@ http://www.digitalmars.com/pnews/read.php?server=news.digitalmars.com&group=digitalmars.D.bugs&artnum=3313
363
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
8
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
9
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
10 module dstress.run.align_08;
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
11
1559
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
12 version(Tango){
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
13 static assert(0, "DSTRESS{XFAIL}: Tango doesn't provide access to fullCollect");
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
14 }else{
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
15 // @WARNING@ imports Phobos' gc
363
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
16
1559
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
17 import std.gc;
363
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
18
1559
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
19 struct S{
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
20 char[] font_face;
363
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
21 }
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
22
1559
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
23 int main(){
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
24 S[] x;
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
25
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
26 for (int i=0;i<3;i++) {
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
27 S s;
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
28 s.font_face="font face".dup;
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
29 x ~= s;
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
30 }
363
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
31
1559
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
32 fullCollect();
363
56eae111e8ef struct alignment / gc
thomask
parents:
diff changeset
33
1559
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
34 assert(x[0].font_face=="font face");
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
35 assert(x[1].font_face=="font face");
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
36
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
37 return 0;
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
38 }
ec5e144583ea D1 -> D2 : 1/N
thomask
parents: 1489
diff changeset
39 }