# HG changeset patch # User thomask # Date 1173371157 0 # Node ID 176afd3d6d8eb77b38f072af6c8547b79499eeba # Parent 409d6e0aa69ee151e092435d691b0c9f73c76301 [Issue 1025] mixin("scope(exit) call();"); is broken Tomas Lindquist Olsen 2007-03-05 http://d.puremagic.com/issues/show_bug.cgi?id=1025 diff -r 409d6e0aa69e -r 176afd3d6d8e reporter.txt --- a/reporter.txt Thu Mar 08 16:25:31 2007 +0000 +++ b/reporter.txt Thu Mar 08 16:25:57 2007 +0000 @@ -152,6 +152,7 @@ Tim Fang Tim Keating Tintor Marko +Tomas Lindquist Olsen Tomasz Stachowiak(aka Tom S / h3r3tic / heretic) Tyler Knott Tyro diff -r 409d6e0aa69e -r 176afd3d6d8e run/m/mixin_27_A.d --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/run/m/mixin_27_A.d Thu Mar 08 16:25:57 2007 +0000 @@ -0,0 +1,26 @@ +// $HeadURL$ +// $Date$ +// $Author$ + +// @author@ Tomas Lindquist Olsen +// @date@ 2007-03-05 +// @uri@ http://d.puremagic.com/issues/show_bug.cgi?id=1025 +// @desc@ [Issue 1025] mixin("scope(exit) call();"); is broken + +module dstress.run.m.mixin_27_A; + +int status; + +void test(){ + mixin("status += 1;"); + mixin("scope(exit) status *= 2;"); + mixin("status += 5;"); +} + +int main(){ + test(); + if(12 != status){ + assert(0); + } + return 0; +} diff -r 409d6e0aa69e -r 176afd3d6d8e run/m/mixin_27_B.d --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/run/m/mixin_27_B.d Thu Mar 08 16:25:57 2007 +0000 @@ -0,0 +1,26 @@ +// $HeadURL$ +// $Date$ +// $Author$ + +// @author@ Tomas Lindquist Olsen +// @date@ 2007-03-05 +// @uri@ http://d.puremagic.com/issues/show_bug.cgi?id=1025 +// @desc@ [Issue 1025] mixin("scope(exit) call();"); is broken + +module dstress.run.m.mixin_27_B; + +int status; + +void test(){ + mixin("status += 1;"); + mixin("scope(success) status *= 2;"); + mixin("status += 5;"); +} + +int main(){ + test(); + if(12 != status){ + assert(0); + } + return 0; +} diff -r 409d6e0aa69e -r 176afd3d6d8e run/m/mixin_27_C.d --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/run/m/mixin_27_C.d Thu Mar 08 16:25:57 2007 +0000 @@ -0,0 +1,26 @@ +// $HeadURL$ +// $Date$ +// $Author$ + +// @author@ Tomas Lindquist Olsen +// @date@ 2007-03-05 +// @uri@ http://d.puremagic.com/issues/show_bug.cgi?id=1025 +// @desc@ [Issue 1025] mixin("scope(exit) call();"); is broken + +module dstress.run.m.mixin_27_C; + +int status; + +void test(){ + mixin("status += 1;"); + mixin("scope(failure) status *= 2;"); + mixin("status += 5;"); +} + +int main(){ + test(); + if(6 != status){ + assert(0); + } + return 0; +} diff -r 409d6e0aa69e -r 176afd3d6d8e run/m/mixin_27_D.d --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/run/m/mixin_27_D.d Thu Mar 08 16:25:57 2007 +0000 @@ -0,0 +1,31 @@ +// $HeadURL$ +// $Date$ +// $Author$ + +// @author@ Tomas Lindquist Olsen +// @date@ 2007-03-05 +// @uri@ http://d.puremagic.com/issues/show_bug.cgi?id=1025 +// @desc@ [Issue 1025] mixin("scope(exit) call();"); is broken + +module dstress.run.m.mixin_27_D; + +int status; + +void test(){ + mixin("status += 1;"); + mixin("scope(failure) status *= 2;"); + throw new Exception("foo"); + mixin("status += 5;"); +} + +int main(){ + try{ + test(); + }catch{ + if(2 != status){ + assert(0); + } + return 0; + } + assert(0); +} diff -r 409d6e0aa69e -r 176afd3d6d8e run/m/mixin_27_E.d --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/run/m/mixin_27_E.d Thu Mar 08 16:25:57 2007 +0000 @@ -0,0 +1,31 @@ +// $HeadURL$ +// $Date$ +// $Author$ + +// @author@ Tomas Lindquist Olsen +// @date@ 2007-03-05 +// @uri@ http://d.puremagic.com/issues/show_bug.cgi?id=1025 +// @desc@ [Issue 1025] mixin("scope(exit) call();"); is broken + +module dstress.run.m.mixin_27_E; + +int status; + +void test(){ + mixin("status += 1;"); + mixin("scope(success) status *= 2;"); + throw new Exception("foo"); + mixin("status += 5;"); +} + +int main(){ + try{ + test(); + }catch{ + if(6 != status){ + assert(0); + } + return 0; + } + assert(0); +}