X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/1037987174e34ec2ea483da79d651c7e2e16e83e..7e71d73eb6728d8d498d010976f038789049c131:/src/java/jxbt_utilities.h diff --git a/src/java/jxbt_utilities.h b/src/java/jxbt_utilities.h index 570645bab1..4d6dd0395b 100644 --- a/src/java/jxbt_utilities.h +++ b/src/java/jxbt_utilities.h @@ -14,66 +14,81 @@ #define JXBT_UTILITY_H #include -#include "jxbt_utilities.h" /* *********** */ /* JNI GETTERS */ /* *********** */ /* Search a class and throw an exception if not found */ -jclass jxbt_get_class(JNIEnv* env, const char*name); +jclass jxbt_get_class(JNIEnv * env, const char *name); /* Search a method in a class and throw an exception if not found (it's ok to to pass a NULL class: it's a noop) */ -jmethodID jxbt_get_jmethod(JNIEnv* env, jclass class, - const char *name,const char *signature); - +jmethodID jxbt_get_jmethod(JNIEnv * env, jclass class, + const char *name, const char *signature); + /* Like the jxbt_get_class() but get a static method */ -jmethodID jxbt_get_static_jmethod(JNIEnv* env, jclass cls, - const char *name,const char *signature); +jmethodID jxbt_get_static_jmethod(JNIEnv * env, jclass cls, + const char *name, const char *signature); /* Search a field in a class and throw an exception if not found (it's ok to to pass a NULL class: it's a noop) */ -jfieldID jxbt_get_jfield(JNIEnv* env, jclass class, - const char *name, const char *signature); +jfieldID jxbt_get_jfield(JNIEnv * env, jclass class, + const char *name, const char *signature); /* Search a method in a class and throw an exception if not found (it's ok to to pass a NULL class: it's a noop) */ -jmethodID jxbt_get_smethod(JNIEnv* env, const char *classname, - const char *name,const char *signature); +jmethodID jxbt_get_smethod(JNIEnv * env, const char *classname, + const char *name, const char *signature); /* Like the jxbt_get_smethod() but get a static method */ -jmethodID jxbt_get_static_smethod(JNIEnv* env, const char *classname, - const char *name,const char *signature); +jmethodID jxbt_get_static_smethod(JNIEnv * env, const char *classname, + const char *name, const char *signature); /* Search a field in a class and throw an exception if not found (it's ok to to pass a NULL class: it's a noop) */ -jfieldID jxbt_get_sfield(JNIEnv* env, const char *classname, - const char *name, const char *signature); +jfieldID jxbt_get_sfield(JNIEnv * env, const char *classname, + const char *name, const char *signature); /* ***************** */ /* EXCEPTION RAISING */ /* ***************** */ +#define jxbt_check_res(fun, res, allowed_exceptions, detail) do {\ + if (res != MSG_OK && res | allowed_exceptions) { \ + xbt_die(bprintf("%s failed with error code %d, which is not an allowed exception. Please fix me.",fun,res)); \ + } else if (res == MSG_HOST_FAILURE) { \ + jxbt_throw_host_failure(env, detail); \ + } else if (res == MSG_TRANSFER_FAILURE) { \ + jxbt_throw_transfer_failure(env,detail); \ + } else if (res == MSG_TIMEOUT_FAILURE) { \ + jxbt_throw_time_out_failure(env,detail); \ + } } while (0) /** Thrown on internal error of this layer, or on problem with JNI */ -void jxbt_throw_jni(JNIEnv* env, const char* msg); +void jxbt_throw_jni(JNIEnv * env, const char *msg); /** Thrown when using an object not bound to a native one where it should, or reverse (kinda JNI issue) */ -void jxbt_throw_notbound(JNIEnv* env,const char* kind,void *pointer); +void jxbt_throw_notbound(JNIEnv * env, const char *kind, void *pointer); /** Thrown on error in native MSG code */ -void jxbt_throw_native(JNIEnv* env, char *msg); +void jxbt_throw_native(JNIEnv * env, char *msg); /** Thrown if NULL gets used */ -void jxbt_throw_null(JNIEnv* env,char *msg); +void jxbt_throw_null(JNIEnv * env, char *msg); /** Thrown on illegal arguments */ -void jxbt_throw_illegal(JNIEnv* env,char *msg); +void jxbt_throw_illegal(JNIEnv * env, char *msg); /** Thrown when looking for an host from name does not lead to anything */ -void jxbt_throw_host_not_found(JNIEnv* env, const char *invalid_name); +void jxbt_throw_host_not_found(JNIEnv * env, const char *invalid_name); /** Thrown when looking for an host from name does not lead to anything */ -void jxbt_throw_process_not_found(JNIEnv* env, const char *invalid_name); +void jxbt_throw_process_not_found(JNIEnv * env, const char *invalid_name); +/** Thrown when a transfer failure accure while Sending task */ +void jxbt_throw_transfer_failure(JNIEnv * env,char *detail); +/** Thrown when a host failure accures while Sending task*/ +void jxbt_throw_host_failure(JNIEnv *env,char *details); +/** Thrown when a time out accures While Sending task */ +void jxbt_throw_time_out_failure(JNIEnv *env,char *details); #endif /* ! JXBT_UTILITY_H */