Bug 892 – Another bug in the new GC - pointers in mixins
Status
RESOLVED
Resolution
FIXED
Severity
normal
Priority
P2
Component
dmd
Product
D
Version
D1 (retired)
Platform
x86
OS
Windows
Creation time
2007-01-26T14:20:00Z
Last change time
2014-02-16T15:26:12Z
Assigned to
bugzilla
Creator
wbaxter
Comments
Comment #0 by wbaxter — 2007-01-26T14:20:33Z
This is actually with DMD version 1.003 (and I suspect 1.001, and 1.002).
This program destroys the object from the mixin even though it is still very much referenced by live objects in the program.
------
import std.stdio;
static import std.gc;
class SomeObject
{
this() { writefln("SomeObject created"); }
~this() { writefln("SomeObject destroyed"); }
}
template Mix()
{
void init() {
ptr = new SomeObject;
}
SomeObject ptr;
}
class Container
{
this() { init(); }
mixin Mix;
}
void main()
{
auto x = new Container;
writefln("---Pre collect");
std.gc.fullCollect();
writefln("---Post collect");
}
Comment #1 by wbaxter — 2007-01-26T15:33:11Z
OK, the compiler was being a bit too smart apparently, realizing that x would no longer be used. That makes the test appear to fail all the way back to DMD 0.176. So I should have put writeflns in at the end to make sure the data had a reason to stick around.
Upon doing that, the example works in DMD 1.0 and fails in 1.001--1.003 (I went ahead and tried them all).
Here's the modified test:
-----------------
import std.stdio;
static import std.gc;
class SomeObject
{
this() { writefln("SomeObject created"); }
~this() { writefln("SomeObject destroyed"); }
}
template Mix()
{
void init() {
ptr = new SomeObject;
}
SomeObject ptr;
}
class Container
{
this() { init(); }
mixin Mix;
int v = 10;
}
void main()
{
auto x = new Container;
writefln("---Pre collect");
std.gc.fullCollect();
writefln("---Post collect");
writefln(x.v);
writefln(x.ptr);
}