diff options
author | Stephan Bergmann <sbergman@redhat.com> | 2015-06-15 16:58:21 +0200 |
---|---|---|
committer | Stephan Bergmann <sbergman@redhat.com> | 2015-06-15 16:58:21 +0200 |
commit | dfba745437324b8e1a352ab5280c665c543fc37f (patch) | |
tree | 5aa5b269de9ad68fd60bf7a4311e7fd0fe934494 /bridges/source/jni_uno | |
parent | 814867c75cd175594b8e60125f248ecbb6647644 (diff) |
Work around change in JNI func sigs between Java 6 and 7
Change-Id: I8f6a988ef8bd3642fe6997170dfb50935e6bf3b6
Diffstat (limited to 'bridges/source/jni_uno')
-rw-r--r-- | bridges/source/jni_uno/jni_data.cxx | 57 |
1 files changed, 32 insertions, 25 deletions
diff --git a/bridges/source/jni_uno/jni_data.cxx b/bridges/source/jni_uno/jni_data.cxx index d1f36eda2b42..3e3ed84b3aa4 100644 --- a/bridges/source/jni_uno/jni_data.cxx +++ b/bridges/source/jni_uno/jni_data.cxx @@ -1160,6 +1160,13 @@ void Bridge::map_to_java( bool in_param, bool out_param, bool special_wrapped_integral_types ) const { + // 4th param of Set*ArrayRegion changed from pointer to non-const to pointer + // to const between <http://docs.oracle.com/javase/6/docs/technotes/guides/ + // jni/spec/functions.html#wp22933> and <http://docs.oracle.com/javase/7/ + // docs/technotes/guides/jni/spec/functions.html#wp22933>; work around that + // difference in a way that doesn't trigger loplugin:redundantcast: + void * data = const_cast<void *>(uno_data); + switch (type->eTypeClass) { case typelib_TypeClass_CHAR: @@ -1172,7 +1179,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetCharArrayRegion( - static_cast<jcharArray>(jo_ar.get()), 0, 1, static_cast<jchar const *>(uno_data) ); + static_cast<jcharArray>(jo_ar.get()), 0, 1, static_cast<jchar *>(data) ); jni.ensure_no_exception(); } java_data->l = jo_ar.release(); @@ -1182,7 +1189,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetCharArrayRegion( - static_cast<jcharArray>(java_data->l), 0, 1, static_cast<jchar const *>(uno_data) ); + static_cast<jcharArray>(java_data->l), 0, 1, static_cast<jchar *>(data) ); jni.ensure_no_exception(); } } @@ -1212,7 +1219,7 @@ void Bridge::map_to_java( { jni->SetBooleanArrayRegion( static_cast<jbooleanArray>(jo_ar.get()), - 0, 1, static_cast<jboolean const *>(uno_data) ); + 0, 1, static_cast<jboolean *>(data) ); jni.ensure_no_exception(); } java_data->l = jo_ar.release(); @@ -1223,7 +1230,7 @@ void Bridge::map_to_java( { jni->SetBooleanArrayRegion( static_cast<jbooleanArray>(java_data->l), - 0, 1, static_cast<jboolean const *>(uno_data) ); + 0, 1, static_cast<jboolean *>(data) ); jni.ensure_no_exception(); } } @@ -1252,7 +1259,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetByteArrayRegion( - static_cast<jbyteArray>(jo_ar.get()), 0, 1, static_cast<jbyte const *>(uno_data) ); + static_cast<jbyteArray>(jo_ar.get()), 0, 1, static_cast<jbyte *>(data) ); jni.ensure_no_exception(); } java_data->l = jo_ar.release(); @@ -1262,7 +1269,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetByteArrayRegion( - static_cast<jbyteArray>(java_data->l), 0, 1, static_cast<jbyte const *>(uno_data) ); + static_cast<jbyteArray>(java_data->l), 0, 1, static_cast<jbyte *>(data) ); jni.ensure_no_exception(); } } @@ -1292,7 +1299,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetShortArrayRegion( - static_cast<jshortArray>(jo_ar.get()), 0, 1, static_cast<jshort const *>(uno_data) ); + static_cast<jshortArray>(jo_ar.get()), 0, 1, static_cast<jshort *>(data) ); jni.ensure_no_exception(); } java_data->l = jo_ar.release(); @@ -1302,7 +1309,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetShortArrayRegion( - static_cast<jshortArray>(java_data->l), 0, 1, static_cast<jshort const *>(uno_data) ); + static_cast<jshortArray>(java_data->l), 0, 1, static_cast<jshort *>(data) ); jni.ensure_no_exception(); } } @@ -1332,7 +1339,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetIntArrayRegion( - static_cast<jintArray>(jo_ar.get()), 0, 1, static_cast<jint const *>(uno_data) ); + static_cast<jintArray>(jo_ar.get()), 0, 1, static_cast<jint *>(data) ); jni.ensure_no_exception(); } java_data->l = jo_ar.release(); @@ -1342,7 +1349,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetIntArrayRegion( - static_cast<jintArray>(java_data->l), 0, 1, static_cast<jint const *>(uno_data) ); + static_cast<jintArray>(java_data->l), 0, 1, static_cast<jint *>(data) ); jni.ensure_no_exception(); } } @@ -1372,7 +1379,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetLongArrayRegion( - static_cast<jlongArray>(jo_ar.get()), 0, 1, static_cast<jlong const *>(uno_data) ); + static_cast<jlongArray>(jo_ar.get()), 0, 1, static_cast<jlong *>(data) ); jni.ensure_no_exception(); } java_data->l = jo_ar.release(); @@ -1382,7 +1389,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetLongArrayRegion( - static_cast<jlongArray>(java_data->l), 0, 1, static_cast<jlong const *>(uno_data) ); + static_cast<jlongArray>(java_data->l), 0, 1, static_cast<jlong *>(data) ); jni.ensure_no_exception(); } } @@ -1411,7 +1418,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetFloatArrayRegion( - static_cast<jfloatArray>(jo_ar.get()), 0, 1, static_cast<jfloat const *>(uno_data) ); + static_cast<jfloatArray>(jo_ar.get()), 0, 1, static_cast<jfloat *>(data) ); jni.ensure_no_exception(); } java_data->l = jo_ar.release(); @@ -1421,7 +1428,7 @@ void Bridge::map_to_java( if (in_param) { jni->SetFloatArrayRegion( - static_cast<jfloatArray>(java_data->l), 0, 1, static_cast<jfloat const *>(uno_data) ); + static_cast<jfloatArray>(java_data->l), 0, 1, static_cast<jfloat *>(data) ); jni.ensure_no_exception(); } } @@ -1451,7 +1458,7 @@ void Bridge::map_to_java( { jni->SetDoubleArrayRegion( static_cast<jdoubleArray>(jo_ar.get()), - 0, 1, static_cast<jdouble const *>(uno_data) ); + 0, 1, static_cast<jdouble *>(data) ); jni.ensure_no_exception(); } java_data->l = jo_ar.release(); @@ -1462,7 +1469,7 @@ void Bridge::map_to_java( { jni->SetDoubleArrayRegion( static_cast<jdoubleArray>(java_data->l), - 0, 1, static_cast<jdouble const *>(uno_data) ); + 0, 1, static_cast<jdouble *>(data) ); jni.ensure_no_exception(); } } @@ -2081,7 +2088,7 @@ void Bridge::map_to_java( JLocalAutoRef jo_ar( jni ); sal_Int32 nElements; - uno_Sequence const * seq = 0; + uno_Sequence * seq = 0; if (in_param) { seq = *static_cast<uno_Sequence * const *>(uno_data); @@ -2105,7 +2112,7 @@ void Bridge::map_to_java( { jni->SetCharArrayRegion( static_cast<jcharArray>(jo_ar.get()), - 0, nElements, reinterpret_cast<jchar const *>(seq->elements) ); + 0, nElements, reinterpret_cast<jchar *>(seq->elements) ); jni.ensure_no_exception(); } break; @@ -2116,7 +2123,7 @@ void Bridge::map_to_java( { jni->SetBooleanArrayRegion( static_cast<jbooleanArray>(jo_ar.get()), - 0, nElements, reinterpret_cast<jboolean const *>(seq->elements) ); + 0, nElements, reinterpret_cast<jboolean *>(seq->elements) ); jni.ensure_no_exception(); } break; @@ -2127,7 +2134,7 @@ void Bridge::map_to_java( { jni->SetByteArrayRegion( static_cast<jbyteArray>(jo_ar.get()), - 0, nElements, reinterpret_cast<jbyte const *>(seq->elements) ); + 0, nElements, reinterpret_cast<jbyte *>(seq->elements) ); jni.ensure_no_exception(); } break; @@ -2139,7 +2146,7 @@ void Bridge::map_to_java( { jni->SetShortArrayRegion( static_cast<jshortArray>(jo_ar.get()), - 0, nElements, reinterpret_cast<jshort const *>(seq->elements) ); + 0, nElements, reinterpret_cast<jshort *>(seq->elements) ); jni.ensure_no_exception(); } break; @@ -2151,7 +2158,7 @@ void Bridge::map_to_java( { jni->SetIntArrayRegion( static_cast<jintArray>(jo_ar.get()), - 0, nElements, reinterpret_cast<jint const *>(seq->elements) ); + 0, nElements, reinterpret_cast<jint *>(seq->elements) ); jni.ensure_no_exception(); } break; @@ -2163,7 +2170,7 @@ void Bridge::map_to_java( { jni->SetLongArrayRegion( static_cast<jlongArray>(jo_ar.get()), - 0, nElements, reinterpret_cast<jlong const *>(seq->elements) ); + 0, nElements, reinterpret_cast<jlong *>(seq->elements) ); jni.ensure_no_exception(); } break; @@ -2174,7 +2181,7 @@ void Bridge::map_to_java( { jni->SetFloatArrayRegion( static_cast<jfloatArray>(jo_ar.get()), - 0, nElements, reinterpret_cast<jfloat const *>(seq->elements) ); + 0, nElements, reinterpret_cast<jfloat *>(seq->elements) ); jni.ensure_no_exception(); } break; @@ -2185,7 +2192,7 @@ void Bridge::map_to_java( { jni->SetDoubleArrayRegion( static_cast<jdoubleArray>(jo_ar.get()), - 0, nElements, reinterpret_cast<jdouble const *>(seq->elements) ); + 0, nElements, reinterpret_cast<jdouble *>(seq->elements) ); jni.ensure_no_exception(); } break; |