fix a crash situation when starting a thread and other small fixes
This commit is contained in:
parent
5900e7f589
commit
f220183e40
@ -1757,7 +1757,9 @@ _Mutex::~_Mutex(){
|
|||||||
|
|
||||||
void _Thread::_start_func(void *ud) {
|
void _Thread::_start_func(void *ud) {
|
||||||
|
|
||||||
_Thread *t=(_Thread*)ud;
|
Ref<_Thread>* tud=(Ref<_Thread>*)ud;
|
||||||
|
Ref<_Thread> t=*tud;
|
||||||
|
memdelete(tud);
|
||||||
Variant::CallError ce;
|
Variant::CallError ce;
|
||||||
const Variant* arg[1]={&t->userdata};
|
const Variant* arg[1]={&t->userdata};
|
||||||
t->ret=t->target_instance->call(t->target_method,arg,1,ce);
|
t->ret=t->target_instance->call(t->target_method,arg,1,ce);
|
||||||
@ -1804,9 +1806,11 @@ Error _Thread::start(Object *p_instance,const StringName& p_method,const Variant
|
|||||||
userdata=p_userdata;
|
userdata=p_userdata;
|
||||||
active=true;
|
active=true;
|
||||||
|
|
||||||
|
Ref<_Thread> *ud = memnew( Ref<_Thread>(this) );
|
||||||
|
|
||||||
Thread::Settings s;
|
Thread::Settings s;
|
||||||
s.priority=(Thread::Priority)p_priority;
|
s.priority=(Thread::Priority)p_priority;
|
||||||
thread = Thread::create(_start_func,this,s);
|
thread = Thread::create(_start_func,ud,s);
|
||||||
if (!thread) {
|
if (!thread) {
|
||||||
active=false;
|
active=false;
|
||||||
target_method=StringName();
|
target_method=StringName();
|
||||||
@ -1867,5 +1871,8 @@ _Thread::_Thread() {
|
|||||||
|
|
||||||
_Thread::~_Thread() {
|
_Thread::~_Thread() {
|
||||||
|
|
||||||
|
if (active) {
|
||||||
|
ERR_EXPLAIN("Reference to a Thread object object was lost while the thread is still running..")
|
||||||
|
}
|
||||||
ERR_FAIL_COND(active==true);
|
ERR_FAIL_COND(active==true);
|
||||||
}
|
}
|
||||||
|
@ -437,6 +437,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int ac = E->get().argtypes.size();
|
int ac = E->get().argtypes.size();
|
||||||
if (ac<p_argcount) {
|
if (ac<p_argcount) {
|
||||||
|
|
||||||
@ -455,7 +456,6 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
for(int i=0;i<p_argcount;i++) {
|
for(int i=0;i<p_argcount;i++) {
|
||||||
|
|
||||||
if (!Variant::can_convert(p_args[i]->get_type(),E->get().argtypes[i])) {
|
if (!Variant::can_convert(p_args[i]->get_type(),E->get().argtypes[i])) {
|
||||||
@ -476,6 +476,10 @@ public:
|
|||||||
|
|
||||||
JNIEnv *env = ThreadAndroid::get_env();
|
JNIEnv *env = ThreadAndroid::get_env();
|
||||||
|
|
||||||
|
int res = env->PushLocalFrame(16);
|
||||||
|
|
||||||
|
ERR_FAIL_COND_V(res!=0,Variant());
|
||||||
|
|
||||||
//print_line("argcount "+String::num(p_argcount));
|
//print_line("argcount "+String::num(p_argcount));
|
||||||
List<jobject> to_erase;
|
List<jobject> to_erase;
|
||||||
for(int i=0;i<p_argcount;i++) {
|
for(int i=0;i<p_argcount;i++) {
|
||||||
@ -568,6 +572,7 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
print_line("failure..");
|
print_line("failure..");
|
||||||
|
env->PopLocalFrame(NULL);
|
||||||
ERR_FAIL_V(Variant());
|
ERR_FAIL_V(Variant());
|
||||||
} break;
|
} break;
|
||||||
}
|
}
|
||||||
@ -576,6 +581,8 @@ public:
|
|||||||
env->DeleteLocalRef(to_erase.front()->get());
|
env->DeleteLocalRef(to_erase.front()->get());
|
||||||
to_erase.pop_front();
|
to_erase.pop_front();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
env->PopLocalFrame(NULL);
|
||||||
//print_line("success");
|
//print_line("success");
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
@ -1613,11 +1620,15 @@ JNIEXPORT void JNICALL Java_com_android_godot_GodotLib_method(JNIEnv * env, jobj
|
|||||||
|
|
||||||
JNIEXPORT void JNICALL Java_com_android_godot_GodotLib_callobject(JNIEnv * env, jobject p_obj, jint ID, jstring method, jobjectArray params) {
|
JNIEXPORT void JNICALL Java_com_android_godot_GodotLib_callobject(JNIEnv * env, jobject p_obj, jint ID, jstring method, jobjectArray params) {
|
||||||
|
|
||||||
String str_method = env->GetStringUTFChars( method, NULL );
|
|
||||||
|
|
||||||
Object* obj = ObjectDB::get_instance(ID);
|
Object* obj = ObjectDB::get_instance(ID);
|
||||||
ERR_FAIL_COND(!obj);
|
ERR_FAIL_COND(!obj);
|
||||||
|
|
||||||
|
int res = env->PushLocalFrame(16);
|
||||||
|
ERR_FAIL_COND(res!=0);
|
||||||
|
|
||||||
|
String str_method = env->GetStringUTFChars( method, NULL );
|
||||||
|
|
||||||
|
|
||||||
int count = env->GetArrayLength(params);
|
int count = env->GetArrayLength(params);
|
||||||
Variant* vlist = (Variant*)alloca(sizeof(Variant) * count);
|
Variant* vlist = (Variant*)alloca(sizeof(Variant) * count);
|
||||||
Variant** vptr = (Variant**)alloca(sizeof(Variant*) * count);
|
Variant** vptr = (Variant**)alloca(sizeof(Variant*) * count);
|
||||||
@ -1637,15 +1648,22 @@ JNIEXPORT void JNICALL Java_com_android_godot_GodotLib_callobject(JNIEnv * env,
|
|||||||
Variant::CallError err;
|
Variant::CallError err;
|
||||||
obj->call(str_method, (const Variant**)vptr, count, err);
|
obj->call(str_method, (const Variant**)vptr, count, err);
|
||||||
// something
|
// something
|
||||||
|
|
||||||
|
env->PopLocalFrame(NULL);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_com_android_godot_GodotLib_calldeferred(JNIEnv * env, jobject p_obj, jint ID, jstring method, jobjectArray params) {
|
JNIEXPORT void JNICALL Java_com_android_godot_GodotLib_calldeferred(JNIEnv * env, jobject p_obj, jint ID, jstring method, jobjectArray params) {
|
||||||
|
|
||||||
String str_method = env->GetStringUTFChars( method, NULL );
|
|
||||||
|
|
||||||
Object* obj = ObjectDB::get_instance(ID);
|
Object* obj = ObjectDB::get_instance(ID);
|
||||||
ERR_FAIL_COND(!obj);
|
ERR_FAIL_COND(!obj);
|
||||||
|
|
||||||
|
int res = env->PushLocalFrame(16);
|
||||||
|
ERR_FAIL_COND(res!=0);
|
||||||
|
|
||||||
|
String str_method = env->GetStringUTFChars( method, NULL );
|
||||||
|
|
||||||
int count = env->GetArrayLength(params);
|
int count = env->GetArrayLength(params);
|
||||||
Variant args[VARIANT_ARG_MAX];
|
Variant args[VARIANT_ARG_MAX];
|
||||||
|
|
||||||
@ -1666,6 +1684,8 @@ JNIEXPORT void JNICALL Java_com_android_godot_GodotLib_calldeferred(JNIEnv * env
|
|||||||
|
|
||||||
obj->call_deferred(str_method, args[0],args[1],args[2],args[3],args[4]);
|
obj->call_deferred(str_method, args[0],args[1],args[2],args[3],args[4]);
|
||||||
// something
|
// something
|
||||||
|
env->PopLocalFrame(NULL);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
//Main::cleanup();
|
//Main::cleanup();
|
||||||
|
@ -1673,6 +1673,8 @@ void RichTextLabel::_bind_methods() {
|
|||||||
ObjectTypeDB::bind_method(_MD("set_scroll_follow","follow"),&RichTextLabel::set_scroll_follow);
|
ObjectTypeDB::bind_method(_MD("set_scroll_follow","follow"),&RichTextLabel::set_scroll_follow);
|
||||||
ObjectTypeDB::bind_method(_MD("is_scroll_following"),&RichTextLabel::is_scroll_following);
|
ObjectTypeDB::bind_method(_MD("is_scroll_following"),&RichTextLabel::is_scroll_following);
|
||||||
|
|
||||||
|
ObjectTypeDB::bind_method(_MD("get_v_scroll"),&RichTextLabel::get_v_scroll);
|
||||||
|
|
||||||
ObjectTypeDB::bind_method(_MD("set_tab_size","spaces"),&RichTextLabel::set_tab_size);
|
ObjectTypeDB::bind_method(_MD("set_tab_size","spaces"),&RichTextLabel::set_tab_size);
|
||||||
ObjectTypeDB::bind_method(_MD("get_tab_size"),&RichTextLabel::get_tab_size);
|
ObjectTypeDB::bind_method(_MD("get_tab_size"),&RichTextLabel::get_tab_size);
|
||||||
|
|
||||||
|
@ -2638,8 +2638,11 @@ void EditorSceneImportPlugin::_filter_tracks(Node *scene, const String& p_text)
|
|||||||
for(Set<String>::Element *F=keep_local.front();F;F=F->next()) {
|
for(Set<String>::Element *F=keep_local.front();F;F=F->next()) {
|
||||||
keep.insert(F->get());
|
keep.insert(F->get());
|
||||||
}
|
}
|
||||||
|
print_line("FILTERING ANIM: "+String(E->get()));
|
||||||
_filter_anim_tracks(anim->get_animation(name),keep);
|
_filter_anim_tracks(anim->get_animation(name),keep);
|
||||||
|
} else {
|
||||||
|
print_line("NOT FILTERING ANIM: "+String(E->get()));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user