JavaClassWrapper: Allow handling exceptions (rather than just crashing)
This commit is contained in:
@@ -70,6 +70,7 @@ void JavaObject::_bind_methods() {
|
||||
|
||||
void JavaClassWrapper::_bind_methods() {
|
||||
ClassDB::bind_method(D_METHOD("wrap", "name"), &JavaClassWrapper::wrap);
|
||||
ClassDB::bind_method(D_METHOD("get_exception"), &JavaClassWrapper::get_exception);
|
||||
}
|
||||
|
||||
#if !defined(ANDROID_ENABLED)
|
||||
|
||||
@@ -271,6 +271,8 @@ class JavaClassWrapper : public Object {
|
||||
bool _get_type_sig(JNIEnv *env, jobject obj, uint32_t &sig, String &strsig);
|
||||
#endif
|
||||
|
||||
Ref<JavaObject> exception;
|
||||
|
||||
Ref<JavaClass> _wrap(const String &p_class, bool p_allow_private_methods_access);
|
||||
|
||||
static JavaClassWrapper *singleton;
|
||||
@@ -285,6 +287,10 @@ public:
|
||||
return _wrap(p_class, false);
|
||||
}
|
||||
|
||||
Ref<JavaObject> get_exception() {
|
||||
return exception;
|
||||
}
|
||||
|
||||
#ifdef ANDROID_ENABLED
|
||||
Ref<JavaClass> wrap_jclass(jclass p_class, bool p_allow_private_methods_access = false);
|
||||
#endif
|
||||
|
||||
@@ -517,6 +517,20 @@ bool JavaClass::_call_method(JavaObject *p_instance, const StringName &p_method,
|
||||
env->DeleteLocalRef(E);
|
||||
}
|
||||
|
||||
jobject exception = env->ExceptionOccurred();
|
||||
if (exception) {
|
||||
env->ExceptionClear();
|
||||
|
||||
jclass java_class = env->GetObjectClass(exception);
|
||||
Ref<JavaClass> java_class_wrapped = JavaClassWrapper::singleton->wrap_jclass(java_class);
|
||||
env->DeleteLocalRef(java_class);
|
||||
|
||||
JavaClassWrapper::singleton->exception.instantiate(java_class_wrapped, exception);
|
||||
env->DeleteLocalRef(exception);
|
||||
} else {
|
||||
JavaClassWrapper::singleton->exception.unref();
|
||||
}
|
||||
|
||||
return success;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user