X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/1555ef43eee251e5892a2f7fd49bc96e99d68fef..3297da9f47ce18371941b2b48a2f4018b4793ced:/include/xbt/ex.h diff --git a/include/xbt/ex.h b/include/xbt/ex.h index 8fbd00d8ae..ed4056626b 100644 --- a/include/xbt/ex.h +++ b/include/xbt/ex.h @@ -1,80 +1,33 @@ -/* Copyright (c) 2005-2015. The SimGrid Team. - * All rights reserved. */ - -/* Copyright (c) 2002-2004 Ralf S. Engelschall */ -/* Copyright (c) 2002-2004 The OSSP Project */ -/* Copyright (c) 2002-2004 Cable & Wireless */ -/* All rights reserved. */ - -/* This code is inspirated from the OSSP version (as retrieved back in 2004)*/ -/* It was heavily modified to fit the SimGrid framework. */ - -/* The OSSP version has the following copyright notice: -** OSSP ex - Exception Handling -** Copyright (c) 2002-2004 Ralf S. Engelschall -** Copyright (c) 2002-2004 The OSSP Project -** Copyright (c) 2002-2004 Cable & Wireless -** -** This file is part of OSSP ex, an exception handling library -** which can be found at http://www.ossp.org/pkg/lib/ex/. -** -** Permission to use, copy, modify, and distribute this software for -** any purpose with or without fee is hereby granted, provided that -** the above copyright notice and this permission notice appear in all -** copies. -** -** THIS SOFTWARE IS PROVIDED `AS IS'' AND ANY EXPRESSED OR IMPLIED -** WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF -** MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -** IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR -** CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF -** USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND -** ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, -** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT -** OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF -** SUCH DAMAGE. - */ +/* Copyright (c) 2005-2018. The SimGrid Team. All rights reserved. */ -/* The extensions made for the SimGrid project can either be distributed */ -/* under the same license, or under the LGPL v2.1 */ +/* This program is free software; you can redistribute it and/or modify it + * under the terms of the license (GNU LGPL) which comes with this package. */ -#ifndef __XBT_EX_H__ -#define __XBT_EX_H__ +#ifndef XBT_EX_H +#define XBT_EX_H #include -#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 */ +#include +#include +#include +#include + +/** @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 */ @@ -94,31 +47,48 @@ typedef enum { SG_BEGIN_DECL() -XBT_PUBLIC(const char *) xbt_ex_catname(xbt_errcat_t cat); +/** 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__) -#define THROW_IMPOSSIBLE \ - THROWF(unknown_error, 0, "The Impossible Did Happen (yet again)") -#define THROW_UNIMPLEMENTED \ - THROWF(unknown_error, 0, "Function %s unimplemented",__func__) -#define THROW_DEADCODE \ - THROWF(unknown_error, 0, "Function %s was supposed to be DEADCODE, but it's not",__func__) +XBT_ATTRIB_NORETURN void xbt_throw_impossible(const char* file, int line, const char* func); +/** Throw an exception because something impossible happened + * @ingroup XBT_ex_c + */ +#define THROW_IMPOSSIBLE xbt_throw_impossible(__FILE__, __LINE__, __func__) +/** Throw an exception because something unimplemented stuff has been attempted + * @ingroup XBT_ex_c + */ +XBT_ATTRIB_NORETURN void xbt_throw_unimplemented(const char* file, int line, const char* func); +#define THROW_UNIMPLEMENTED xbt_throw_unimplemented(__FILE__, __LINE__, __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 */ -XBT_PUBLIC(void) xbt_ex_display(xbt_ex_t * e); +/** Display an exception */ +XBT_PUBLIC void xbt_ex_display(xbt_ex_t* e); SG_END_DECL()