annotate run/try_04.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 f87ba6507260
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
374
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
1 // $HeadURL$
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
2 // $Date$
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
3 // $Author$
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
4
f87ba6507260 added missing meta-data
thomask
parents: 1
diff changeset
5 module dstress.run.try_04;
0
3269e4627918 init dstress
svnowner
parents:
diff changeset
6
3269e4627918 init dstress
svnowner
parents:
diff changeset
7 class MyException : Exception{
3269e4627918 init dstress
svnowner
parents:
diff changeset
8 this(char[] msg){
3269e4627918 init dstress
svnowner
parents:
diff changeset
9 super(msg);
3269e4627918 init dstress
svnowner
parents:
diff changeset
10 }
3269e4627918 init dstress
svnowner
parents:
diff changeset
11 int x;
3269e4627918 init dstress
svnowner
parents:
diff changeset
12 }
3269e4627918 init dstress
svnowner
parents:
diff changeset
13 int main(){
3269e4627918 init dstress
svnowner
parents:
diff changeset
14 int check=0;
3269e4627918 init dstress
svnowner
parents:
diff changeset
15 assert(check==0);
3269e4627918 init dstress
svnowner
parents:
diff changeset
16 try{
3269e4627918 init dstress
svnowner
parents:
diff changeset
17 MyException e=new MyException("");
3269e4627918 init dstress
svnowner
parents:
diff changeset
18 e.x=2;
3269e4627918 init dstress
svnowner
parents:
diff changeset
19 throw e;
3269e4627918 init dstress
svnowner
parents:
diff changeset
20 }catch(MyException me){
3269e4627918 init dstress
svnowner
parents:
diff changeset
21 assert(me.x==2);
3269e4627918 init dstress
svnowner
parents:
diff changeset
22 check+=5;
3269e4627918 init dstress
svnowner
parents:
diff changeset
23 }catch(Exception){
3269e4627918 init dstress
svnowner
parents:
diff changeset
24 check+=3;
3269e4627918 init dstress
svnowner
parents:
diff changeset
25 }finally{
3269e4627918 init dstress
svnowner
parents:
diff changeset
26 check++;
3269e4627918 init dstress
svnowner
parents:
diff changeset
27 }
3269e4627918 init dstress
svnowner
parents:
diff changeset
28 assert(check==6);
3269e4627918 init dstress
svnowner
parents:
diff changeset
29 return 0;
3269e4627918 init dstress
svnowner
parents:
diff changeset
30 }