* under the terms of the license (GNU LGPL) which comes with this package. */
#include "jmsg_file.h"
#include "jxbt_utilities.h"
+
void jfile_bind(JNIEnv *env, jobject jfile, msg_file_t stream) {
- (*env)->SetLongField(env, jfile, jfile_field_bind, (jlong) (long) (stream));
+ (*env)->SetLongField(env, jfile, jfile_field_bind, (intptr_t)stream);
}
msg_file_t jfile_get_native(JNIEnv *env, jobject jfile) {
- msg_file_t file = (msg_file_t)(*env)->GetLongField(env, jfile, jfile_field_bind);
+ msg_file_t file =
+ (msg_file_t)(intptr_t)(*env)->GetLongField(env, jfile, jfile_field_bind);
return file;
}
const char *path = (*env)->GetStringUTFChars(env, jpath, 0);
const char *mode = (*env)->GetStringUTFChars(env, jmode, 0);
msg_file_t file;
- xbt_ex_t e;
- TRY {
- file = MSG_file_open(storage, path, mode);
- }
- CATCH(e) {
- xbt_ex_free(e);
- }
+
+ file = MSG_file_open(storage, path, mode);
jfile_bind(env, jfile, file);
(*env)->ReleaseStringUTFChars(env, jstorage, storage);
Java_org_simgrid_msg_File_read(JNIEnv *env, jobject jfile, jlong jsize, jlong jnmemb) {
msg_file_t file = jfile_get_native(env, jfile);
size_t n;
- xbt_ex_t e;
- TRY {
- n = MSG_file_read(NULL,(size_t)jsize, (size_t)jnmemb, file);
- }
- CATCH (e) {
- xbt_ex_free(e);
- }
+ n = MSG_file_read(NULL,(size_t)jsize, (size_t)jnmemb, file);
return (jlong)n;
}
JNIEXPORT jlong JNICALL
Java_org_simgrid_msg_File_write(JNIEnv *env, jobject jfile, jlong jsize, jlong jnmemb) {
msg_file_t file = jfile_get_native(env, jfile);
- xbt_ex_t e;
size_t n;
- TRY {
- n = MSG_file_write(NULL, (size_t)jsize, (size_t)jnmemb, file);
- }
- CATCH(e) {
- xbt_ex_free(e);
- }
+ n = MSG_file_write(NULL, (size_t)jsize, (size_t)jnmemb, file);
return (jlong)n;
}
JNIEXPORT void JNICALL