Improve debug output.
Should make it easier to determine the exact reason the debugger call is triggered.
This commit is contained in:
parent
eab9d5b444
commit
58a2847a12
@ -6,6 +6,10 @@
|
|||||||
|
|
||||||
#include <Referenceable.h>
|
#include <Referenceable.h>
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
#include <stdio.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <debugger.h>
|
#include <debugger.h>
|
||||||
|
|
||||||
//#define TRACE_REFERENCEABLE
|
//#define TRACE_REFERENCEABLE
|
||||||
@ -28,6 +32,7 @@ BReferenceable::~BReferenceable()
|
|||||||
{
|
{
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
bool enterDebugger = false;
|
bool enterDebugger = false;
|
||||||
|
char message[256];
|
||||||
if (fReferenceCount == 1) {
|
if (fReferenceCount == 1) {
|
||||||
// Simple heuristic to test if this object was allocated
|
// Simple heuristic to test if this object was allocated
|
||||||
// on the stack: check if this is within 1KB in either
|
// on the stack: check if this is within 1KB in either
|
||||||
@ -44,14 +49,21 @@ BReferenceable::~BReferenceable()
|
|||||||
status_t result = get_thread_info(find_thread(NULL), &info);
|
status_t result = get_thread_info(find_thread(NULL), &info);
|
||||||
if (result != B_OK || this < info.stack_base
|
if (result != B_OK || this < info.stack_base
|
||||||
|| this > info.stack_end) {
|
|| this > info.stack_end) {
|
||||||
|
snprintf(message, sizeof(message), "Deleted referenceable "
|
||||||
|
"object that's not on the stack (this: %p, stack_base: %p,"
|
||||||
|
" stack_end: %p)\n", this, info.stack_base,
|
||||||
|
info.stack_end);
|
||||||
enterDebugger = true;
|
enterDebugger = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (fReferenceCount != 0)
|
} else if (fReferenceCount != 0) {
|
||||||
|
snprintf(message, sizeof(message), "Deleted referenceable object with "
|
||||||
|
"non-zero reference count (%" B_PRId32 ")\n", fReferenceCount);
|
||||||
enterDebugger = true;
|
enterDebugger = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (enterDebugger)
|
if (enterDebugger)
|
||||||
debugger("Deleted referenceable object with non-zero ref count.");
|
debugger(message);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user