diff options
author | Michal Cmarada <mcmarada@cisco.com> | 2019-05-16 11:12:49 +0200 |
---|---|---|
committer | Michal Cmarada <mcmarada@cisco.com> | 2019-05-16 09:23:21 +0000 |
commit | fae82a77fec1ab43b0714210dd97378fd3f7b235 (patch) | |
tree | 3d66ad5b0e0ed1395ce44a32b70df2d2f6e0987c /java | |
parent | e1c702fef2fa7c0e21b4c6d850048c898e4ccfc8 (diff) |
fix signature bug for enumsets
Change-Id: If28bb60eb58e1649c5bee0d707b95d5879e677b2
Signed-off-by: Michal Cmarada <mcmarada@cisco.com>
Diffstat (limited to 'java')
-rwxr-xr-x | java/jvpp/gen/jvppgen/jni_type_handlers_gen.py | 23 |
1 files changed, 19 insertions, 4 deletions
diff --git a/java/jvpp/gen/jvppgen/jni_type_handlers_gen.py b/java/jvpp/gen/jvppgen/jni_type_handlers_gen.py index 90fc101..5f5525c 100755 --- a/java/jvpp/gen/jvppgen/jni_type_handlers_gen.py +++ b/java/jvpp/gen/jvppgen/jni_type_handlers_gen.py @@ -140,8 +140,21 @@ static inline ${jni_type} _net_to_host_${c_name}(vl_api_${c_name}_t _net) }""") +type_to_signature_map = { + "jboolean" : "Z", + "jbyte" : "B", + "jchar" : "C", + "jshort" : "S", + "jint" : "I", + "jlong" : "J", + "jfloat" : "F", + "jdouble" : "D" +} + + def _generate_enumset(model, t, type_handlers): value_type = t.value.type + signature = type_to_signature_map[value_type.jni_type] type_handlers.append(_ENUMSET_NET_TO_HOST_TEMPLATE.substitute( c_name=t.name, json_filename=model.json_api_files, @@ -150,7 +163,8 @@ def _generate_enumset(model, t, type_handlers): jni_signature=value_type.jni_signature, jni_type=value_type.jni_type, jni_accessor=value_type.jni_accessor, - swap=_generate_scalar_host_to_net_swap(t.value) + swap=_generate_scalar_host_to_net_swap(t.value), + signature=signature )) type_handlers.append(_ENUMSET_HOST_TO_NET_TEMPLATE.substitute( @@ -159,7 +173,8 @@ def _generate_enumset(model, t, type_handlers): json_definition=t.doc, class_FQN=t.jni_name, jni_type=value_type.jni_type, - type_swap=_generate_scalar_net_to_host_swap(t.value) + type_swap=_generate_scalar_net_to_host_swap(t.value), + signature=signature )) @@ -172,7 +187,7 @@ $json_definition static inline void _host_to_net_${c_name}(JNIEnv * env, jobject _host, vl_api_${c_name}_t * _net) { jclass enumClass = (*env)->FindClass(env, "${class_FQN}"); - jmethodID getValueMethod = (*env)->GetMethodID(env, enumClass, "getOptionsValue", "()I"); + jmethodID getValueMethod = (*env)->GetMethodID(env, enumClass, "getOptionsValue", "()${signature}"); ${jni_type} value = (*env)->CallIntMethod(env, _host, getValueMethod); ${swap}; }""") @@ -186,7 +201,7 @@ $json_definition static inline jobject _net_to_host_${c_name}(JNIEnv * env, vl_api_${c_name}_t _net) { jclass enumClass = (*env)->FindClass(env, "${class_FQN}"); - jmethodID constructor = (*env)->GetMethodID(env, enumClass, "<init>", "(I)V"); + jmethodID constructor = (*env)->GetMethodID(env, enumClass, "<init>", "(${signature})V"); ${jni_type} value = (${jni_type}) $type_swap; return (*env)->NewObject(env, enumClass, constructor, value); }""") |