On Thursday, 4 June 2015 at 23:59:11 UTC, Vladimir Panteleev
wrote:
On Thursday, 4 June 2015 at 23:56:28 UTC, Etienne wrote:
Since the application will probably have to stop, might as
well use the GC:
in GC:
if (gcx.running) {
gcx.running = false;
onInvalidMemoryOperationError();
}
in core.exception:
throw new InvalidMemoryOperationError();
And there you go, a beautiful stack trace. I now have a
pinpoint of the error within 100k++ LOC. Thank you.
Why D? Why fail with a one line message and no debug tools?
Why??
I don't understand what you're grieving about, but:
1. We can't show a stack trace in an
InvalidMemoryOperationError situation because we need to
allocate memory for the stack trace, which we can't do in an
InvalidMemoryOperationError situation.
2. Hope this helps:
http://wiki.dlang.org/InvalidMemoryOperationError
Apparently GDB couldn't stack trace the error with symbols, was
limited to 2 frames without symbols:
http://forum.dlang.org/thread/[email protected]#post-rpnmeklflyzodhfehari:40forum.dlang.org
http://forum.dlang.org/thread/[email protected]?page=2#post-pjntbqmxjbyxiwevdlra:40forum.dlang.org
The error also didn't occur in Windows so I couldn't use that.
I think you're mixing up the "invalid state" and "unusable". The
GC is fully usable for the purpose of throwing, because I got a
35 frame stack trace from it.