X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FBacktrace.cc;h=411a33c4366c8328d19f97ef30a5ebfd050cdb56;hb=19ff129ad7beefdf7e79e8ea9da7fb18e8a06aff;hp=039cffceab73d560e1126c238d7cf761610203bd;hpb=7db21ff4de83edddec7084c5f121a10321b5a42f;p=senf.git diff --git a/senf/Utils/Backtrace.cc b/senf/Utils/Backtrace.cc index 039cffc..411a33c 100644 --- a/senf/Utils/Backtrace.cc +++ b/senf/Utils/Backtrace.cc @@ -30,6 +30,7 @@ #include #ifdef SENF_BACKTRACE #include + #include #endif #include #include @@ -39,10 +40,14 @@ #define prefix_ //-///////////////////////////////////////////////////////////////////////////////////////////////// -prefix_ void senf::formatBacktrace(std::ostream & os, void ** backtrace, unsigned numEntries) +prefix_ void senf::formatBacktrace(std::ostream & os, void ** backtrace, int numEntries) { #ifdef SENF_BACKTRACE char ** symbols (::backtrace_symbols(backtrace, numEntries)); + if (symbols == NULL) { + os << "error on translating backtrace addresses with ::backtrace_symbols: " << std::strerror(errno); + return; + } static boost::regex const backtraceRx ("(.*)\\((.*)\\+(0x[0-9a-f]+)\\) \\[(0x[0-9a-f]+)\\]"); @@ -51,7 +56,7 @@ prefix_ void senf::formatBacktrace(std::ostream & os, void ** backtrace, unsigne Offset = 3, Address = 4 }; - for (unsigned i=0; i