Prefix messages with their thread id if they aren't coming from the main thread in the editor log.

This commit is contained in:
Relintai 2023-09-06 14:19:28 +02:00
parent deb5c49700
commit e7fe643ce5
5 changed files with 34 additions and 42 deletions

View File

@ -96,22 +96,17 @@ void EditorLog::_error_handler(void *p_self, const char *p_func, const char *p_f
EditorLog *self = (EditorLog *)p_self; EditorLog *self = (EditorLog *)p_self;
String err_str; String err_str;
if (p_errorexp && p_errorexp[0]) { if (p_errorexp && p_errorexp[0]) {
err_str = String::utf8(p_errorexp); err_str = String::utf8(p_errorexp);
} else { } else {
err_str = String::utf8(p_file) + ":" + itos(p_line) + " - " + String::utf8(p_error); err_str = String::utf8(p_file) + ":" + itos(p_line) + " - " + String::utf8(p_error);
} }
if (p_type == ERR_HANDLER_WARNING) {
self->add_message(err_str, MSG_TYPE_WARNING);
} else {
self->add_message(err_str, MSG_TYPE_ERROR);
}
MessageType message_type = p_type == ERR_HANDLER_WARNING ? MSG_TYPE_WARNING : MSG_TYPE_ERROR; MessageType message_type = p_type == ERR_HANDLER_WARNING ? MSG_TYPE_WARNING : MSG_TYPE_ERROR;
if (self->current != Thread::get_caller_id()) { if (self->current != Thread::get_caller_id()) {
self->call_deferred("add_message", err_str, message_type); self->call_deferred("add_thread_message", Thread::get_caller_id(), err_str, message_type);
} else { } else {
self->add_message(err_str, message_type); self->add_message(err_str, message_type);
} }
@ -260,39 +255,6 @@ void EditorLog::_process_message(const String &p_msg, MessageType p_type, bool p
} }
void EditorLog::add_message(const String &p_msg, MessageType p_type) { void EditorLog::add_message(const String &p_msg, MessageType p_type) {
/* TODO
bool restore = p_type != MSG_TYPE_STD;
switch (p_type) {
case MSG_TYPE_STD: {
} break;
case MSG_TYPE_ERROR: {
log->push_color(get_theme_color("error_color", "Editor"));
Ref<Texture> icon = get_theme_icon("Error", "EditorIcons");
log->add_image(icon);
log->add_text(" ");
tool_button->set_icon(icon);
} break;
case MSG_TYPE_WARNING: {
log->push_color(get_theme_color("warning_color", "Editor"));
Ref<Texture> icon = get_theme_icon("Warning", "EditorIcons");
log->add_image(icon);
log->add_text(" ");
tool_button->set_icon(icon);
} break;
case MSG_TYPE_EDITOR: {
// Distinguish editor messages from messages printed by the project
log->push_color(get_theme_color("font_color", "Editor") * Color(1, 1, 1, 0.6));
} break;
}
log->add_text(p_msg);
log->add_newline();
if (restore) {
log->pop();
}
*/
// Make text split by new lines their own message. // Make text split by new lines their own message.
// See #41321 for reasoning. At time of writing, multiple print()'s in running projects // See #41321 for reasoning. At time of writing, multiple print()'s in running projects
// get grouped together and sent to the editor log as one message. This can mess with the // get grouped together and sent to the editor log as one message. This can mess with the
@ -306,6 +268,22 @@ void EditorLog::add_message(const String &p_msg, MessageType p_type) {
} }
} }
void EditorLog::add_thread_message(Thread::ID thread_id, const String &p_msg, MessageType p_type) {
// Make text split by new lines their own message.
// See #41321 for reasoning. At time of writing, multiple print()'s in running projects
// get grouped together and sent to the editor log as one message. This can mess with the
// search functionality (see the comments on the PR above for more details). This behavior
// also matches that of other IDE's.
Vector<String> lines = p_msg.split("\n", true);
int line_count = lines.size();
String thread_str = "(T: " + String::num(thread_id) + ") ";
for (int i = 0; i < line_count; i++) {
_process_message(thread_str + lines[i], p_type, i == line_count - 1);
}
}
void EditorLog::set_tool_button(ToolButton *p_tool_button) { void EditorLog::set_tool_button(ToolButton *p_tool_button) {
tool_button = p_tool_button; tool_button = p_tool_button;
} }
@ -412,6 +390,9 @@ void EditorLog::_reset_message_counts() {
} }
void EditorLog::_bind_methods() { void EditorLog::_bind_methods() {
ClassDB::bind_method(D_METHOD("add_message"), &EditorLog::add_message);
ClassDB::bind_method(D_METHOD("add_thread_message"), &EditorLog::add_thread_message);
ClassDB::bind_method(D_METHOD("_clear_request"), &EditorLog::_clear_request); ClassDB::bind_method(D_METHOD("_clear_request"), &EditorLog::_clear_request);
ClassDB::bind_method(D_METHOD("_copy_request"), &EditorLog::_copy_request); ClassDB::bind_method(D_METHOD("_copy_request"), &EditorLog::_copy_request);

View File

@ -153,6 +153,8 @@ protected:
public: public:
void add_message(const String &p_msg, MessageType p_type = MSG_TYPE_STD); void add_message(const String &p_msg, MessageType p_type = MSG_TYPE_STD);
//not thread safe!
void add_thread_message(Thread::ID thread_id, const String &p_msg, MessageType p_type = MSG_TYPE_STD);
void set_tool_button(ToolButton *p_tool_button); void set_tool_button(ToolButton *p_tool_button);
void deinit(); void deinit();

View File

@ -961,10 +961,11 @@ void EditorScriptEditorDebugger::_parse_message(const String &p_msg, uint64_t p_
//OUT //OUT
for (int i = 0; i < p_data.size(); i++) { for (int i = 0; i < p_data.size(); i++) {
Array output = p_data[i]; Array output = p_data[i];
ERR_FAIL_COND_MSG(output.size() < 2, "Malformed output message from script debugger."); ERR_FAIL_COND_MSG(output.size() < 3, "Malformed output message from script debugger.");
String str = output[0]; String str = output[0];
ScriptDebuggerRemote::MessageType type = (ScriptDebuggerRemote::MessageType)(int)(output[1]); ScriptDebuggerRemote::MessageType type = (ScriptDebuggerRemote::MessageType)(int)(output[1]);
Thread::ID logger_thread_id = (Thread::ID)(output[2]);
EditorLog::MessageType msg_type; EditorLog::MessageType msg_type;
switch (type) { switch (type) {
@ -990,7 +991,11 @@ void EditorScriptEditorDebugger::_parse_message(const String &p_msg, uint64_t p_
} }
} }
if (process_main_thread_id == 0 || process_main_thread_id == logger_thread_id) {
EditorNode::get_log()->add_message(str, msg_type); EditorNode::get_log()->add_message(str, msg_type);
} else {
EditorNode::get_log()->add_thread_message(logger_thread_id, str, msg_type);
}
} }
} else if (p_msg == "performance") { } else if (p_msg == "performance") {
Array arr = p_data[0]; Array arr = p_data[0];

View File

@ -496,6 +496,7 @@ void ScriptDebuggerRemote::_get_output() {
Array msg_data; Array msg_data;
msg_data.push_back(output_string.message); msg_data.push_back(output_string.message);
msg_data.push_back(output_string.type); msg_data.push_back(output_string.type);
msg_data.push_back(output_string.thread);
packet_peer_stream->put_var(msg_data); packet_peer_stream->put_var(msg_data);
@ -1250,11 +1251,13 @@ void ScriptDebuggerRemote::_print_handler(void *p_this, const String &p_string,
OutputString output_string; OutputString output_string;
output_string.message = s; output_string.message = s;
output_string.type = p_error ? MESSAGE_TYPE_ERROR : MESSAGE_TYPE_LOG; output_string.type = p_error ? MESSAGE_TYPE_ERROR : MESSAGE_TYPE_LOG;
output_string.thread = Thread::get_caller_id();
sdr->output_strings.push_back(output_string); sdr->output_strings.push_back(output_string);
if (overflowed) { if (overflowed) {
output_string.message = "[output overflow, print less text!]"; output_string.message = "[output overflow, print less text!]";
output_string.type = MESSAGE_TYPE_ERROR; output_string.type = MESSAGE_TYPE_ERROR;
output_string.thread = Thread::get_caller_id();
sdr->output_strings.push_back(output_string); sdr->output_strings.push_back(output_string);
} }
} }

View File

@ -91,6 +91,7 @@ class ScriptDebuggerRemote : public ScriptDebugger {
struct OutputString { struct OutputString {
String message; String message;
int type; int type;
Thread::ID thread;
}; };
List<OutputString> output_strings; List<OutputString> output_strings;