#include <stdio.h>
#include <stdlib.h>
+#include "portable.h" /* execinfo when available */
#include "xbt/ex.h"
/* default __ex_ctx callback function */
}
/* default __ex_terminate callback function */
-void __xbt_ex_terminate_default(ex_t *e) {
-
- fprintf(stderr,
- "** SimGrid: UNCAUGHT EXCEPTION:\n"
- "** (%d/%d) %s\n"
- "** Thrown by %s%s%s at %s:%d:%s\n",
- e->category, e->value, e->msg,
- e->procname, (e->host?"@":""),(e->host?e->host:""),
- e->file,e->line,e->func);
- abort();
+void __xbt_ex_terminate_default(xbt_ex_t *e) {
+
+ fprintf(stderr,
+ "** SimGrid: UNCAUGHT EXCEPTION: category: %s; value: %d\n"
+ "** %s\n"
+ "** Thrown by %s%s%s at %s:%d:%s\n",
+ xbt_ex_catname(e->category), e->value, e->msg,
+ e->procname, (e->host?"@":""),(e->host?e->host:"localhost"),
+ e->file,e->line,e->func);
+
+#ifdef HAVE_EXECINFO_H
+ {
+ char **strings;
+ size_t i;
+
+ fprintf(stderr,"** Backtrace:\n");
+ strings = backtrace_symbols (e->bt, e->used);
+
+ for (i = 0; i < e->used; i++)
+ printf (" %s\n", strings[i]);
+
+ free (strings);
+ }
+#endif
+
+ abort();
}
/* the externally visible API */
ex_ctx_cb_t __xbt_ex_ctx = &__xbt_ex_ctx_default;
ex_term_cb_t __xbt_ex_terminate = &__xbt_ex_terminate_default;
+void xbt_ex_free(xbt_ex_t e) {
+ if (e.msg) free(e.msg);
+ free(e.procname);
+}
+
+/** \brief returns a short name for the given exception category */
+const char * xbt_ex_catname(xbt_errcat_t cat) {
+ switch (cat) {
+ case unknown_error: return "unknown_err";
+ case arg_error: return "invalid_arg";
+ case mismatch_error: return "mismatch";
+ case not_found_error: return "not found";
+ case system_error: return "system_err";
+ case network_error: return "network_err";
+ case timeout_error: return "timeout";
+ case thread_error: return "thread_err";
+ default: return "INVALID_ERR";
+ }
+}
+
+#ifndef HAVE_EXECINFO_H
+/* dummy implementation. We won't use the result, but ex.h needs it to be defined */
+int backtrace (void **__array, int __size) {
+ return 0;
+}
+
+#endif