2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: stackwalk.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxStackWalker
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxStackWalker
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxStackWalker allows an application to enumerate, or walk, the stack frames
|
|
|
|
(the function callstack).
|
|
|
|
It is mostly useful in only two situations:
|
|
|
|
inside wxApp::OnFatalException function to
|
|
|
|
programmatically get the location of the crash and, in debug builds, in
|
|
|
|
wxApp::OnAssertFailure to report the caller of the failed
|
|
|
|
assert.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxStackWalker works by repeatedly calling
|
|
|
|
the wxStackWalker::OnStackFrame method for each frame in the
|
|
|
|
stack, so to use it you must derive your own class from it and override this
|
|
|
|
method.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This class will not return anything except raw stack frame addresses if the
|
|
|
|
debug information is not available. Under Win32 this means that the PDB file
|
|
|
|
matching the program being executed should be present. Note that if you use
|
|
|
|
Microsoft Visual C++ compiler, you can create PDB files even for the programs
|
|
|
|
built in release mode and it doesn't affect the program size (at least if you
|
|
|
|
don't forget to add @c /opt:ref option which is suppressed by using
|
|
|
|
@c /debug linker option by default but should be always enabled for
|
|
|
|
release builds). Under Unix, you need to compile your program with debugging
|
|
|
|
information (usually using @c -g compiler and linker options) to get the
|
|
|
|
file and line numbers information, however function names should be available
|
|
|
|
even without it. Of course, all this is only @true if you build using a recent
|
|
|
|
enough version of GNU libc which provides the @c backtrace() function
|
|
|
|
needed to walk the stack.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@ref overview_debuggingoverview "debugging overview" for how to make it
|
|
|
|
available.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{FIXME}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxStackFrame
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
class wxStackWalker
|
2008-03-08 13:52:38 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Constructor does nothing, use Walk() to walk the
|
|
|
|
stack.
|
|
|
|
*/
|
|
|
|
wxStackWalker();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor does nothing neither but should be virtual as this class is used as
|
|
|
|
a base one.
|
|
|
|
*/
|
|
|
|
~wxStackWalker();
|
|
|
|
|
|
|
|
/**
|
|
|
|
This function must be overrided to process the given frame.
|
|
|
|
*/
|
|
|
|
void OnStackFrame(const wxStackFrame& frame);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Enumerate stack frames from the current location, skipping the initial
|
|
|
|
number of them (this can be useful when Walk() is called from some known
|
|
|
|
location and you don't want to see the first few frames anyhow; also
|
|
|
|
notice that Walk() frame itself is not included if skip = 1).
|
2008-03-09 12:33:59 +00:00
|
|
|
Up to @a maxDepth frames are walked from the innermost to the outermost one.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void Walk(size_t skip = 1, size_t maxDepth = 200);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Enumerate stack frames from the location of uncaught exception.
|
|
|
|
This method can only be called from
|
|
|
|
wxApp::OnFatalException.
|
2008-03-09 12:33:59 +00:00
|
|
|
Up to @a maxDepth frames are walked from the innermost to the outermost one.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void WalkFromException(size_t maxDepth = 200);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxStackFrame
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxStackFrame represents a single stack frame, or a single function in the call
|
2008-03-08 14:43:31 +00:00
|
|
|
stack, and is used exclusively together with
|
2008-03-08 13:52:38 +00:00
|
|
|
wxStackWalker, see there for a more detailed
|
|
|
|
discussion.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{FIXME}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxStackWalker
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
class wxStackFrame
|
2008-03-08 13:52:38 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Return the address of this frame.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
void* GetAddress() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Return the name of the file containing this frame, empty if
|
|
|
|
unavailable (typically because debug info is missing).
|
|
|
|
Use HasSourceLocation() to check whether
|
|
|
|
the file name is available.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxString GetFileName() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Get the level of this frame (deepest/innermost one is 0).
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
size_t GetLevel() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Return the line number of this frame, 0 if unavailable.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see GetFileName()
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
size_t GetLine() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Get the module this function belongs to (empty if not available).
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxString GetModule() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Return the unmangled (if possible) name of the function containing this
|
|
|
|
frame.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxString GetName() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Return the return address of this frame.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
size_t GetOffset() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Get the name, type and value (in text form) of the given parameter.
|
|
|
|
Any pointer may be @NULL if you're not interested in the corresponding
|
|
|
|
value.
|
|
|
|
Return @true if at least some values could be retrieved.
|
|
|
|
This function currently is only implemented under Win32 and requires a PDB
|
|
|
|
file.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
bool GetParam(size_t n, wxString* type, wxString* name,
|
2008-03-09 16:24:26 +00:00
|
|
|
wxString* value) const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Return the number of parameters of this function (may return 0 if we
|
|
|
|
can't retrieve the parameters info even although the function does have
|
|
|
|
parameters).
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
size_t GetParamCount() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Return @true if we have the file name and line number for this frame.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool HasSourceLocation() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|