mirror of
https://github.com/neovim/neovim.git
synced 2025-09-06 03:18:16 +00:00
Merge #30105 fix(tohtml): quote font-family names
This commit is contained in:
@@ -1293,9 +1293,25 @@ local function opt_to_global_state(opt, title)
|
|||||||
local fonts = {}
|
local fonts = {}
|
||||||
if opt.font then
|
if opt.font then
|
||||||
fonts = type(opt.font) == 'string' and { opt.font } or opt.font --[[@as (string[])]]
|
fonts = type(opt.font) == 'string' and { opt.font } or opt.font --[[@as (string[])]]
|
||||||
|
for i, v in pairs(fonts) do
|
||||||
|
fonts[i] = ('"%s"'):format(v)
|
||||||
|
end
|
||||||
elseif vim.o.guifont:match('^[^:]+') then
|
elseif vim.o.guifont:match('^[^:]+') then
|
||||||
table.insert(fonts, vim.o.guifont:match('^[^:]+'))
|
-- Example:
|
||||||
|
-- Input: "Font,Escape\,comma, Ignore space after comma"
|
||||||
|
-- Output: { "Font","Escape,comma","Ignore space after comma" }
|
||||||
|
local prev = ''
|
||||||
|
for name in vim.gsplit(vim.o.guifont:match('^[^:]+'), ',', { trimempty = true }) do
|
||||||
|
if vim.endswith(name, '\\') then
|
||||||
|
prev = prev .. vim.trim(name:sub(1, -2) .. ',')
|
||||||
|
elseif vim.trim(name) ~= '' then
|
||||||
|
table.insert(fonts, ('"%s%s"'):format(prev, vim.trim(name)))
|
||||||
|
prev = ''
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
-- Generic family names (monospace here) must not be quoted
|
||||||
|
-- because the browser recognizes them as font families.
|
||||||
table.insert(fonts, 'monospace')
|
table.insert(fonts, 'monospace')
|
||||||
--- @type vim.tohtml.state.global
|
--- @type vim.tohtml.state.global
|
||||||
local state = {
|
local state = {
|
||||||
|
@@ -136,6 +136,50 @@ local function run_tohtml_and_assert(screen, func)
|
|||||||
screen:expect({ grid = expected.grid, attr_ids = expected.attr_ids })
|
screen:expect({ grid = expected.grid, attr_ids = expected.attr_ids })
|
||||||
end
|
end
|
||||||
|
|
||||||
|
---@param guifont boolean
|
||||||
|
local function test_generates_html(guifont, expect_font)
|
||||||
|
insert([[line]])
|
||||||
|
exec('set termguicolors')
|
||||||
|
local bg = fn.synIDattr(fn.hlID('Normal'), 'bg#', 'gui')
|
||||||
|
local fg = fn.synIDattr(fn.hlID('Normal'), 'fg#', 'gui')
|
||||||
|
local tmpfile = t.tmpname()
|
||||||
|
|
||||||
|
exec_lua(
|
||||||
|
[[
|
||||||
|
local guifont, outfile = ...
|
||||||
|
local html = (guifont
|
||||||
|
and require('tohtml').tohtml(0,{title="title"})
|
||||||
|
or require('tohtml').tohtml(0,{title="title",font={ "dumyfont","anotherfont" }}))
|
||||||
|
vim.fn.writefile(html, outfile)
|
||||||
|
vim.cmd.split(outfile)
|
||||||
|
]],
|
||||||
|
guifont,
|
||||||
|
tmpfile
|
||||||
|
)
|
||||||
|
|
||||||
|
local out_file = api.nvim_buf_get_name(api.nvim_get_current_buf())
|
||||||
|
eq({
|
||||||
|
'<!DOCTYPE html>',
|
||||||
|
'<html>',
|
||||||
|
'<head>',
|
||||||
|
'<meta charset="UTF-8">',
|
||||||
|
'<title>title</title>',
|
||||||
|
('<meta name="colorscheme" content="%s"></meta>'):format(api.nvim_get_var('colors_name')),
|
||||||
|
'<style>',
|
||||||
|
('* {font-family: %s,monospace}'):format(expect_font),
|
||||||
|
('body {background-color: %s; color: %s}'):format(bg, fg),
|
||||||
|
'</style>',
|
||||||
|
'</head>',
|
||||||
|
'<body style="display: flex">',
|
||||||
|
'<pre>',
|
||||||
|
'line',
|
||||||
|
'',
|
||||||
|
'</pre>',
|
||||||
|
'</body>',
|
||||||
|
'</html>',
|
||||||
|
}, fn.readfile(out_file))
|
||||||
|
end
|
||||||
|
|
||||||
describe(':TOhtml', function()
|
describe(':TOhtml', function()
|
||||||
--- @type test.functional.ui.screen
|
--- @type test.functional.ui.screen
|
||||||
local screen
|
local screen
|
||||||
@@ -146,41 +190,16 @@ describe(':TOhtml', function()
|
|||||||
exec('colorscheme default')
|
exec('colorscheme default')
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('expected internal html generated', function()
|
it('generates html with given font', function()
|
||||||
insert([[line]])
|
test_generates_html(false, '"dumyfont","anotherfont"')
|
||||||
exec('set termguicolors')
|
|
||||||
local bg = fn.synIDattr(fn.hlID('Normal'), 'bg#', 'gui')
|
|
||||||
local fg = fn.synIDattr(fn.hlID('Normal'), 'fg#', 'gui')
|
|
||||||
exec_lua [[
|
|
||||||
local outfile = vim.fn.tempname() .. '.html'
|
|
||||||
local html = require('tohtml').tohtml(0,{title="title",font="dumyfont"})
|
|
||||||
vim.fn.writefile(html, outfile)
|
|
||||||
vim.cmd.split(outfile)
|
|
||||||
]]
|
|
||||||
local out_file = api.nvim_buf_get_name(api.nvim_get_current_buf())
|
|
||||||
eq({
|
|
||||||
'<!DOCTYPE html>',
|
|
||||||
'<html>',
|
|
||||||
'<head>',
|
|
||||||
'<meta charset="UTF-8">',
|
|
||||||
'<title>title</title>',
|
|
||||||
('<meta name="colorscheme" content="%s"></meta>'):format(api.nvim_get_var('colors_name')),
|
|
||||||
'<style>',
|
|
||||||
'* {font-family: dumyfont,monospace}',
|
|
||||||
('body {background-color: %s; color: %s}'):format(bg, fg),
|
|
||||||
'</style>',
|
|
||||||
'</head>',
|
|
||||||
'<body style="display: flex">',
|
|
||||||
'<pre>',
|
|
||||||
'line',
|
|
||||||
'',
|
|
||||||
'</pre>',
|
|
||||||
'</body>',
|
|
||||||
'</html>',
|
|
||||||
}, fn.readfile(out_file))
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('expected internal html generated from range', function()
|
it("generates html, respects 'guifont'", function()
|
||||||
|
exec_lua [[vim.o.guifont='Font,Escape\\,comma, Ignore space after comma']]
|
||||||
|
test_generates_html(true, '"Font","Escape,comma","Ignore space after comma"')
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('generates html from range', function()
|
||||||
insert([[
|
insert([[
|
||||||
line1
|
line1
|
||||||
line2
|
line2
|
||||||
@@ -218,7 +237,7 @@ describe(':TOhtml', function()
|
|||||||
}, fn.readfile(out_file))
|
}, fn.readfile(out_file))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('highlight attributes generated', function()
|
it('generates highlight attributes', function()
|
||||||
--Make sure to uncomment the attribute in `html_syntax_match()`
|
--Make sure to uncomment the attribute in `html_syntax_match()`
|
||||||
exec('hi LINE guisp=#00ff00 gui=' .. table.concat({
|
exec('hi LINE guisp=#00ff00 gui=' .. table.concat({
|
||||||
'bold',
|
'bold',
|
||||||
|
Reference in New Issue
Block a user