2006-07-05 15:47:25 -04:00
|
|
|
#include <pbd/stacktrace.h>
|
|
|
|
#include <iostream>
|
|
|
|
|
|
|
|
/* Obtain a backtrace and print it to stdout. */
|
|
|
|
|
|
|
|
#ifdef HAVE_EXECINFO
|
|
|
|
|
|
|
|
#include <execinfo.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
void
|
2006-10-21 15:01:50 -04:00
|
|
|
PBD::stacktrace (std::ostream& out, int levels)
|
2006-07-05 15:47:25 -04:00
|
|
|
{
|
|
|
|
void *array[200];
|
|
|
|
size_t size;
|
|
|
|
char **strings;
|
|
|
|
size_t i;
|
|
|
|
|
|
|
|
size = backtrace (array, 200);
|
|
|
|
strings = backtrace_symbols (array, size);
|
|
|
|
|
|
|
|
if (strings) {
|
|
|
|
|
|
|
|
printf ("Obtained %zd stack frames.\n", size);
|
|
|
|
|
2006-10-21 15:01:50 -04:00
|
|
|
for (i = 0; i < size && (levels == 0 || i < levels); i++) {
|
2006-07-05 15:47:25 -04:00
|
|
|
out << strings[i] << std::endl;
|
|
|
|
}
|
|
|
|
|
|
|
|
free (strings);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
void
|
2006-10-21 15:01:50 -04:00
|
|
|
PBD::stacktrace (std::ostream& out, int levels)
|
2006-07-05 15:47:25 -04:00
|
|
|
{
|
|
|
|
out << "stack tracing is not enabled on this platform" << std::endl;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* HAVE_EXECINFO */
|