http://d.puremagic.com/issues/show_bug.cgi?id=6203
Summary: [GSoC] RefCounted (and clear()) doesn't call
destructors of members of structs.
Product: D
Version: D1 & D2
Platform: Other
OS/Version: Windows
Status: NEW
Severity: normal
Priority: P2
Component: Phobos
AssignedTo: [email protected]
ReportedBy: [email protected]
--- Comment #0 from Cristi Cobzarenco <[email protected]> 2011-06-23
15:57:31 PDT ---
Code:
import std.typecons;
import std.stdio;
struct Enclosing {
Member m;
~this() { writeln("Enclosing.~this()"); }
}
struct Member {
~this() { writeln("Member.~this()"); }
}
alias RefCounted!Enclosing Test;
int main() {
Test a;
a.RefCounted.initialize();
return 0;
}
Outputs:
Enclosing.~this()
Member.~this()
Enclosing.~this()
The first two destructor calls are because of the call to initialize() which
replaces the internal copy. The third one is called when 'a' goes out of scope.
Unfortunately the destructor of 'a.m' is not called.
This seems to be because of clear():
Code:
int main() {
Enclosing a;
clear(a);
return 0;
}
Output:
Enclosing.~this()
Enclosing.~this()
Member.~this()
The last two calls are when 'a' goes out of scope. The first one is on clear(),
but as you can see it only calls the destructor of Enclosing.
This causes memory leaks in my project, but that's about it. So it's not a
blocker, but it's important for it to get fixed.
--
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
------- You are receiving this mail because: -------