|
@@ -34,13 +34,14 @@
|
|
|
|
|
|
bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method, const Variant **p_args, int p_argcount, Variant::CallError &r_error, Variant &ret) {
|
|
bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method, const Variant **p_args, int p_argcount, Variant::CallError &r_error, Variant &ret) {
|
|
Map<StringName, List<MethodInfo>>::Element *M = methods.find(p_method);
|
|
Map<StringName, List<MethodInfo>>::Element *M = methods.find(p_method);
|
|
- if (!M)
|
|
|
|
|
|
+ if (!M) {
|
|
return false;
|
|
return false;
|
|
|
|
+ }
|
|
|
|
|
|
JNIEnv *env = get_jni_env();
|
|
JNIEnv *env = get_jni_env();
|
|
- ERR_FAIL_COND_V(env == nullptr, false);
|
|
|
|
|
|
+ ERR_FAIL_NULL_V(env, false);
|
|
|
|
|
|
- MethodInfo *method = NULL;
|
|
|
|
|
|
+ MethodInfo *method = nullptr;
|
|
for (List<MethodInfo>::Element *E = M->get().front(); E; E = E->next()) {
|
|
for (List<MethodInfo>::Element *E = M->get().front(); E; E = E->next()) {
|
|
if (!p_instance && !E->get()._static) {
|
|
if (!p_instance && !E->get()._static) {
|
|
r_error.error = Variant::CallError::CALL_ERROR_INSTANCE_IS_NULL;
|
|
r_error.error = Variant::CallError::CALL_ERROR_INSTANCE_IS_NULL;
|
|
@@ -68,8 +69,9 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|
//bug?
|
|
//bug?
|
|
} break;
|
|
} break;
|
|
case ARG_TYPE_BOOLEAN: {
|
|
case ARG_TYPE_BOOLEAN: {
|
|
- if (p_args[i]->get_type() != Variant::BOOL)
|
|
|
|
|
|
+ if (p_args[i]->get_type() != Variant::BOOL) {
|
|
arg_expected = Variant::BOOL;
|
|
arg_expected = Variant::BOOL;
|
|
|
|
+ }
|
|
} break;
|
|
} break;
|
|
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_BYTE:
|
|
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_BYTE:
|
|
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_CHAR:
|
|
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_CHAR:
|
|
@@ -81,27 +83,27 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|
case ARG_TYPE_SHORT:
|
|
case ARG_TYPE_SHORT:
|
|
case ARG_TYPE_INT:
|
|
case ARG_TYPE_INT:
|
|
case ARG_TYPE_LONG: {
|
|
case ARG_TYPE_LONG: {
|
|
- if (!p_args[i]->is_num())
|
|
|
|
|
|
+ if (!p_args[i]->is_num()) {
|
|
arg_expected = Variant::INT;
|
|
arg_expected = Variant::INT;
|
|
-
|
|
|
|
|
|
+ }
|
|
} break;
|
|
} break;
|
|
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_FLOAT:
|
|
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_FLOAT:
|
|
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_DOUBLE:
|
|
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_DOUBLE:
|
|
case ARG_TYPE_FLOAT:
|
|
case ARG_TYPE_FLOAT:
|
|
case ARG_TYPE_DOUBLE: {
|
|
case ARG_TYPE_DOUBLE: {
|
|
- if (!p_args[i]->is_num())
|
|
|
|
|
|
+ if (!p_args[i]->is_num()) {
|
|
arg_expected = Variant::REAL;
|
|
arg_expected = Variant::REAL;
|
|
-
|
|
|
|
|
|
+ }
|
|
} break;
|
|
} break;
|
|
case ARG_TYPE_STRING: {
|
|
case ARG_TYPE_STRING: {
|
|
- if (p_args[i]->get_type() != Variant::STRING)
|
|
|
|
|
|
+ if (p_args[i]->get_type() != Variant::STRING) {
|
|
arg_expected = Variant::STRING;
|
|
arg_expected = Variant::STRING;
|
|
-
|
|
|
|
|
|
+ }
|
|
} break;
|
|
} break;
|
|
case ARG_TYPE_CLASS: {
|
|
case ARG_TYPE_CLASS: {
|
|
- if (p_args[i]->get_type() != Variant::OBJECT)
|
|
|
|
|
|
+ if (p_args[i]->get_type() != Variant::OBJECT) {
|
|
arg_expected = Variant::OBJECT;
|
|
arg_expected = Variant::OBJECT;
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
Ref<Reference> ref = *p_args[i];
|
|
Ref<Reference> ref = *p_args[i];
|
|
if (!ref.is_null()) {
|
|
if (!ref.is_null()) {
|
|
if (Object::cast_to<JavaObject>(ref.ptr())) {
|
|
if (Object::cast_to<JavaObject>(ref.ptr())) {
|
|
@@ -121,9 +123,9 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|
|
|
|
|
} break;
|
|
} break;
|
|
default: {
|
|
default: {
|
|
- if (p_args[i]->get_type() != Variant::ARRAY)
|
|
|
|
|
|
+ if (p_args[i]->get_type() != Variant::ARRAY) {
|
|
arg_expected = Variant::ARRAY;
|
|
arg_expected = Variant::ARRAY;
|
|
-
|
|
|
|
|
|
+ }
|
|
} break;
|
|
} break;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -135,19 +137,21 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
- if (!valid)
|
|
|
|
|
|
+ if (!valid) {
|
|
continue;
|
|
continue;
|
|
|
|
+ }
|
|
|
|
|
|
method = &E->get();
|
|
method = &E->get();
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
- if (!method)
|
|
|
|
|
|
+ if (!method) {
|
|
return true; //no version convinces
|
|
return true; //no version convinces
|
|
|
|
+ }
|
|
|
|
|
|
r_error.error = Variant::CallError::CALL_OK;
|
|
r_error.error = Variant::CallError::CALL_OK;
|
|
|
|
|
|
- jvalue *argv = NULL;
|
|
|
|
|
|
+ jvalue *argv = nullptr;
|
|
|
|
|
|
if (method->param_types.size()) {
|
|
if (method->param_types.size()) {
|
|
argv = (jvalue *)alloca(sizeof(jvalue) * method->param_types.size());
|
|
argv = (jvalue *)alloca(sizeof(jvalue) * method->param_types.size());
|
|
@@ -158,7 +162,7 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|
switch (method->param_types[i]) {
|
|
switch (method->param_types[i]) {
|
|
case ARG_TYPE_VOID: {
|
|
case ARG_TYPE_VOID: {
|
|
//can't happen
|
|
//can't happen
|
|
- argv[i].l = NULL; //I hope this works
|
|
|
|
|
|
+ argv[i].l = nullptr; //I hope this works
|
|
} break;
|
|
} break;
|
|
|
|
|
|
case ARG_TYPE_BOOLEAN: {
|
|
case ARG_TYPE_BOOLEAN: {
|
|
@@ -268,7 +272,7 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|
if (jo.is_valid()) {
|
|
if (jo.is_valid()) {
|
|
argv[i].l = jo->instance;
|
|
argv[i].l = jo->instance;
|
|
} else {
|
|
} else {
|
|
- argv[i].l = NULL; //I hope this works
|
|
|
|
|
|
+ argv[i].l = nullptr; //I hope this works
|
|
}
|
|
}
|
|
|
|
|
|
} break;
|
|
} break;
|
|
@@ -361,7 +365,7 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|
} break;
|
|
} break;
|
|
case ARG_ARRAY_BIT | ARG_TYPE_STRING: {
|
|
case ARG_ARRAY_BIT | ARG_TYPE_STRING: {
|
|
Array arr = *p_args[i];
|
|
Array arr = *p_args[i];
|
|
- jobjectArray a = env->NewObjectArray(arr.size(), env->FindClass("java/lang/String"), NULL);
|
|
|
|
|
|
+ jobjectArray a = env->NewObjectArray(arr.size(), env->FindClass("java/lang/String"), nullptr);
|
|
for (int j = 0; j < arr.size(); j++) {
|
|
for (int j = 0; j < arr.size(); j++) {
|
|
String s = arr[j];
|
|
String s = arr[j];
|
|
jstring jStr = env->NewStringUTF(s.utf8().get_data());
|
|
jstring jStr = env->NewStringUTF(s.utf8().get_data());
|
|
@@ -373,7 +377,7 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|
to_free.push_back(a);
|
|
to_free.push_back(a);
|
|
} break;
|
|
} break;
|
|
case ARG_ARRAY_BIT | ARG_TYPE_CLASS: {
|
|
case ARG_ARRAY_BIT | ARG_TYPE_CLASS: {
|
|
- argv[i].l = NULL;
|
|
|
|
|
|
+ argv[i].l = nullptr;
|
|
} break;
|
|
} break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -483,7 +487,7 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|
|
|
|
|
Variant JavaClass::call(const StringName &p_method, const Variant **p_args, int p_argcount, Variant::CallError &r_error) {
|
|
Variant JavaClass::call(const StringName &p_method, const Variant **p_args, int p_argcount, Variant::CallError &r_error) {
|
|
Variant ret;
|
|
Variant ret;
|
|
- bool found = _call_method(NULL, p_method, p_args, p_argcount, r_error, ret);
|
|
|
|
|
|
+ bool found = _call_method(nullptr, p_method, p_args, p_argcount, r_error, ret);
|
|
if (found) {
|
|
if (found) {
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
@@ -780,9 +784,9 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
- if (!o)
|
|
|
|
|
|
+ if (!o) {
|
|
ret.push_back(Variant());
|
|
ret.push_back(Variant());
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
bool val = env->CallBooleanMethod(o, JavaClassWrapper::singleton->Boolean_booleanValue);
|
|
bool val = env->CallBooleanMethod(o, JavaClassWrapper::singleton->Boolean_booleanValue);
|
|
ret.push_back(val);
|
|
ret.push_back(val);
|
|
}
|
|
}
|
|
@@ -801,9 +805,9 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
- if (!o)
|
|
|
|
|
|
+ if (!o) {
|
|
ret.push_back(Variant());
|
|
ret.push_back(Variant());
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
int val = env->CallByteMethod(o, JavaClassWrapper::singleton->Byte_byteValue);
|
|
int val = env->CallByteMethod(o, JavaClassWrapper::singleton->Byte_byteValue);
|
|
ret.push_back(val);
|
|
ret.push_back(val);
|
|
}
|
|
}
|
|
@@ -821,9 +825,9 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
- if (!o)
|
|
|
|
|
|
+ if (!o) {
|
|
ret.push_back(Variant());
|
|
ret.push_back(Variant());
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
int val = env->CallCharMethod(o, JavaClassWrapper::singleton->Character_characterValue);
|
|
int val = env->CallCharMethod(o, JavaClassWrapper::singleton->Character_characterValue);
|
|
ret.push_back(val);
|
|
ret.push_back(val);
|
|
}
|
|
}
|
|
@@ -841,9 +845,9 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
- if (!o)
|
|
|
|
|
|
+ if (!o) {
|
|
ret.push_back(Variant());
|
|
ret.push_back(Variant());
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
int val = env->CallShortMethod(o, JavaClassWrapper::singleton->Short_shortValue);
|
|
int val = env->CallShortMethod(o, JavaClassWrapper::singleton->Short_shortValue);
|
|
ret.push_back(val);
|
|
ret.push_back(val);
|
|
}
|
|
}
|
|
@@ -861,9 +865,9 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
- if (!o)
|
|
|
|
|
|
+ if (!o) {
|
|
ret.push_back(Variant());
|
|
ret.push_back(Variant());
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
int val = env->CallIntMethod(o, JavaClassWrapper::singleton->Integer_integerValue);
|
|
int val = env->CallIntMethod(o, JavaClassWrapper::singleton->Integer_integerValue);
|
|
ret.push_back(val);
|
|
ret.push_back(val);
|
|
}
|
|
}
|
|
@@ -881,9 +885,9 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
- if (!o)
|
|
|
|
|
|
+ if (!o) {
|
|
ret.push_back(Variant());
|
|
ret.push_back(Variant());
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
int64_t val = env->CallLongMethod(o, JavaClassWrapper::singleton->Long_longValue);
|
|
int64_t val = env->CallLongMethod(o, JavaClassWrapper::singleton->Long_longValue);
|
|
ret.push_back(val);
|
|
ret.push_back(val);
|
|
}
|
|
}
|
|
@@ -901,9 +905,9 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
- if (!o)
|
|
|
|
|
|
+ if (!o) {
|
|
ret.push_back(Variant());
|
|
ret.push_back(Variant());
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
float val = env->CallFloatMethod(o, JavaClassWrapper::singleton->Float_floatValue);
|
|
float val = env->CallFloatMethod(o, JavaClassWrapper::singleton->Float_floatValue);
|
|
ret.push_back(val);
|
|
ret.push_back(val);
|
|
}
|
|
}
|
|
@@ -921,9 +925,9 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
- if (!o)
|
|
|
|
|
|
+ if (!o) {
|
|
ret.push_back(Variant());
|
|
ret.push_back(Variant());
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
double val = env->CallDoubleMethod(o, JavaClassWrapper::singleton->Double_doubleValue);
|
|
double val = env->CallDoubleMethod(o, JavaClassWrapper::singleton->Double_doubleValue);
|
|
ret.push_back(val);
|
|
ret.push_back(val);
|
|
}
|
|
}
|
|
@@ -942,9 +946,9 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
jobject o = env->GetObjectArrayElement(arr, i);
|
|
- if (!o)
|
|
|
|
|
|
+ if (!o) {
|
|
ret.push_back(Variant());
|
|
ret.push_back(Variant());
|
|
- else {
|
|
|
|
|
|
+ } else {
|
|
String val = jstring_to_string((jstring)o, env);
|
|
String val = jstring_to_string((jstring)o, env);
|
|
ret.push_back(val);
|
|
ret.push_back(val);
|
|
}
|
|
}
|
|
@@ -962,22 +966,19 @@ bool JavaClass::_convert_object_to_variant(JNIEnv *env, jobject obj, Variant &va
|
|
}
|
|
}
|
|
|
|
|
|
Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|
Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|
- if (class_cache.has(p_class))
|
|
|
|
|
|
+ if (class_cache.has(p_class)) {
|
|
return class_cache[p_class];
|
|
return class_cache[p_class];
|
|
|
|
+ }
|
|
|
|
|
|
JNIEnv *env = get_jni_env();
|
|
JNIEnv *env = get_jni_env();
|
|
- ERR_FAIL_COND_V(env == nullptr, Ref<JavaClass>());
|
|
|
|
|
|
+ ERR_FAIL_NULL_V(env, Ref<JavaClass>());
|
|
|
|
|
|
jclass bclass = env->FindClass(p_class.utf8().get_data());
|
|
jclass bclass = env->FindClass(p_class.utf8().get_data());
|
|
- ERR_FAIL_COND_V(!bclass, Ref<JavaClass>());
|
|
|
|
-
|
|
|
|
- //jmethodID getDeclaredMethods = env->GetMethodID(bclass,"getDeclaredMethods", "()[Ljava/lang/reflect/Method;");
|
|
|
|
-
|
|
|
|
- //ERR_FAIL_COND_V(!getDeclaredMethods,Ref<JavaClass>());
|
|
|
|
|
|
+ ERR_FAIL_NULL_V(bclass, Ref<JavaClass>());
|
|
|
|
|
|
jobjectArray methods = (jobjectArray)env->CallObjectMethod(bclass, getDeclaredMethods);
|
|
jobjectArray methods = (jobjectArray)env->CallObjectMethod(bclass, getDeclaredMethods);
|
|
|
|
|
|
- ERR_FAIL_COND_V(!methods, Ref<JavaClass>());
|
|
|
|
|
|
+ ERR_FAIL_NULL_V(methods, Ref<JavaClass>());
|
|
|
|
|
|
Ref<JavaClass> java_class = memnew(JavaClass);
|
|
Ref<JavaClass> java_class = memnew(JavaClass);
|
|
|
|
|
|
@@ -1057,9 +1058,10 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|
float new_likeliness = 0;
|
|
float new_likeliness = 0;
|
|
float existing_likeliness = 0;
|
|
float existing_likeliness = 0;
|
|
|
|
|
|
- if (E->get().param_types.size() != mi.param_types.size())
|
|
|
|
|
|
+ if (E->get().param_types.size() != mi.param_types.size()) {
|
|
continue;
|
|
continue;
|
|
- bool valid = true;
|
|
|
|
|
|
+ }
|
|
|
|
+ bool this_valid = true;
|
|
for (int j = 0; j < E->get().param_types.size(); j++) {
|
|
for (int j = 0; j < E->get().param_types.size(); j++) {
|
|
Variant::Type _new;
|
|
Variant::Type _new;
|
|
float new_l;
|
|
float new_l;
|
|
@@ -1068,15 +1070,16 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|
JavaClass::_convert_to_variant_type(E->get().param_types[j], existing, existing_l);
|
|
JavaClass::_convert_to_variant_type(E->get().param_types[j], existing, existing_l);
|
|
JavaClass::_convert_to_variant_type(mi.param_types[j], _new, new_l);
|
|
JavaClass::_convert_to_variant_type(mi.param_types[j], _new, new_l);
|
|
if (_new != existing) {
|
|
if (_new != existing) {
|
|
- valid = false;
|
|
|
|
|
|
+ this_valid = false;
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
new_likeliness += new_l;
|
|
new_likeliness += new_l;
|
|
existing_likeliness = existing_l;
|
|
existing_likeliness = existing_l;
|
|
}
|
|
}
|
|
|
|
|
|
- if (!valid)
|
|
|
|
|
|
+ if (!this_valid) {
|
|
continue;
|
|
continue;
|
|
|
|
+ }
|
|
|
|
|
|
if (new_likeliness > existing_likeliness) {
|
|
if (new_likeliness > existing_likeliness) {
|
|
java_class->methods[str_method].erase(E);
|
|
java_class->methods[str_method].erase(E);
|
|
@@ -1087,10 +1090,11 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|
}
|
|
}
|
|
|
|
|
|
if (!discard) {
|
|
if (!discard) {
|
|
- if (mi._static)
|
|
|
|
|
|
+ if (mi._static) {
|
|
mi.method = env->GetStaticMethodID(bclass, str_method.utf8().get_data(), signature.utf8().get_data());
|
|
mi.method = env->GetStaticMethodID(bclass, str_method.utf8().get_data(), signature.utf8().get_data());
|
|
- else
|
|
|
|
|
|
+ } else {
|
|
mi.method = env->GetMethodID(bclass, str_method.utf8().get_data(), signature.utf8().get_data());
|
|
mi.method = env->GetMethodID(bclass, str_method.utf8().get_data(), signature.utf8().get_data());
|
|
|
|
+ }
|
|
|
|
|
|
ERR_CONTINUE(!mi.method);
|
|
ERR_CONTINUE(!mi.method);
|
|
|
|
|
|
@@ -1100,7 +1104,7 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|
env->DeleteLocalRef(obj);
|
|
env->DeleteLocalRef(obj);
|
|
env->DeleteLocalRef(param_types);
|
|
env->DeleteLocalRef(param_types);
|
|
env->DeleteLocalRef(return_type);
|
|
env->DeleteLocalRef(return_type);
|
|
- };
|
|
|
|
|
|
+ }
|
|
|
|
|
|
env->DeleteLocalRef(methods);
|
|
env->DeleteLocalRef(methods);
|
|
|
|
|
|
@@ -1118,7 +1122,7 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|
int mods = env->CallIntMethod(obj, Field_getModifiers);
|
|
int mods = env->CallIntMethod(obj, Field_getModifiers);
|
|
if ((mods & 0x8) && (mods & 0x10) && (mods & 0x1)) { //static final public!
|
|
if ((mods & 0x8) && (mods & 0x10) && (mods & 0x1)) { //static final public!
|
|
|
|
|
|
- jobject objc = env->CallObjectMethod(obj, Field_get, NULL);
|
|
|
|
|
|
+ jobject objc = env->CallObjectMethod(obj, Field_get, nullptr);
|
|
if (objc) {
|
|
if (objc) {
|
|
uint32_t sig;
|
|
uint32_t sig;
|
|
String strsig;
|
|
String strsig;
|
|
@@ -1145,16 +1149,16 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|
return Ref<JavaClass>();
|
|
return Ref<JavaClass>();
|
|
}
|
|
}
|
|
|
|
|
|
-JavaClassWrapper *JavaClassWrapper::singleton = NULL;
|
|
|
|
|
|
+JavaClassWrapper *JavaClassWrapper::singleton = nullptr;
|
|
|
|
|
|
JavaClassWrapper::JavaClassWrapper(jobject p_activity) {
|
|
JavaClassWrapper::JavaClassWrapper(jobject p_activity) {
|
|
singleton = this;
|
|
singleton = this;
|
|
|
|
|
|
JNIEnv *env = get_jni_env();
|
|
JNIEnv *env = get_jni_env();
|
|
- ERR_FAIL_COND(env == nullptr);
|
|
|
|
|
|
+ ERR_FAIL_NULL(env);
|
|
|
|
|
|
- jclass activityClass = env->FindClass("android/app/Activity");
|
|
|
|
- jmethodID getClassLoader = env->GetMethodID(activityClass, "getClassLoader", "()Ljava/lang/ClassLoader;");
|
|
|
|
|
|
+ jclass activity = env->FindClass("android/app/Activity");
|
|
|
|
+ jmethodID getClassLoader = env->GetMethodID(activity, "getClassLoader", "()Ljava/lang/ClassLoader;");
|
|
classLoader = env->CallObjectMethod(p_activity, getClassLoader);
|
|
classLoader = env->CallObjectMethod(p_activity, getClassLoader);
|
|
classLoader = (jclass)env->NewGlobalRef(classLoader);
|
|
classLoader = (jclass)env->NewGlobalRef(classLoader);
|
|
jclass classLoaderClass = env->FindClass("java/lang/ClassLoader");
|
|
jclass classLoaderClass = env->FindClass("java/lang/ClassLoader");
|
|
@@ -1164,18 +1168,18 @@ JavaClassWrapper::JavaClassWrapper(jobject p_activity) {
|
|
getDeclaredMethods = env->GetMethodID(bclass, "getDeclaredMethods", "()[Ljava/lang/reflect/Method;");
|
|
getDeclaredMethods = env->GetMethodID(bclass, "getDeclaredMethods", "()[Ljava/lang/reflect/Method;");
|
|
getFields = env->GetMethodID(bclass, "getFields", "()[Ljava/lang/reflect/Field;");
|
|
getFields = env->GetMethodID(bclass, "getFields", "()[Ljava/lang/reflect/Field;");
|
|
Class_getName = env->GetMethodID(bclass, "getName", "()Ljava/lang/String;");
|
|
Class_getName = env->GetMethodID(bclass, "getName", "()Ljava/lang/String;");
|
|
- //
|
|
|
|
|
|
+
|
|
bclass = env->FindClass("java/lang/reflect/Method");
|
|
bclass = env->FindClass("java/lang/reflect/Method");
|
|
getParameterTypes = env->GetMethodID(bclass, "getParameterTypes", "()[Ljava/lang/Class;");
|
|
getParameterTypes = env->GetMethodID(bclass, "getParameterTypes", "()[Ljava/lang/Class;");
|
|
getReturnType = env->GetMethodID(bclass, "getReturnType", "()Ljava/lang/Class;");
|
|
getReturnType = env->GetMethodID(bclass, "getReturnType", "()Ljava/lang/Class;");
|
|
getName = env->GetMethodID(bclass, "getName", "()Ljava/lang/String;");
|
|
getName = env->GetMethodID(bclass, "getName", "()Ljava/lang/String;");
|
|
getModifiers = env->GetMethodID(bclass, "getModifiers", "()I");
|
|
getModifiers = env->GetMethodID(bclass, "getModifiers", "()I");
|
|
- ///
|
|
|
|
|
|
+
|
|
bclass = env->FindClass("java/lang/reflect/Field");
|
|
bclass = env->FindClass("java/lang/reflect/Field");
|
|
Field_getName = env->GetMethodID(bclass, "getName", "()Ljava/lang/String;");
|
|
Field_getName = env->GetMethodID(bclass, "getName", "()Ljava/lang/String;");
|
|
Field_getModifiers = env->GetMethodID(bclass, "getModifiers", "()I");
|
|
Field_getModifiers = env->GetMethodID(bclass, "getModifiers", "()I");
|
|
Field_get = env->GetMethodID(bclass, "get", "(Ljava/lang/Object;)Ljava/lang/Object;");
|
|
Field_get = env->GetMethodID(bclass, "get", "(Ljava/lang/Object;)Ljava/lang/Object;");
|
|
- // each
|
|
|
|
|
|
+
|
|
bclass = env->FindClass("java/lang/Boolean");
|
|
bclass = env->FindClass("java/lang/Boolean");
|
|
Boolean_booleanValue = env->GetMethodID(bclass, "booleanValue", "()Z");
|
|
Boolean_booleanValue = env->GetMethodID(bclass, "booleanValue", "()Z");
|
|
|
|
|