X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/5826c2dea3a9a0d929eed630fb0c84c41015bc3d..98926ddb21f3361caf5d8e3bb9d33c0d56fef7a2:/src/xbt/exception.cpp diff --git a/src/xbt/exception.cpp b/src/xbt/exception.cpp index ad829c2169..a1c6d0b52b 100644 --- a/src/xbt/exception.cpp +++ b/src/xbt/exception.cpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2005-2016. The SimGrid Team. +/* Copyright (c) 2005-2017. The SimGrid Team. * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it @@ -15,6 +15,8 @@ #include #include +#include +#include #include #include #include @@ -47,7 +49,7 @@ void logException( XBT_LOG(prio, "%s %s: %s", context, name.get(), exception.what()); // Do we have a backtrace? - if (with_context != nullptr) { + if (with_context != nullptr && not xbt_cfg_get_boolean("exception/cutpath")) { auto backtrace = simgrid::xbt::resolveBacktrace( with_context->backtrace().data(), with_context->backtrace().size()); for (std::string const& s : backtrace) @@ -76,6 +78,10 @@ void logException( static void showBacktrace(std::vector& bt) { + if (xbt_cfg_get_boolean("exception/cutpath")) { + XBT_LOG(xbt_log_priority_critical, "Display of current backtrace disabled by --cfg=exception/cutpath."); + return; + } std::vector res = resolveBacktrace(&bt[0], bt.size()); XBT_LOG(xbt_log_priority_critical, "Current backtrace:"); for (std::string const& s : res) @@ -90,7 +96,7 @@ static void handler() // an uncaught exception static std::atomic_flag lock = ATOMIC_FLAG_INIT; if (lock.test_and_set()) { - XBT_ERROR("Multiple uncaught exceptions"); + XBT_ERROR("Handling an exception raised an exception. Bailing out."); std::abort(); }