|
|
|
#ifndef _DEV_STACKTRACE_H
|
|
|
|
#define _DEV_STACKTRACE_H
|
|
|
|
|
|
|
|
|
|
|
|
namespace dev
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
class MapFile;
|
|
|
|
|
|
|
|
|
|
|
|
/** Stack tracing utility. */
|
|
|
|
class StackTrace
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Prints formatted call stack to the user buffer.
|
|
|
|
* Always terminates the user buffer with 0.
|
|
|
|
*
|
|
|
|
* @param map Array of pointers to map files.
|
|
|
|
* @param maps Number of map files.
|
|
|
|
* @param initLevel Number of functions to skip before starting the tracing.
|
|
|
|
* @param maxDepth Maximum number of levels in the stack trace.
|
|
|
|
* @param buffer [out] Output buffer for the formatted stack trace.
|
|
|
|
* @param bufferSize Size of the output buffer.
|
|
|
|
* @return Needed buffer size.
|
|
|
|
*/
|
|
|
|
static int printStackTrace( MapFile** map, int maps,
|
|
|
|
int initLevel, int maxDepth,
|
|
|
|
char* buffer, int bufferSize, unsigned long stackPtr = 0, unsigned long opPtr = 0 );
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // dev
|
|
|
|
|
|
|
|
|
|
|
|
#endif // _DEV_STACKTRACE_H
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2001 Jani Kajala
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, distribute and sell this
|
|
|
|
* software and its documentation for any purpose is hereby
|
|
|
|
* granted without fee, provided that the above copyright notice
|
|
|
|
* appear in all copies and that both that copyright notice and
|
|
|
|
* this permission notice appear in supporting documentation.
|
|
|
|
* Jani Kajala makes no representations about the suitability
|
|
|
|
* of this software for any purpose. It is provided "as is"
|
|
|
|
* without express or implied warranty.
|
|
|
|
*/
|