backtrace: remove dependency on addr2line
This wasn't functioning in any case so we may as well get rid of it.
This commit is contained in:
parent
2ad86d28a5
commit
9ca093d982
@ -54,15 +54,6 @@ else ()
|
||||
endif ()
|
||||
|
||||
|
||||
##-----------------------------------------------------------------------------
|
||||
if (NOT WIN32)
|
||||
find_program(ADDR2LINE NAMES addr2line)
|
||||
if (ADDR2LINE)
|
||||
add_definitions(-DADDR2LINE="${ADDR2LINE}")
|
||||
endif()
|
||||
endif ()
|
||||
|
||||
|
||||
###############################################################################
|
||||
# Platform wrappers
|
||||
if (LINUX)
|
||||
|
@ -36,42 +36,23 @@ debug::backtrace::backtrace (void):
|
||||
}
|
||||
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
static std::string
|
||||
addr2line (const void *addr)
|
||||
{
|
||||
#if defined(ADDR2LINE)
|
||||
using pstream_t = std::unique_ptr<FILE,decltype(&::pclose)>;
|
||||
|
||||
std::ostringstream cmd;
|
||||
cmd << ADDR2LINE << " -e " << cruft::image_path () << ' ' << std::hex << addr;
|
||||
|
||||
pstream_t stream (
|
||||
::popen (cmd.str ().c_str (), "r"),
|
||||
::pclose
|
||||
);
|
||||
|
||||
// inefficient to copy from vector to string, but it's not a high priority path
|
||||
auto data = cruft::slurp<char> (stream.get ());
|
||||
return std::string (data.cbegin (), data.cend ());
|
||||
|
||||
#else
|
||||
return "";
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
std::ostream&
|
||||
debug::operator <<(std::ostream &os, const debug::backtrace &rhs) {
|
||||
auto const &frames = rhs.frames ();
|
||||
|
||||
// We don't use the array form of unique_ptr as clang fails on ambigious constructors
|
||||
typedef std::unique_ptr<char *, decltype(&std::free)> str_t;
|
||||
str_t names (backtrace_symbols (frames.data (), cruft::cast::lossless <int> (frames.size ())), ::free);
|
||||
using str_t = std::unique_ptr<char *, decltype(&std::free)>;
|
||||
str_t names (
|
||||
backtrace_symbols (
|
||||
frames.data (),
|
||||
cruft::cast::lossless <int> (frames.size ())
|
||||
),
|
||||
::free
|
||||
);
|
||||
|
||||
for (unsigned int i = 0; i < frames.size (); ++i)
|
||||
os << frames[i] << '\t' << names.get()[i] << '\t' << addr2line (frames[i]);
|
||||
os << frames[i] << '\t' << names.get()[i] << '\n';
|
||||
|
||||
return os;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user