Backtrace();
Backtrace(const Backtrace& bt);
~Backtrace();
+ /** @brief Translate the backtrace in a human friendly form, unmangled with source code locations. */
+ std::string const resolve() const;
+ /** @brief Display the resolved backtrace on stderr */
+ void display() const;
};
-/* Translate the backtrace in an human friendly form
- *
- * Try resolve symbols and source code locations.
- */
-XBT_PUBLIC std::string resolve_backtrace(const Backtrace& bt);
}
}
-
-/** @brief Display a previously captured backtrace */
-XBT_PUBLIC void xbt_backtrace_display(const simgrid::xbt::Backtrace& bt);
-
#endif
XBT_LOG_NEW_DEFAULT_SUBCATEGORY(xbt_backtrace, xbt, "Backtrace");
-void xbt_backtrace_display(const simgrid::xbt::Backtrace& bt)
-{
- std::string backtrace = simgrid::xbt::resolve_backtrace(bt);
- if (backtrace.empty()) {
- fprintf(stderr, "(backtrace not set -- did you install Boost.Stacktrace?)\n");
- return;
- }
- fprintf(stderr, "Backtrace (displayed in actor %s):\n", SIMIX_process_self_get_name());
- std::fprintf(stderr, "%s\n", backtrace.c_str());
-}
-
/** @brief show the backtrace of the current point (lovely while debugging) */
void xbt_backtrace_display_current()
{
- simgrid::xbt::Backtrace bt = simgrid::xbt::Backtrace();
- xbt_backtrace_display(bt);
+ simgrid::xbt::Backtrace().display();
}
namespace simgrid {
delete impl_;
}
}
-} // namespace xbt
-} // namespace simgrid
-namespace simgrid {
-namespace xbt {
-
-std::string resolve_backtrace(const Backtrace& bt)
+std::string const Backtrace::resolve() const
{
std::string result("");
#if HAVE_BOOST_STACKTRACE
std::stringstream ss;
- ss << bt.impl_->st;
+ ss << impl_->st;
result.append(ss.str());
#endif
return result;
}
+void Backtrace::display() const
+{
+ std::string backtrace = resolve();
+ if (backtrace.empty()) {
+ fprintf(stderr, "(backtrace not set -- did you install Boost.Stacktrace?)\n");
+ return;
+ }
+ fprintf(stderr, "Backtrace (displayed in actor %s):\n", SIMIX_process_self_get_name());
+ std::fprintf(stderr, "%s\n", backtrace.c_str());
+}
+
} // namespace xbt
} // namespace simgrid
// Do we have a backtrace?
if (with_context != nullptr && not simgrid::config::get_value<bool>("exception/cutpath")) {
- auto backtrace = simgrid::xbt::resolve_backtrace(with_context->throw_point().backtrace_);
+ auto backtrace = with_context->resolve_backtrace();
XBT_LOG(prio, " -> %s", backtrace.c_str());
}
XBT_LOG(xbt_log_priority_critical, "Display of current backtrace disabled by --cfg=exception/cutpath.");
return;
}
- std::string res = resolve_backtrace(bt);
+ std::string res = bt.resolve();
XBT_LOG(xbt_log_priority_critical, "Current backtrace:");
XBT_LOG(xbt_log_priority_critical, " -> %s", res.c_str());
}