X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/931c72e9293d64a1797a6187dd0e744408c23d59..f70b81e98894e971dbac565d8e496dc99e3fa30a:/include/xbt/ex.h?ds=sidebyside diff --git a/include/xbt/ex.h b/include/xbt/ex.h index d1e3fdf0f6..78ade076cc 100644 --- a/include/xbt/ex.h +++ b/include/xbt/ex.h @@ -1,4 +1,4 @@ -/* Copyright (c) 2005-2015. The SimGrid Team. +/* Copyright (c) 2005-2017. The SimGrid Team. * All rights reserved. */ /* Copyright (c) 2002-2004 Ralf S. Engelschall */ @@ -40,48 +40,31 @@ /* The extensions made for the SimGrid project can either be distributed */ /* under the same license, or under the LGPL v2.1 */ -#ifndef __XBT_EX_H__ -#define __XBT_EX_H__ +#ifndef XBT_EX_H +#define XBT_EX_H #include -#ifdef __cplusplus -#include -#include -#include -#include -#endif - #include "xbt/base.h" #include "xbt/sysdep.h" #include "xbt/misc.h" #include "xbt/virtu.h" -/*-*-* Emergency debuging: define this when the exceptions get crazy *-*-*/ -#undef __EX_MAYDAY -#ifdef __EX_MAYDAY -# include -#include -# define MAYDAY_SAVE(m) printf("%d %s:%d save %p\n", \ - xbt_getpid(), __FILE__, __LINE__, \ - (m)->jb \ - ), -# define MAYDAY_RESTORE(m) printf("%d %s:%d restore %p\n", \ - xbt_getpid(), __FILE__, __LINE__, \ - (m)->jb \ - ), -# define MAYDAY_CATCH(e) printf("%d %s:%d Catched '%s'\n", \ - xbt_getpid(), __FILE__, __LINE__, \ - (e).msg \ - ), -#else -# define MAYDAY_SAVE(m) -# define MAYDAY_RESTORE(m) -# define MAYDAY_CATCH(e) -#endif -/*-*-* end of debugging stuff *-*-*/ - -/** @brief different kind of errors */ +/** @addtogroup XBT_ex_c + * @brief Exceptions support (C) + * + * Those fonctions are used to throw C++ exceptions from C code. This feature + * should probably be removed in the future because C and exception do not + * exactly play nicely together. + */ + +/** Categories of errors + * + * This very similar to std::error_catgory and should probably be replaced + * by this in the future. + * + * @ingroup XBT_ex_c + */ typedef enum { unknown_error = 0, /**< unknown error */ arg_error, /**< Invalid argument */ @@ -99,49 +82,55 @@ typedef enum { vm_error /**< vm error */ } xbt_errcat_t; -#ifdef __cplusplus -XBT_PUBLIC_CLASS xbt_ex : - public std::runtime_error, - public simgrid::xbt::WithContextException { -public: - xbt_ex() : std::runtime_error("") {} - xbt_ex(const char* message) : std::runtime_error(message) {} - ~xbt_ex() override; - - xbt_errcat_t category; /**< category like HTTP (what went wrong) */ - int value; /**< like errno (why did it went wrong) */ - const char *file; /**< Thrown point */ - int line; /**< Thrown point */ - const char *func; /**< Thrown point */ -}; -#endif - SG_BEGIN_DECL() +/** Get the name of a category + * @ingroup XBT_ex_c + */ XBT_PUBLIC(const char *) xbt_ex_catname(xbt_errcat_t cat); typedef struct xbt_ex xbt_ex_t; -XBT_PUBLIC(void) xbt_throw(char* message, xbt_errcat_t errcat, int value, const char* file, int line, const char* func) XBT_ATTRIB_NORETURN; +/** Helper function used to throw exceptions in C */ +XBT_ATTRIB_NORETURN XBT_PUBLIC(void) + _xbt_throw(char* message, xbt_errcat_t errcat, int value, const char* file, int line, const char* func); -/** @brief Builds and throws an exception - @hideinitializer */ -#define THROW(c, v) { xbt_throw(NULL, (xbt_errcat_t) c, v, __FILE__, __LINE__, __func__); } +/** Builds and throws an exception + * @ingroup XBT_ex_c + * @hideinitializer + */ +#define THROW(c, v) { _xbt_throw(NULL, (xbt_errcat_t) c, v, __FILE__, __LINE__, __func__); } -/** @brief Builds and throws an exception with a printf-like formatted message - @hideinitializer */ -#define THROWF(c, v, ...) xbt_throw(bprintf(__VA_ARGS__), (xbt_errcat_t) c, v, __FILE__, __LINE__, __func__) +/** Builds and throws an exception with a printf-like formatted message + * @ingroup XBT_ex_c + * @hideinitializer + */ +#define THROWF(c, v, ...) _xbt_throw(bprintf(__VA_ARGS__), (xbt_errcat_t) c, v, __FILE__, __LINE__, __func__) +/** Throw an exception because someting impossible happened + * @ingroup XBT_ex_c + */ #define THROW_IMPOSSIBLE \ THROWF(unknown_error, 0, "The Impossible Did Happen (yet again)") + +/** Throw an exception because someting unimplemented stuff has been attempted + * @ingroup XBT_ex_c + */ #define THROW_UNIMPLEMENTED \ THROWF(unknown_error, 0, "Function %s unimplemented",__func__) + +/** Throw an exception because some dead code was reached + * @ingroup XBT_ex_c + */ #define THROW_DEADCODE \ THROWF(unknown_error, 0, "Function %s was supposed to be DEADCODE, but it's not",__func__) +/** Die because something impossible happened + * @ingroup XBT_ex_c + */ #define DIE_IMPOSSIBLE xbt_die("The Impossible Did Happen (yet again)") -/** @brief The display made by an exception that is not catched */ +/** Display an exception */ XBT_PUBLIC(void) xbt_ex_display(xbt_ex_t * e); SG_END_DECL()