mirror of
https://github.com/godotengine/godot.git
synced 2025-10-23 09:53:25 +00:00
Cleanup Android C++ code
This commit is contained in:
parent
340283f5be
commit
7a782edeaa
29 changed files with 405 additions and 459 deletions
|
@ -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) {
|
||||
Map<StringName, List<MethodInfo>>::Element *M = methods.find(p_method);
|
||||
if (!M)
|
||||
if (!M) {
|
||||
return false;
|
||||
}
|
||||
|
||||
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()) {
|
||||
if (!p_instance && !E->get()._static) {
|
||||
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?
|
||||
} break;
|
||||
case ARG_TYPE_BOOLEAN: {
|
||||
if (p_args[i]->get_type() != Variant::BOOL)
|
||||
if (p_args[i]->get_type() != Variant::BOOL) {
|
||||
arg_expected = Variant::BOOL;
|
||||
}
|
||||
} break;
|
||||
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_BYTE:
|
||||
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_INT:
|
||||
case ARG_TYPE_LONG: {
|
||||
if (!p_args[i]->is_num())
|
||||
if (!p_args[i]->is_num()) {
|
||||
arg_expected = Variant::INT;
|
||||
|
||||
}
|
||||
} break;
|
||||
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_FLOAT:
|
||||
case ARG_NUMBER_CLASS_BIT | ARG_TYPE_DOUBLE:
|
||||
case ARG_TYPE_FLOAT:
|
||||
case ARG_TYPE_DOUBLE: {
|
||||
if (!p_args[i]->is_num())
|
||||
if (!p_args[i]->is_num()) {
|
||||
arg_expected = Variant::REAL;
|
||||
|
||||
}
|
||||
} break;
|
||||
case ARG_TYPE_STRING: {
|
||||
if (p_args[i]->get_type() != Variant::STRING)
|
||||
if (p_args[i]->get_type() != Variant::STRING) {
|
||||
arg_expected = Variant::STRING;
|
||||
|
||||
}
|
||||
} break;
|
||||
case ARG_TYPE_CLASS: {
|
||||
if (p_args[i]->get_type() != Variant::OBJECT)
|
||||
if (p_args[i]->get_type() != Variant::OBJECT) {
|
||||
arg_expected = Variant::OBJECT;
|
||||
else {
|
||||
} else {
|
||||
Ref<Reference> ref = *p_args[i];
|
||||
if (!ref.is_null()) {
|
||||
if (Object::cast_to<JavaObject>(ref.ptr())) {
|
||||
|
@ -121,9 +123,9 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|||
|
||||
} break;
|
||||
default: {
|
||||
if (p_args[i]->get_type() != Variant::ARRAY)
|
||||
if (p_args[i]->get_type() != Variant::ARRAY) {
|
||||
arg_expected = Variant::ARRAY;
|
||||
|
||||
}
|
||||
} break;
|
||||
}
|
||||
|
||||
|
@ -135,19 +137,21 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|||
break;
|
||||
}
|
||||
}
|
||||
if (!valid)
|
||||
if (!valid) {
|
||||
continue;
|
||||
}
|
||||
|
||||
method = &E->get();
|
||||
break;
|
||||
}
|
||||
|
||||
if (!method)
|
||||
if (!method) {
|
||||
return true; //no version convinces
|
||||
}
|
||||
|
||||
r_error.error = Variant::CallError::CALL_OK;
|
||||
|
||||
jvalue *argv = NULL;
|
||||
jvalue *argv = nullptr;
|
||||
|
||||
if (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]) {
|
||||
case ARG_TYPE_VOID: {
|
||||
//can't happen
|
||||
argv[i].l = NULL; //I hope this works
|
||||
argv[i].l = nullptr; //I hope this works
|
||||
} break;
|
||||
|
||||
case ARG_TYPE_BOOLEAN: {
|
||||
|
@ -268,7 +272,7 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|||
if (jo.is_valid()) {
|
||||
argv[i].l = jo->instance;
|
||||
} else {
|
||||
argv[i].l = NULL; //I hope this works
|
||||
argv[i].l = nullptr; //I hope this works
|
||||
}
|
||||
|
||||
} break;
|
||||
|
@ -361,7 +365,7 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
|||
} break;
|
||||
case ARG_ARRAY_BIT | ARG_TYPE_STRING: {
|
||||
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++) {
|
||||
String s = arr[j];
|
||||
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);
|
||||
} break;
|
||||
case ARG_ARRAY_BIT | ARG_TYPE_CLASS: {
|
||||
argv[i].l = NULL;
|
||||
argv[i].l = nullptr;
|
||||
} 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 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) {
|
||||
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++) {
|
||||
jobject o = env->GetObjectArrayElement(arr, i);
|
||||
if (!o)
|
||||
if (!o) {
|
||||
ret.push_back(Variant());
|
||||
else {
|
||||
} else {
|
||||
bool val = env->CallBooleanMethod(o, JavaClassWrapper::singleton->Boolean_booleanValue);
|
||||
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++) {
|
||||
jobject o = env->GetObjectArrayElement(arr, i);
|
||||
if (!o)
|
||||
if (!o) {
|
||||
ret.push_back(Variant());
|
||||
else {
|
||||
} else {
|
||||
int val = env->CallByteMethod(o, JavaClassWrapper::singleton->Byte_byteValue);
|
||||
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++) {
|
||||
jobject o = env->GetObjectArrayElement(arr, i);
|
||||
if (!o)
|
||||
if (!o) {
|
||||
ret.push_back(Variant());
|
||||
else {
|
||||
} else {
|
||||
int val = env->CallCharMethod(o, JavaClassWrapper::singleton->Character_characterValue);
|
||||
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++) {
|
||||
jobject o = env->GetObjectArrayElement(arr, i);
|
||||
if (!o)
|
||||
if (!o) {
|
||||
ret.push_back(Variant());
|
||||
else {
|
||||
} else {
|
||||
int val = env->CallShortMethod(o, JavaClassWrapper::singleton->Short_shortValue);
|
||||
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++) {
|
||||
jobject o = env->GetObjectArrayElement(arr, i);
|
||||
if (!o)
|
||||
if (!o) {
|
||||
ret.push_back(Variant());
|
||||
else {
|
||||
} else {
|
||||
int val = env->CallIntMethod(o, JavaClassWrapper::singleton->Integer_integerValue);
|
||||
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++) {
|
||||
jobject o = env->GetObjectArrayElement(arr, i);
|
||||
if (!o)
|
||||
if (!o) {
|
||||
ret.push_back(Variant());
|
||||
else {
|
||||
} else {
|
||||
int64_t val = env->CallLongMethod(o, JavaClassWrapper::singleton->Long_longValue);
|
||||
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++) {
|
||||
jobject o = env->GetObjectArrayElement(arr, i);
|
||||
if (!o)
|
||||
if (!o) {
|
||||
ret.push_back(Variant());
|
||||
else {
|
||||
} else {
|
||||
float val = env->CallFloatMethod(o, JavaClassWrapper::singleton->Float_floatValue);
|
||||
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++) {
|
||||
jobject o = env->GetObjectArrayElement(arr, i);
|
||||
if (!o)
|
||||
if (!o) {
|
||||
ret.push_back(Variant());
|
||||
else {
|
||||
} else {
|
||||
double val = env->CallDoubleMethod(o, JavaClassWrapper::singleton->Double_doubleValue);
|
||||
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++) {
|
||||
jobject o = env->GetObjectArrayElement(arr, i);
|
||||
if (!o)
|
||||
if (!o) {
|
||||
ret.push_back(Variant());
|
||||
else {
|
||||
} else {
|
||||
String val = jstring_to_string((jstring)o, env);
|
||||
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) {
|
||||
if (class_cache.has(p_class))
|
||||
if (class_cache.has(p_class)) {
|
||||
return class_cache[p_class];
|
||||
}
|
||||
|
||||
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());
|
||||
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);
|
||||
|
||||
ERR_FAIL_COND_V(!methods, Ref<JavaClass>());
|
||||
ERR_FAIL_NULL_V(methods, Ref<JavaClass>());
|
||||
|
||||
Ref<JavaClass> java_class = memnew(JavaClass);
|
||||
|
||||
|
@ -1057,9 +1058,10 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|||
float new_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;
|
||||
bool valid = true;
|
||||
}
|
||||
bool this_valid = true;
|
||||
for (int j = 0; j < E->get().param_types.size(); j++) {
|
||||
Variant::Type _new;
|
||||
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(mi.param_types[j], _new, new_l);
|
||||
if (_new != existing) {
|
||||
valid = false;
|
||||
this_valid = false;
|
||||
break;
|
||||
}
|
||||
new_likeliness += new_l;
|
||||
existing_likeliness = existing_l;
|
||||
}
|
||||
|
||||
if (!valid)
|
||||
if (!this_valid) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if (new_likeliness > existing_likeliness) {
|
||||
java_class->methods[str_method].erase(E);
|
||||
|
@ -1087,10 +1090,11 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|||
}
|
||||
|
||||
if (!discard) {
|
||||
if (mi._static)
|
||||
if (mi._static) {
|
||||
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());
|
||||
}
|
||||
|
||||
ERR_CONTINUE(!mi.method);
|
||||
|
||||
|
@ -1100,7 +1104,7 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|||
env->DeleteLocalRef(obj);
|
||||
env->DeleteLocalRef(param_types);
|
||||
env->DeleteLocalRef(return_type);
|
||||
};
|
||||
}
|
||||
|
||||
env->DeleteLocalRef(methods);
|
||||
|
||||
|
@ -1118,7 +1122,7 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|||
int mods = env->CallIntMethod(obj, Field_getModifiers);
|
||||
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) {
|
||||
uint32_t sig;
|
||||
String strsig;
|
||||
|
@ -1145,16 +1149,16 @@ Ref<JavaClass> JavaClassWrapper::wrap(const String &p_class) {
|
|||
return Ref<JavaClass>();
|
||||
}
|
||||
|
||||
JavaClassWrapper *JavaClassWrapper::singleton = NULL;
|
||||
JavaClassWrapper *JavaClassWrapper::singleton = nullptr;
|
||||
|
||||
JavaClassWrapper::JavaClassWrapper(jobject p_activity) {
|
||||
singleton = this;
|
||||
|
||||
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 = (jclass)env->NewGlobalRef(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;");
|
||||
getFields = env->GetMethodID(bclass, "getFields", "()[Ljava/lang/reflect/Field;");
|
||||
Class_getName = env->GetMethodID(bclass, "getName", "()Ljava/lang/String;");
|
||||
//
|
||||
|
||||
bclass = env->FindClass("java/lang/reflect/Method");
|
||||
getParameterTypes = env->GetMethodID(bclass, "getParameterTypes", "()[Ljava/lang/Class;");
|
||||
getReturnType = env->GetMethodID(bclass, "getReturnType", "()Ljava/lang/Class;");
|
||||
getName = env->GetMethodID(bclass, "getName", "()Ljava/lang/String;");
|
||||
getModifiers = env->GetMethodID(bclass, "getModifiers", "()I");
|
||||
///
|
||||
|
||||
bclass = env->FindClass("java/lang/reflect/Field");
|
||||
Field_getName = env->GetMethodID(bclass, "getName", "()Ljava/lang/String;");
|
||||
Field_getModifiers = env->GetMethodID(bclass, "getModifiers", "()I");
|
||||
Field_get = env->GetMethodID(bclass, "get", "(Ljava/lang/Object;)Ljava/lang/Object;");
|
||||
// each
|
||||
|
||||
bclass = env->FindClass("java/lang/Boolean");
|
||||
Boolean_booleanValue = env->GetMethodID(bclass, "booleanValue", "()Z");
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue