X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fpbd%2Fstacktrace.cc;h=c74dd946f78d7896246d4dfe36f19df64440bc32;hb=d75b27f6dc3a5878672cd40b26a368eeee21356c;hp=4fafb6120c48a65959805c122451165354034f1c;hpb=69a8fc43e2552d9d3c72f9117131ca6b9392093b;p=ardour.git diff --git a/libs/pbd/stacktrace.cc b/libs/pbd/stacktrace.cc index 4fafb6120c..c74dd946f7 100644 --- a/libs/pbd/stacktrace.cc +++ b/libs/pbd/stacktrace.cc @@ -22,6 +22,7 @@ #include "pbd/stacktrace.h" #include #include +#include void PBD::trace_twb () @@ -35,37 +36,45 @@ PBD::trace_twb () #include #include -std::string demangle (std::string const & l) +static std::string +symbol_demangle (const std::string& l) +{ + int status; + + try { + + char* realname = abi::__cxa_demangle (l.c_str(), 0, 0, &status); + std::string d (realname); + free (realname); + return d; + } catch (std::exception) { + + } + + return l; +} + +std::string +PBD::demangle (std::string const & l) { std::string::size_type const b = l.find_first_of ("("); + if (b == std::string::npos) { - return l; + return symbol_demangle (l); } std::string::size_type const p = l.find_last_of ("+"); if (p == std::string::npos) { - return l; + return symbol_demangle (l); } if ((p - b) <= 1) { - return l; + return symbol_demangle (l); } std::string const fn = l.substr (b + 1, p - b - 1); - int status; - try { - - char* realname = abi::__cxa_demangle (fn.c_str(), 0, 0, &status); - std::string d (realname); - free (realname); - return d; - - } catch (std::exception) { - - } - - return l; + return symbol_demangle (fn); } void @@ -97,7 +106,7 @@ PBD::stacktrace (std::ostream& out, int levels) #else std::string -demangle (std::string const & l) +PBD::demangle (std::string const & l) /* JE - !!!! 'PBD' namespace might possibly get removed (except it's still used in 'libs/canvas/item.cc') */ { return std::string(); }