浏览代码

Let EditorLog use the right call queue for thread safety

This is a complement to f61c63e3a1d525ccc204f64ad813c4ba77077468.
Pedro J. Estébanez 1 年之前
父节点
当前提交
20298fbf07
共有 2 个文件被更改,包括 2 次插入6 次删除
  1. 2 4
      editor/editor_log.cpp
  2. 0 2
      editor/editor_log.h

+ 2 - 4
editor/editor_log.cpp

@@ -58,8 +58,8 @@ void EditorLog::_error_handler(void *p_self, const char *p_func, const char *p_f
 
 	MessageType message_type = p_type == ERR_HANDLER_WARNING ? MSG_TYPE_WARNING : MSG_TYPE_ERROR;
 
-	if (self->current != Thread::get_caller_id()) {
-		callable_mp(self, &EditorLog::add_message).call_deferred(err_str, message_type);
+	if (!Thread::is_main_thread()) {
+		MessageQueue::get_main_singleton()->push_callable(callable_mp(self, &EditorLog::add_message), err_str, message_type);
 	} else {
 		self->add_message(err_str, message_type);
 	}
@@ -557,8 +557,6 @@ EditorLog::EditorLog() {
 	eh.errfunc = _error_handler;
 	eh.userdata = this;
 	add_error_handler(&eh);
-
-	current = Thread::get_caller_id();
 }
 
 void EditorLog::deinit() {

+ 0 - 2
editor/editor_log.h

@@ -156,8 +156,6 @@ private:
 
 	ErrorHandlerList eh;
 
-	Thread::ID current;
-
 	//void _dragged(const Point2& p_ofs);
 	void _meta_clicked(const String &p_meta);
 	void _clear_request();