How to debug FinalizeError?

unDEFER undefer at gmail.com
Thu Nov 29 07:07:45 UTC 2018


No I'm not preallocating any exceptions. It was idea, but I 
removed all calls which can make throw.
I'm using very old dmd 2.074.1, so as I have patched it for my 
text editor with IDE functions. I had a year break in 
development, so now I need to rewrite all my patches.
But exactly the output of my program looks like this:

core.exception.FinalizeError at src/rt/lifetime.d(1407): 
Finalization error
----------------
=== Bypassed ===

|||||||||||| BerkeleyDB exceptions mixed with output of 
destructors ||||||||||||||||||

core.exception.InvalidMemoryOperationError at src/core/exception.d(696): Invalid memory operation
----------------

It means that "Invalid memory operation" occurred earlier than 
"Finalization error"?
The line on which shows the pointer src/rt/lifetime.d(1407) is 
exactly:
         onFinalizeError(*pc, e);
Why gdb doesn't see this function?

My program (the text editor) had run test all night under gdb 
with break on InvalidMemoryOperationError and didn't fall. So it 
is very-very-very hard to reproduce.
And I haven't ideas where maybe this throw. At least I don't see 
any throw in explicit form.


More information about the Digitalmars-d-learn mailing list