X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/0ca1291c2f63ca6235f4b4885c48413a900aade4..25702930c148d7d6b9dfd08cbc12f2068d5cf4b2:/include/xbt/ex.h diff --git a/include/xbt/ex.h b/include/xbt/ex.h index ae391fa41b..50ef63e9fe 100644 --- a/include/xbt/ex.h +++ b/include/xbt/ex.h @@ -64,7 +64,7 @@ SG_BEGIN_DECL() ), # define MAYDAY_CATCH(e) printf("%d %s:%d Catched '%s'\n", \ (*xbt_getpid)(),__FILE__,__LINE__, \ - e.msg \ + (e).msg \ ), #else # define MAYDAY_SAVE(m) @@ -385,6 +385,17 @@ extern void __xbt_ex_terminate_default(xbt_ex_t * e); * @hideinitializer */ #define CATCH(e) \ + DO_CATCH((e) = XBT_EX_T_CPLUSPLUSCAST __xbt_running_ctx_fetch()->exception) + +/** @brief like CATCH(e) but without argument + * @hideinitializer + * + * Useful if you only want to rethrow the exception caught, and do not want to + * bother with an unused variable. + */ +#define CATCH_ANONYMOUS DO_CATCH(0) + +#define DO_CATCH(_xbt_do_catch_set_e) \ else { \ } \ if (!(__ex_cleanup)) \ @@ -398,7 +409,8 @@ extern void __xbt_ex_terminate_default(xbt_ex_t * e); __xbt_ex_ctx_ptr->ctx_mctx = __ex_mctx_en; \ } \ if ( !(__xbt_running_ctx_fetch()->ctx_caught) \ - || ((e) = XBT_EX_T_CPLUSPLUSCAST __xbt_running_ctx_fetch()->exception, MAYDAY_CATCH(e) 0)) { \ + || ((void)(_xbt_do_catch_set_e), \ + MAYDAY_CATCH(__xbt_running_ctx_fetch()->exception) 0)) { \ } \ else