diff --git a/editor/editor_log.cpp b/editor/editor_log.cpp index b37debbd70ec..0fd9d6460259 100644 --- a/editor/editor_log.cpp +++ b/editor/editor_log.cpp @@ -346,6 +346,15 @@ void EditorLog::_add_log_line(LogMessage &p_message, bool p_replace_previous) { } log->add_newline(); + + if (p_replace_previous) { + // Force sync last line update (skip if number of unprocessed log messages is too large to avoid editor lag). + if (log->get_pending_paragraphs() < 100) { + while (!log->is_ready()) { + ::OS::get_singleton()->delay_usec(1); + } + } + } } void EditorLog::_set_filter_active(bool p_active, MessageType p_message_type) { diff --git a/scene/gui/rich_text_label.cpp b/scene/gui/rich_text_label.cpp index 0819e9305e76..65bf47598ea1 100644 --- a/scene/gui/rich_text_label.cpp +++ b/scene/gui/rich_text_label.cpp @@ -2741,7 +2741,16 @@ void RichTextLabel::_stop_thread() { } } +int RichTextLabel::get_pending_paragraphs() const { + int to_line = main->first_invalid_line.load(); + int lines = main->lines.size(); + + return lines - to_line; +} + bool RichTextLabel::is_ready() const { + const_cast(this)->_validate_line_caches(); + if (updating.load()) { return false; } @@ -3177,7 +3186,8 @@ bool RichTextLabel::remove_paragraph(const int p_paragraph) { main->lines[0].from = main; } - main->first_invalid_line.store(0); + int to_line = main->first_invalid_line.load(); + main->first_invalid_line.store(MIN(to_line, p_paragraph)); queue_redraw(); return true; diff --git a/scene/gui/rich_text_label.h b/scene/gui/rich_text_label.h index b502e71a4fc8..cbdad3e4d718 100644 --- a/scene/gui/rich_text_label.h +++ b/scene/gui/rich_text_label.h @@ -684,6 +684,7 @@ class RichTextLabel : public Control { bool is_deselect_on_focus_loss_enabled() const; void deselect(); + int get_pending_paragraphs() const; bool is_ready() const; bool is_updating() const;