From 4a74bd78fd7791f881329a69d1117eab88d852a9 Mon Sep 17 00:00:00 2001 From: paxcut <53811119+paxcut@users.noreply.github.com> Date: Wed, 18 Dec 2024 12:19:18 -0700 Subject: [PATCH] fix: Console either printed no newlines or printed extra ones. (#2016) The reason for the error were the text preprocessor added to deal with tabs was created to process entire files, not just lines or words. In that context it cleaned trailing new lines if any existed but in the new role that's not only unwanted but erroneous. ### Problem description After that was fixed the console started to add two empty lines between each output line. When splitting a string using new lines you need to not add a new line to the last line created. Even if the text ends in an end line, the split screen code is set to not discard empty lines. ### Implementation description The fixes are straightforward. --- .../imgui/ColorTextEditor/source/TextEditor.cpp | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/lib/third_party/imgui/ColorTextEditor/source/TextEditor.cpp b/lib/third_party/imgui/ColorTextEditor/source/TextEditor.cpp index c15dcae66..14a98b6db 100644 --- a/lib/third_party/imgui/ColorTextEditor/source/TextEditor.cpp +++ b/lib/third_party/imgui/ColorTextEditor/source/TextEditor.cpp @@ -2066,12 +2066,14 @@ std::vector TextEditor::SplitString(const std::string &string, cons std::string TextEditor::ReplaceTabsWithSpaces(const std::string& string, uint32_t tabSize) { - if (tabSize == 0) + if (tabSize == 0 || string.empty() || string.find('\t') == std::string::npos) return string; auto stringVector = SplitString(string, "\n", false); + auto size = stringVector.size(); std::string result; - for (auto &line : stringVector) { + for (size_t i = 0; i < size - 1; i++) { + auto &line = stringVector[i]; std::size_t pos = 0; while ((pos = line.find('\t', pos)) != std::string::npos) { auto spaces = tabSize - (pos % tabSize); @@ -2088,8 +2090,7 @@ std::string TextEditor::PreprocessText(const std::string &code) { std::string result = ReplaceStrings(code, "\r\n", "\n"); result = ReplaceStrings(result, "\r", "\n"); result = ReplaceTabsWithSpaces(result, 4); - while (result.ends_with('\n')) - result.pop_back(); + return result; }