#include <inttypes.h>
// library header file's path
-#include "orte.h"
+#include "orte_all.h"
// pregenerated header
#include "jorte/org_ocera_orte_Subscription.h"
// enable TEST_STAGE run level
jclass cls_msg = 0;
jobject rinfo = 0;
jobject obj_msg;
+ jobject obj_bo = 0;
+ jfieldID fid = 0;
jmethodID mid = 0;
jmethodID mid_callback = 0;
//
- JORTECallbackContext_t *callback_cont = (JORTECallbackContext_t*)recvCallBackParam;
+ // if the subscriber has been destroyed, return
+ if((*(JORTECallbackContext_t**)recvCallBackParam) == 0)
+ return;
+
+ JORTECallbackContext_t *callback_cont = *((JORTECallbackContext_t**)recvCallBackParam);
#ifdef TEST_STAGE
printf("\n\n:c: --------------- recvCallBack called.. --------------- \n");
}
jvm = callback_cont->jvm;
// get env
- (*jvm)->AttachCurrentThread(jvm, (void **)&env, NULL);
+ (*jvm)->AttachCurrentThread(jvm,
+ #ifdef __ANDROID__
+ &env,
+ #else
+ (void **)&env,
+ #endif
+ NULL);
if(env == 0)
{
#ifdef TEST_STAGE
break;
}
//
+ // set byte order only if it differs from that currently set
+ if(info->data_endian != callback_cont->cur_endian) {
+ //prepare ByteOrder
+ cls = (*env)->FindClass(env, "java/nio/ByteOrder");
+ if (cls == 0) {
+ #ifdef TEST_STAGE
+ printf(":!c: cls = NULL \n");
+ #endif
+ }
+ if(info->data_endian == BigEndian) {
+ fid = (*env)->GetStaticFieldID(env,
+ cls,
+ "BIG_ENDIAN",
+ "Ljava/nio/ByteOrder;");
+ callback_cont->cur_endian = BigEndian;
+ }
+ else {
+ fid = (*env)->GetStaticFieldID(env,
+ cls,
+ "LITTLE_ENDIAN",
+ "Ljava/nio/ByteOrder;");
+ callback_cont->cur_endian = LittleEndian;
+ }
+ if(fid == 0) {
+ #ifdef TEST_STAGE
+ printf(":!c: fid = NULL \n");
+ #endif
+ }
+ obj_bo = (*env)->GetStaticObjectField(env, cls, fid);
+ if(obj_bo == 0) {
+ #ifdef TEST_STAGE
+ printf(":!c: cls = NULL \n");
+ #endif
+ }
+
+ // set byte order to ByteBuffer
+ // get BB class
+ cls = (*env)->GetObjectClass(env, callback_cont->obj_buf);
+ if(cls == 0)
+ {
+ #ifdef TEST_STAGE
+ printf(":!c: cls = NULL \n");
+ #endif
+ }
+ // get methodID - order(ByteOrder)
+ mid = (*env)->GetMethodID(env,
+ cls,
+ "order",
+ "(Ljava/nio/ByteOrder;)Ljava/nio/ByteBuffer;");
+ if(mid == 0)
+ {
+ #ifdef TEST_STAGE
+ printf(":!c: mid = NULL \n");
+ #endif
+ }
+
+ // set ByteOrder
+ if((*env)->CallObjectMethod(env,callback_cont->obj_buf,mid,obj_bo) == 0)
+ {
+ #ifdef TEST_STAGE
+ printf(":!c: set byte order failed.. \n");
+ #endif
+ }
+ }
+ //
if(callback_cont->obj == 0)
{
#ifdef TEST_STAGE
jstring jtopic, // subs topic
jstring jtname, // subs typeName
jobject jinstance, // direct ByteBuffer
+ jint jbyteOrder,// byte order of ByteBuffer
jobject obj_msg, // messageData instance
jobject jdeadline,
jobject jminSeparation,
SubscriptionType stype;
NtpTime deadline;
NtpTime minSeparation;
- // jorte varialbe
+ // jorte variable
JORTECallbackContext_t *callback_cont;
+ JORTECallbackContext_t **callback_cont_ptr;
+
// standart variables
const char *topic = 0;
const char *typename = 0;
// memory alocation
// don't forget use free() funct.!!
callback_cont = (JORTECallbackContext_t*)malloc(sizeof(JORTECallbackContext_t));
+ callback_cont_ptr = (JORTECallbackContext_t**)malloc(sizeof(JORTECallbackContext_t*));
+ *callback_cont_ptr = callback_cont;
do
{
#endif
}
callback_cont->jvm = jvm;
+ callback_cont->cur_endian = (CDR_Endianness) jbyteOrder;
// create global references
callback_cont->obj = (*env)->NewGlobalRef(env, obj_callback);
//
break;
}
// create global references
+ callback_cont->obj_buf = (*env)->NewGlobalRef(env, jinstance);
+ //
+ if (callback_cont->obj_buf == 0)
+ {
+ #ifdef TEST_STAGE
+ printf(":c: global reference not created! \n");
+ #endif
+ break;
+ }
+ // create global references
callback_cont->msg = (*env)->NewGlobalRef(env, obj_msg);
//
if (callback_cont->msg == 0)
(*env)->SetLongField(env,
obj,
fid,
- (jlong) callback_cont);
+ (jlong) callback_cont_ptr);
#ifdef TEST_STAGE
printf(":c: ORTESubscriptionCreate() calling..\n");
#endif
&deadline,
&minSeparation,
recvCallBack,
- (void*)callback_cont,
+ (void*)callback_cont_ptr,
(uint32_t) j_multicastIP);
if (s == 0)
{