mirror of https://github.com/Hilbis/Hilbish
fix(greenhouse): reset at end and beginning of line to fix colors leaking to other lines
parent
bbd5637e9b
commit
ff6e08902f
|
@ -28,6 +28,9 @@ hilbish.run('wc -l', {
|
||||||
})
|
})
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
- Fix ansi attributes causing issues with text when cut off in greenhouse
|
||||||
|
|
||||||
## [2.2.3] - 2024-04-27
|
## [2.2.3] - 2024-04-27
|
||||||
### Fixed
|
### Fixed
|
||||||
- Highligher and hinter work now, since it was regressed from the previous minor release.
|
- Highligher and hinter work now, since it was regressed from the previous minor release.
|
||||||
|
|
|
@ -17,8 +17,8 @@ function M.renderCodeBlock(text)
|
||||||
end
|
end
|
||||||
|
|
||||||
for i, line in ipairs(lines) do
|
for i, line in ipairs(lines) do
|
||||||
lines[i] = ' ' .. M.highlight(line:sub(0, longest))
|
lines[i] = lunacolors.format('{greyBg}' .. ' ' .. M.highlight(line:sub(0, longest))
|
||||||
.. string.rep(' ', longest - line:len()) .. ' '
|
.. string.rep(' ', longest - line:len()) .. ' ')
|
||||||
end
|
end
|
||||||
|
|
||||||
return '\n' .. lunacolors.format('{greyBg}' .. table.concat(lines, '\n')) .. '\n'
|
return '\n' .. lunacolors.format('{greyBg}' .. table.concat(lines, '\n')) .. '\n'
|
||||||
|
|
|
@ -61,17 +61,24 @@ function Greenhouse:updateCurrentPage(text)
|
||||||
page:setText(text)
|
page:setText(text)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local ansiPatters = {
|
||||||
|
'\x1b%[%d+;%d+;%d+;%d+;%d+%w',
|
||||||
|
'\x1b%[%d+;%d+;%d+;%d+%w',
|
||||||
|
'\x1b%[%d+;%d+;%d+%w',
|
||||||
|
'\x1b%[%d+;%d+%w',
|
||||||
|
'\x1b%[%d+%w'
|
||||||
|
}
|
||||||
|
|
||||||
function Greenhouse:sub(str, offset, limit)
|
function Greenhouse:sub(str, offset, limit)
|
||||||
local overhead = 0
|
local overhead = 0
|
||||||
local function addOverhead(s)
|
local function addOverhead(s)
|
||||||
overhead = overhead + string.len(s)
|
overhead = overhead + string.len(s)
|
||||||
end
|
end
|
||||||
|
|
||||||
local s = str:gsub('\x1b%[%d+;%d+;%d+;%d+;%d+%w', addOverhead)
|
local s = str
|
||||||
:gsub('\x1b%[%d+;%d+;%d+;%d+%w', addOverhead)
|
for _, pat in ipairs(ansiPatters) do
|
||||||
:gsub('\x1b%[%d+;%d+;%d+%w',addOverhead)
|
s = s:gsub(pat, addOverhead)
|
||||||
:gsub('\x1b%[%d+;%d+%w', addOverhead)
|
end
|
||||||
:gsub('\x1b%[%d+%w', addOverhead)
|
|
||||||
|
|
||||||
return s:sub(offset, utf8.offset(str, limit + overhead) or limit + overhead)
|
return s:sub(offset, utf8.offset(str, limit + overhead) or limit + overhead)
|
||||||
--return s:sub(offset, limit + overhead)
|
--return s:sub(offset, limit + overhead)
|
||||||
|
@ -94,14 +101,40 @@ function Greenhouse:draw()
|
||||||
self.sink:write(ansikit.getCSI(2, 'J'))
|
self.sink:write(ansikit.getCSI(2, 'J'))
|
||||||
|
|
||||||
local writer = self.sink.writeln
|
local writer = self.sink.writeln
|
||||||
|
self.attributes = {}
|
||||||
for i = offset, offset + self.region.height - 1 do
|
for i = offset, offset + self.region.height - 1 do
|
||||||
|
local resetEnd = false
|
||||||
if i > #lines then break end
|
if i > #lines then break end
|
||||||
|
|
||||||
if i == offset + self.region.height - 1 then writer = self.sink.write end
|
if i == offset + self.region.height - 1 then writer = self.sink.write end
|
||||||
|
|
||||||
self.sink:write(ansikit.getCSI(self.start + i - offset .. ';1', 'H'))
|
self.sink:write(ansikit.getCSI(self.start + i - offset .. ';1', 'H'))
|
||||||
local line = lines[i]:gsub('{separator}', function() return self.separator:rep(self.region.width - 1) end)
|
local line = lines[i]:gsub('{separator}', function() return self.separator:rep(self.region.width - 1) end)
|
||||||
writer(self.sink, self:sub(line:gsub('\t', ' '), self.horizOffset, self.region.width))
|
for _, pat in ipairs(ansiPatters) do
|
||||||
|
line:gsub(pat, function(s)
|
||||||
|
if s == lunacolors.formatColors.reset then
|
||||||
|
self.attributes = {}
|
||||||
|
resetEnd = true
|
||||||
|
else
|
||||||
|
--resetEnd = false
|
||||||
|
--table.insert(self.attributes, s)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
--[[
|
||||||
|
if #self.attributes ~= 0 then
|
||||||
|
for _, attr in ipairs(self.attributes) do
|
||||||
|
--writer(self.sink, attr)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
]]--
|
||||||
|
|
||||||
|
self.sink:write(lunacolors.formatColors.reset)
|
||||||
|
writer(self.sink, self:sub(line:gsub('\t', ' '), self.horizOffset, self.region.width + self.horizOffset))
|
||||||
|
if resetEnd then
|
||||||
|
self.sink:write(lunacolors.formatColors.reset)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
writer(self.sink, '\27[0m')
|
writer(self.sink, '\27[0m')
|
||||||
self:render()
|
self:render()
|
||||||
|
|
Loading…
Reference in New Issue