scope and raising from constructor
Denis Koroskin
2korden at gmail.com
Tue Oct 14 02:04:18 PDT 2008
On Tue, 14 Oct 2008 11:51:27 +0400, Paolo Invernizzi
<arathorn at fastwebnet.it> wrote:
> Hi all,
> I've posted this on D learn, just to know: is it a bug? If yes, I'll
> post a ticket...
> If not, I don't understand the difference behaviour...
> Thanks, Paolo
>
> module tests.d.scopes.t02.test;
>
> class Resource {
> static int allocated = 0;
> this( bool mustThrow = false ){
> allocated ++;
> if( mustThrow ) throw new Exception("bang");
> }
> ~this(){
> allocated --;
> }
> }
> class Factory {
> Resource resource(bool b=false){
> return new Resource(b);
> }
> }
>
> import std.gc, std.stdio;
> void main(){
> // In this case everything it's ok
> {
> try {
> scope r1 = new Resource(true);
> assert( false );
> }
> catch(Exception e){}
> assert( Resource.allocated == 1);
> std.gc.fullCollect();
> assert( Resource.allocated == 1 );
> }
> Resource.allocated = 0;
> // In this case the destructor IS called, only on collect...
> {
> auto f = new Factory();
> try {
> scope r1 = f.resource(true);
> assert( false );
> }
> catch(Exception e){}
> assert( Resource.allocated == 1);
> std.gc.fullCollect();
> assert( Resource.allocated == 0 ); // Dho! Destructor called!
> }
> }
I think there is no need to post it twice across different newsgroups,
most of the people monitor all or none of them.
More information about the Digitalmars-d
mailing list