From e86963b9d2c6fe68c14ca1a9bda4fb11620d6043 Mon Sep 17 00:00:00 2001 From: Folke Lemaitre Date: Sat, 27 May 2023 14:06:18 +0200 Subject: [PATCH] fix(text): better (correct) way of dealing with `\r` characters. Fixes #483 --- lua/noice/text/block.lua | 20 +++++++++----------- 1 file changed, 9 insertions(+), 11 deletions(-) diff --git a/lua/noice/text/block.lua b/lua/noice/text/block.lua index ff26ce6..3ca2359 100644 --- a/lua/noice/text/block.lua +++ b/lua/noice/text/block.lua @@ -109,6 +109,15 @@ function Block:_append(content, highlight) if #self._lines == 0 then table.insert(self._lines, NuiLine()) end + if type(content) == "string" then + -- handle carriage returns. They overwrite the line from the first character + local cr = content:match("^.*()[\r^M]") + if cr then + table.remove(self._lines) + table.insert(self._lines, NuiLine()) + content = content:sub(cr + 1) + end + end return self._lines[#self._lines]:append(content, highlight) end @@ -156,7 +165,6 @@ function Block:append(contents, highlight) -- Handle newlines ---@type number|string|table, string local attr_id, text = unpack(content) - text = text:gsub("\r\n", "\n") ---@type string|table|nil local hl_group @@ -170,16 +178,6 @@ function Block:append(contents, highlight) local nl = text:find("\n") if nl then local str = text:sub(1, nl - 1) - - -- handle carriage returns. They overwrite the line from the first character - if str:find("\r") then - local parts = vim.split(str, "\r", { plain = true }) - str = "" - for _, p in ipairs(parts) do - str = p .. str:sub(p:len() + 1) - end - end - self:_append(str, hl_group) self:newline() text = text:sub(nl + 1)