1 /* Copyright (c) 2005-2018. The SimGrid Team.All rights reserved. */
3 /* This program is free software; you can redistribute it and/or modify it
4 * under the terms of the license (GNU LGPL) which comes with this package. */
6 #ifndef SIMGRID_XBT_EXCEPTION_HPP
7 #define SIMGRID_XBT_EXCEPTION_HPP
10 #include <type_traits>
14 #include <xbt/backtrace.h>
15 #include <xbt/backtrace.hpp>
17 #include <xbt/misc.h> // xbt_procname
18 #include <xbt/virtu.h> // xbt_getpid
20 /** @addtogroup XBT_ex
21 * @brief Exceptions support
29 * This is used (among other things) in exceptions to store the associated
34 typedef std::vector<xbt_backtrace_location_t> Backtrace;
36 /** The location of where an exception has been throwed
38 * This is a tuple (__FILE__, __LINE__, __func__) and can be created with
39 * @ref XBT_THROW_POINT.
45 ThrowPoint() = default;
46 explicit ThrowPoint(const char* file, int line, const char* function) : file(file), line(line), function(function) {}
47 const char* file = nullptr;
49 const char* function = nullptr;
52 /** Create a ThrowPoint with (__FILE__, __LINE__, __func__) */
53 #define XBT_THROW_POINT ::simgrid::xbt::ThrowPoint(__FILE__, __LINE__, __func__)
55 /** A base class for exceptions with context
57 * This is a base class for exceptions which store additional contextual
58 * information: backtrace, throw point, simulated process name, PID, etc.
60 * You are not expected to inherit from it. Instead of you use should
61 * @ref XBT_THROW an exception which will throw a subclass of your original
62 * exception with those additional features.
64 * However, you can try `dynamic_cast` an exception to this type in order to
65 * get contextual information about the exception.
67 class XBT_PUBLIC WithContextException {
69 WithContextException() :
70 backtrace_(simgrid::xbt::backtrace()),
71 procname_(xbt_procname()),
74 explicit WithContextException(Backtrace bt) : backtrace_(std::move(bt)), procname_(xbt_procname()), pid_(xbt_getpid())
76 explicit WithContextException(ThrowPoint throwpoint, Backtrace bt)
77 : backtrace_(std::move(bt)), procname_(xbt_procname()), pid_(xbt_getpid()), throwpoint_(throwpoint)
79 virtual ~WithContextException();
80 Backtrace const& backtrace() const
84 int pid() const { return pid_; }
85 std::string const& process_name() const { return procname_; }
86 ThrowPoint& throw_point() { return throwpoint_; }
89 XBT_ATTRIB_DEPRECATED_v323("Please use WithContextException::process_name()") std::string const& processName() const
91 return process_name();
93 XBT_ATTRIB_DEPRECATED_v323("Please use WithContextException::throw_point()") ThrowPoint& throwPoint()
100 std::string procname_; /**< Name of the process who thrown this */
101 int pid_; /**< PID of the process who thrown this */
102 ThrowPoint throwpoint_;