digitalmars.D.bugs - [Issue 6167] New: RefCounted and lazy/delegate
- d-bugmail puremagic.com (54/54) Jun 16 2011 http://d.puremagic.com/issues/show_bug.cgi?id=6167
- d-bugmail puremagic.com (24/24) Jun 16 2011 http://d.puremagic.com/issues/show_bug.cgi?id=6167
- d-bugmail puremagic.com (49/49) Oct 26 2012 http://d.puremagic.com/issues/show_bug.cgi?id=6167
http://d.puremagic.com/issues/show_bug.cgi?id=6167
Summary: RefCounted and lazy/delegate
Product: D
Version: D2
Platform: Other
OS/Version: Windows
Status: NEW
Severity: normal
Priority: P2
Component: DMD
AssignedTo: nobody puremagic.com
ReportedBy: jsancio gmail.com
I am not sure what is going but this maybe a dmd bug so filing here. The
following program:
import std.typecons;
import std.exception;
struct Struct
{
this(int dummy) { refCount = RefCounted!Impl(Impl(dummy)); }
~this() {}
RefCounted!Impl refCount;
struct Impl { int dummy; }
Struct fun(bool now)
{
if(now) throw new Exception("");
return Struct(1);
}
}
void lazyFun(lazy Struct exp)
{
try { exp(); } catch(Exception e) {}
}
void delegateFun(Struct delegate() exp)
{
try { exp(); } catch(Exception e) {}
}
void main()
{
auto var = Struct(1);
try { auto result = var.fun(true); } catch(Exception e) {}
delegateFun({ return var.fun(true); }); // segfaults
lazyFun(var.fun(true)); // segfaults
assertThrown(var.fun(true)); // segfaults
}
Produces the following nonsensical output:
_RefCounted 95F9410: initialized with (Impl _param_0)
RefCounted!(Impl) B74B8E40: decrement refcount to 157258767
RefCounted!(Impl) B74B8E40: decrement refcount to 157258766
RefCounted!(Impl) 95F940E: decrement refcount to 65535
Notice the value of the refcount!
--
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
Jun 16 2011
http://d.puremagic.com/issues/show_bug.cgi?id=6167
Also, note that if change fun to not be a member function you get the
following:
struct Struct
{
this(int dummy) { refCount = RefCounted!Impl(Impl(dummy)); }
~this() {}
RefCounted!Impl refCount;
struct Impl { int dummy; }
}
Struct fun()
{
throw new Exception("");
}
//...
$ ../dmd/dmd/src/dmd -debug=RefCounted -w -gc ref_test.d
../dmd/phobos/std/typecons.d && ./ref_test
_RefCounted 89A8410: initialized with (Impl _param_0)
RefCounted!(Impl) 89A8410: freeing... done!
Which is the expected result.
--
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
Jun 16 2011
http://d.puremagic.com/issues/show_bug.cgi?id=6167
Denis Shelomovskij <verylonglogin.reg gmail.com> changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|NEW |RESOLVED
CC| |verylonglogin.reg gmail.com
Resolution| |DUPLICATE
15:45:47 MSD ---
Reduced testcase:
---
import std.stdio;
struct Struct
{
int dummy, count = 0;
this(int dummy)
{ writefln(" this(dummy = %s): count: %s", this.dummy = dummy, ++count); }
~this()
{ writefln("~this(dummy = %s): count: %s", dummy, --count); }
static Struct getWithDummy2()
{
return Struct(2);
}
}
static Struct neverCalled()
{
assert(0);
}
void lazyFun(lazy Struct exp)
{ }
void main()
{
Struct var = Struct(1);
(){ return var.getWithDummy2(); }();
lazyFun(neverCalled());
}
---
Output:
---
this(dummy = 1): count: 1
this(dummy = 2): count: 1
~this(dummy = 2): count: 0
~this(dummy = 10366848): count: 4203019
~this(dummy = 1): count: 0
---
So this is a duplicate of Issue 8182 which is fixed in dmd 2.060.
*** This issue has been marked as a duplicate of issue 8182 ***
--
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
Oct 26 2012









d-bugmail puremagic.com 