aboutsummaryrefslogtreecommitdiff
path: root/test/functional/api/highlight_spec.lua
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional/api/highlight_spec.lua')
-rw-r--r--test/functional/api/highlight_spec.lua344
1 files changed, 194 insertions, 150 deletions
diff --git a/test/functional/api/highlight_spec.lua b/test/functional/api/highlight_spec.lua
index c9edbf825d..fe9e2a7727 100644
--- a/test/functional/api/highlight_spec.lua
+++ b/test/functional/api/highlight_spec.lua
@@ -10,7 +10,7 @@ local pcall_err = helpers.pcall_err
local ok = helpers.ok
local assert_alive = helpers.assert_alive
-describe('API: highlight',function()
+describe('API: highlight', function()
clear()
Screen.new() -- initialize Screen.colors
@@ -45,31 +45,35 @@ describe('API: highlight',function()
before_each(function()
clear()
- command("hi NewHighlight cterm=underline ctermbg=green guifg=red guibg=yellow guisp=blue gui=bold")
+ command(
+ 'hi NewHighlight cterm=underline ctermbg=green guifg=red guibg=yellow guisp=blue gui=bold'
+ )
end)
- it("nvim_get_hl_by_id", function()
+ it('nvim_get_hl_by_id', function()
local hl_id = eval("hlID('NewHighlight')")
- eq(expected_cterm, nvim("get_hl_by_id", hl_id, false))
+ eq(expected_cterm, nvim('get_hl_by_id', hl_id, false))
hl_id = eval("hlID('NewHighlight')")
-- Test valid id.
- eq(expected_rgb, nvim("get_hl_by_id", hl_id, true))
+ eq(expected_rgb, nvim('get_hl_by_id', hl_id, true))
-- Test invalid id.
eq('Invalid highlight id: 30000', pcall_err(meths.get_hl_by_id, 30000, false))
-- Test all highlight properties.
command('hi NewHighlight gui=underline,bold,italic,reverse,strikethrough,altfont,nocombine')
- eq(expected_rgb2, nvim("get_hl_by_id", hl_id, true))
+ eq(expected_rgb2, nvim('get_hl_by_id', hl_id, true))
-- Test undercurl
command('hi NewHighlight gui=undercurl')
- eq(expected_undercurl, nvim("get_hl_by_id", hl_id, true))
+ eq(expected_undercurl, nvim('get_hl_by_id', hl_id, true))
-- Test nil argument.
- eq('Wrong type for argument 1 when calling nvim_get_hl_by_id, expecting Integer',
- pcall_err(meths.get_hl_by_id, { nil }, false))
+ eq(
+ 'Wrong type for argument 1 when calling nvim_get_hl_by_id, expecting Integer',
+ pcall_err(meths.get_hl_by_id, { nil }, false)
+ )
-- Test 0 argument.
eq('Invalid highlight id: 0', pcall_err(meths.get_hl_by_id, 0, false))
@@ -81,76 +85,83 @@ describe('API: highlight',function()
command('hi Normal ctermfg=red ctermbg=yellow')
command('hi NewConstant ctermfg=green guifg=white guibg=blue')
hl_id = eval("hlID('NewConstant')")
- eq({foreground = 10,}, meths.get_hl_by_id(hl_id, false))
+ eq({ foreground = 10 }, meths.get_hl_by_id(hl_id, false))
-- Test highlight group without ctermfg value.
command('hi clear NewConstant')
command('hi NewConstant ctermbg=Magenta guifg=white guibg=blue')
- eq({background = 13,}, meths.get_hl_by_id(hl_id, false))
+ eq({ background = 13 }, meths.get_hl_by_id(hl_id, false))
-- Test highlight group with ctermfg and ctermbg values.
command('hi clear NewConstant')
command('hi NewConstant ctermfg=green ctermbg=Magenta guifg=white guibg=blue')
- eq({foreground = 10, background = 13,}, meths.get_hl_by_id(hl_id, false))
+ eq({ foreground = 10, background = 13 }, meths.get_hl_by_id(hl_id, false))
end)
- it("nvim_get_hl_by_name", function()
- local expected_normal = { background = Screen.colors.Yellow,
- foreground = Screen.colors.Red }
+ it('nvim_get_hl_by_name', function()
+ local expected_normal = { background = Screen.colors.Yellow, foreground = Screen.colors.Red }
-- Test `Normal` default values.
- eq({}, nvim("get_hl_by_name", 'Normal', true))
+ eq({}, nvim('get_hl_by_name', 'Normal', true))
- eq(expected_cterm, nvim("get_hl_by_name", 'NewHighlight', false))
- eq(expected_rgb, nvim("get_hl_by_name", 'NewHighlight', true))
+ eq(expected_cterm, nvim('get_hl_by_name', 'NewHighlight', false))
+ eq(expected_rgb, nvim('get_hl_by_name', 'NewHighlight', true))
-- Test `Normal` modified values.
command('hi Normal guifg=red guibg=yellow')
- eq(expected_normal, nvim("get_hl_by_name", 'Normal', true))
+ eq(expected_normal, nvim('get_hl_by_name', 'Normal', true))
-- Test invalid name.
- eq("Invalid highlight name: 'unknown_highlight'",
- pcall_err(meths.get_hl_by_name , 'unknown_highlight', false))
+ eq(
+ "Invalid highlight name: 'unknown_highlight'",
+ pcall_err(meths.get_hl_by_name, 'unknown_highlight', false)
+ )
-- Test nil argument.
- eq('Wrong type for argument 1 when calling nvim_get_hl_by_name, expecting String',
- pcall_err(meths.get_hl_by_name , { nil }, false))
+ eq(
+ 'Wrong type for argument 1 when calling nvim_get_hl_by_name, expecting String',
+ pcall_err(meths.get_hl_by_name, { nil }, false)
+ )
-- Test empty string argument.
- eq('Invalid highlight name',
- pcall_err(meths.get_hl_by_name , '', false))
+ eq('Invalid highlight name', pcall_err(meths.get_hl_by_name, '', false))
-- Test "standout" attribute. #8054
- eq({ underline = true, },
- meths.get_hl_by_name('cursorline', 0));
+ eq({ underline = true }, meths.get_hl_by_name('cursorline', 0))
command('hi CursorLine cterm=standout,underline term=standout,underline gui=standout,underline')
command('set cursorline')
- eq({ underline = true, standout = true, },
- meths.get_hl_by_name('cursorline', 0));
+ eq({ underline = true, standout = true }, meths.get_hl_by_name('cursorline', 0))
-- Test cterm & Normal values. #18024 (tail) & #18980
-- Ensure Normal, and groups that match Normal return their fg & bg cterm values
- meths.set_hl(0, 'Normal', {ctermfg = 17, ctermbg = 213})
- meths.set_hl(0, 'NotNormal', {ctermfg = 17, ctermbg = 213, nocombine = true})
+ meths.set_hl(0, 'Normal', { ctermfg = 17, ctermbg = 213 })
+ meths.set_hl(0, 'NotNormal', { ctermfg = 17, ctermbg = 213, nocombine = true })
-- Note colors are "cterm" values, not rgb-as-ints
- eq({foreground = 17, background = 213}, nvim("get_hl_by_name", 'Normal', false))
- eq({foreground = 17, background = 213, nocombine = true}, nvim("get_hl_by_name", 'NotNormal', false))
+ eq({ foreground = 17, background = 213 }, nvim('get_hl_by_name', 'Normal', false))
+ eq(
+ { foreground = 17, background = 213, nocombine = true },
+ nvim('get_hl_by_name', 'NotNormal', false)
+ )
end)
it('nvim_get_hl_id_by_name', function()
-- precondition: use a hl group that does not yet exist
- eq("Invalid highlight name: 'Shrubbery'", pcall_err(meths.get_hl_by_name, "Shrubbery", true))
- eq(0, funcs.hlID("Shrubbery"))
+ eq("Invalid highlight name: 'Shrubbery'", pcall_err(meths.get_hl_by_name, 'Shrubbery', true))
+ eq(0, funcs.hlID('Shrubbery'))
- local hl_id = meths.get_hl_id_by_name("Shrubbery")
+ local hl_id = meths.get_hl_id_by_name('Shrubbery')
ok(hl_id > 0)
- eq(hl_id, funcs.hlID("Shrubbery"))
+ eq(hl_id, funcs.hlID('Shrubbery'))
command('hi Shrubbery guifg=#888888 guibg=#888888')
- eq({foreground=tonumber("0x888888"), background=tonumber("0x888888")},
- meths.get_hl_by_id(hl_id, true))
- eq({foreground=tonumber("0x888888"), background=tonumber("0x888888")},
- meths.get_hl_by_name("Shrubbery", true))
+ eq(
+ { foreground = tonumber('0x888888'), background = tonumber('0x888888') },
+ meths.get_hl_by_id(hl_id, true)
+ )
+ eq(
+ { foreground = tonumber('0x888888'), background = tonumber('0x888888') },
+ meths.get_hl_by_name('Shrubbery', true)
+ )
end)
it("nvim_buf_add_highlight to other buffer doesn't crash if undo is disabled #12873", function()
@@ -165,7 +176,7 @@ describe('API: highlight',function()
end)
end)
-describe("API: set highlight", function()
+describe('API: set highlight', function()
local highlight_color = {
fg = tonumber('0xff0000'),
bg = tonumber('0x0032aa'),
@@ -207,7 +218,7 @@ describe("API: set highlight", function()
strikethrough = true,
altfont = true,
nocombine = true,
- }
+ },
}
local highlight3_result_gui = {
background = highlight_color.bg,
@@ -238,31 +249,35 @@ describe("API: set highlight", function()
before_each(clear)
it('validation', function()
- eq("Invalid 'blend': out of range",
- pcall_err(meths.set_hl, 0, 'Test_hl3', {fg='#FF00FF', blend=999}))
- eq("Invalid 'blend': expected Integer, got Array",
- pcall_err(meths.set_hl, 0, 'Test_hl3', {fg='#FF00FF', blend={}}))
+ eq(
+ "Invalid 'blend': out of range",
+ pcall_err(meths.set_hl, 0, 'Test_hl3', { fg = '#FF00FF', blend = 999 })
+ )
+ eq(
+ "Invalid 'blend': expected Integer, got Array",
+ pcall_err(meths.set_hl, 0, 'Test_hl3', { fg = '#FF00FF', blend = {} })
+ )
end)
- it("can set gui highlight", function()
+ it('can set gui highlight', function()
local ns = get_ns()
meths.set_hl(ns, 'Test_hl', highlight1)
eq(highlight1, meths.get_hl_by_name('Test_hl', true))
end)
- it("can set cterm highlight", function()
+ it('can set cterm highlight', function()
local ns = get_ns()
meths.set_hl(ns, 'Test_hl', highlight2_config)
eq(highlight2_result, meths.get_hl_by_name('Test_hl', false))
end)
- it("can set empty cterm attr", function()
+ it('can set empty cterm attr', function()
local ns = get_ns()
meths.set_hl(ns, 'Test_hl', { cterm = {} })
eq({}, meths.get_hl_by_name('Test_hl', false))
end)
- it("cterm attr defaults to gui attr", function()
+ it('cterm attr defaults to gui attr', function()
local ns = get_ns()
meths.set_hl(ns, 'Test_hl', highlight1)
eq({
@@ -271,14 +286,14 @@ describe("API: set highlight", function()
}, meths.get_hl_by_name('Test_hl', false))
end)
- it("can overwrite attr for cterm", function()
+ it('can overwrite attr for cterm', function()
local ns = get_ns()
meths.set_hl(ns, 'Test_hl', highlight3_config)
eq(highlight3_result_gui, meths.get_hl_by_name('Test_hl', true))
eq(highlight3_result_cterm, meths.get_hl_by_name('Test_hl', false))
end)
- it("only allows one underline attribute #22371", function()
+ it('only allows one underline attribute #22371', function()
local ns = get_ns()
meths.set_hl(ns, 'Test_hl', {
underdouble = true,
@@ -292,80 +307,76 @@ describe("API: set highlight", function()
eq({ underdotted = true }, meths.get_hl_by_name('Test_hl', true))
end)
- it("can set a highlight in the global namespace", function()
+ it('can set a highlight in the global namespace', function()
meths.set_hl(0, 'Test_hl', highlight2_config)
- eq('Test_hl xxx cterm=underline,reverse ctermfg=8 ctermbg=15 gui=underline,reverse',
- exec_capture('highlight Test_hl'))
+ eq(
+ 'Test_hl xxx cterm=underline,reverse ctermfg=8 ctermbg=15 gui=underline,reverse',
+ exec_capture('highlight Test_hl')
+ )
meths.set_hl(0, 'Test_hl', { background = highlight_color.bg })
- eq('Test_hl xxx guibg=#0032aa',
- exec_capture('highlight Test_hl'))
+ eq('Test_hl xxx guibg=#0032aa', exec_capture('highlight Test_hl'))
meths.set_hl(0, 'Test_hl2', highlight3_config)
- eq('Test_hl2 xxx cterm=italic,reverse,strikethrough,altfont,nocombine ctermfg=8 ctermbg=15 gui=bold,underdashed,italic,reverse,strikethrough,altfont guifg=#ff0000 guibg=#0032aa',
- exec_capture('highlight Test_hl2'))
+ eq(
+ 'Test_hl2 xxx cterm=italic,reverse,strikethrough,altfont,nocombine ctermfg=8 ctermbg=15 gui=bold,underdashed,italic,reverse,strikethrough,altfont guifg=#ff0000 guibg=#0032aa',
+ exec_capture('highlight Test_hl2')
+ )
-- Colors are stored with the name they are defined, but
-- with canonical casing
- meths.set_hl(0, 'Test_hl3', { bg = 'reD', fg = 'bLue'})
- eq('Test_hl3 xxx guifg=Blue guibg=Red',
- exec_capture('highlight Test_hl3'))
+ meths.set_hl(0, 'Test_hl3', { bg = 'reD', fg = 'bLue' })
+ eq('Test_hl3 xxx guifg=Blue guibg=Red', exec_capture('highlight Test_hl3'))
end)
- it("can modify a highlight in the global namespace", function()
- meths.set_hl(0, 'Test_hl3', { bg = 'red', fg = 'blue'})
- eq('Test_hl3 xxx guifg=Blue guibg=Red',
- exec_capture('highlight Test_hl3'))
+ it('can modify a highlight in the global namespace', function()
+ meths.set_hl(0, 'Test_hl3', { bg = 'red', fg = 'blue' })
+ eq('Test_hl3 xxx guifg=Blue guibg=Red', exec_capture('highlight Test_hl3'))
meths.set_hl(0, 'Test_hl3', { bg = 'red' })
- eq('Test_hl3 xxx guibg=Red',
- exec_capture('highlight Test_hl3'))
+ eq('Test_hl3 xxx guibg=Red', exec_capture('highlight Test_hl3'))
- meths.set_hl(0, 'Test_hl3', { ctermbg = 9, ctermfg = 12})
- eq('Test_hl3 xxx ctermfg=12 ctermbg=9',
- exec_capture('highlight Test_hl3'))
+ meths.set_hl(0, 'Test_hl3', { ctermbg = 9, ctermfg = 12 })
+ eq('Test_hl3 xxx ctermfg=12 ctermbg=9', exec_capture('highlight Test_hl3'))
- meths.set_hl(0, 'Test_hl3', { ctermbg = 'red' , ctermfg = 'blue'})
- eq('Test_hl3 xxx ctermfg=12 ctermbg=9',
- exec_capture('highlight Test_hl3'))
+ meths.set_hl(0, 'Test_hl3', { ctermbg = 'red', ctermfg = 'blue' })
+ eq('Test_hl3 xxx ctermfg=12 ctermbg=9', exec_capture('highlight Test_hl3'))
meths.set_hl(0, 'Test_hl3', { ctermbg = 9 })
- eq('Test_hl3 xxx ctermbg=9',
- exec_capture('highlight Test_hl3'))
+ eq('Test_hl3 xxx ctermbg=9', exec_capture('highlight Test_hl3'))
- eq("Invalid highlight color: 'redd'",
- pcall_err(meths.set_hl, 0, 'Test_hl3', {fg='redd'}))
+ eq("Invalid highlight color: 'redd'", pcall_err(meths.set_hl, 0, 'Test_hl3', { fg = 'redd' }))
- eq("Invalid highlight color: 'bleu'",
- pcall_err(meths.set_hl, 0, 'Test_hl3', {ctermfg='bleu'}))
+ eq(
+ "Invalid highlight color: 'bleu'",
+ pcall_err(meths.set_hl, 0, 'Test_hl3', { ctermfg = 'bleu' })
+ )
- meths.set_hl(0, 'Test_hl3', {fg='#FF00FF'})
- eq('Test_hl3 xxx guifg=#ff00ff',
- exec_capture('highlight Test_hl3'))
+ meths.set_hl(0, 'Test_hl3', { fg = '#FF00FF' })
+ eq('Test_hl3 xxx guifg=#ff00ff', exec_capture('highlight Test_hl3'))
- eq("Invalid highlight color: '#FF00FF'",
- pcall_err(meths.set_hl, 0, 'Test_hl3', {ctermfg='#FF00FF'}))
+ eq(
+ "Invalid highlight color: '#FF00FF'",
+ pcall_err(meths.set_hl, 0, 'Test_hl3', { ctermfg = '#FF00FF' })
+ )
- for _, fg_val in ipairs{ nil, 'NONE', 'nOnE', '', -1 } do
- meths.set_hl(0, 'Test_hl3', {fg = fg_val})
- eq('Test_hl3 xxx cleared',
- exec_capture('highlight Test_hl3'))
+ for _, fg_val in ipairs { nil, 'NONE', 'nOnE', '', -1 } do
+ meths.set_hl(0, 'Test_hl3', { fg = fg_val })
+ eq('Test_hl3 xxx cleared', exec_capture('highlight Test_hl3'))
end
- meths.set_hl(0, 'Test_hl3', {fg='#FF00FF', blend=50})
- eq('Test_hl3 xxx guifg=#ff00ff blend=50',
- exec_capture('highlight Test_hl3'))
-
+ meths.set_hl(0, 'Test_hl3', { fg = '#FF00FF', blend = 50 })
+ eq('Test_hl3 xxx guifg=#ff00ff blend=50', exec_capture('highlight Test_hl3'))
end)
it("correctly sets 'Normal' internal properties", function()
-- Normal has some special handling internally. #18024
- meths.set_hl(0, 'Normal', {fg='#000083', bg='#0000F3'})
- eq({foreground = 131, background = 243}, nvim("get_hl_by_name", 'Normal', true))
+ meths.set_hl(0, 'Normal', { fg = '#000083', bg = '#0000F3' })
+ eq({ foreground = 131, background = 243 }, nvim('get_hl_by_name', 'Normal', true))
end)
it('does not segfault on invalid group name #20009', function()
- eq("Invalid highlight name: 'foo bar'", pcall_err(meths.set_hl, 0, 'foo bar', {bold = true}))
+ eq("Invalid highlight name: 'foo bar'", pcall_err(meths.set_hl, 0, 'foo bar', { bold = true }))
assert_alive()
end)
end)
@@ -380,14 +391,16 @@ describe('API: get highlight', function()
local highlight1 = {
bg = highlight_color.bg,
fg = highlight_color.fg,
- bold = true, italic = true,
- cterm = {bold = true, italic = true},
+ bold = true,
+ italic = true,
+ cterm = { bold = true, italic = true },
}
local highlight2 = {
ctermbg = highlight_color.ctermbg,
ctermfg = highlight_color.ctermfg,
- underline = true, reverse = true,
- cterm = {underline = true, reverse = true},
+ underline = true,
+ reverse = true,
+ cterm = { underline = true, reverse = true },
}
local highlight3_config = {
bg = highlight_color.bg,
@@ -413,8 +426,19 @@ describe('API: get highlight', function()
fg = highlight_color.fg,
ctermbg = highlight_color.ctermbg,
ctermfg = highlight_color.ctermfg,
- bold = true, italic = true, reverse = true, underdashed = true, strikethrough = true, altfont = true,
- cterm = {italic = true, nocombine = true, reverse = true, strikethrough = true, altfont = true}
+ bold = true,
+ italic = true,
+ reverse = true,
+ underdashed = true,
+ strikethrough = true,
+ altfont = true,
+ cterm = {
+ italic = true,
+ nocombine = true,
+ reverse = true,
+ strikethrough = true,
+ altfont = true,
+ },
}
local function get_ns()
@@ -434,17 +458,16 @@ describe('API: get highlight', function()
before_each(clear)
it('validation', function()
- eq("Invalid 'name': expected String, got Integer",
- pcall_err(meths.get_hl, 0, { name = 177 }))
+ eq("Invalid 'name': expected String, got Integer", pcall_err(meths.get_hl, 0, { name = 177 }))
eq('Highlight id out of bounds', pcall_err(meths.get_hl, 0, { name = 'Test set hl' }))
end)
it('nvim_get_hl with create flag', function()
- eq({}, nvim("get_hl", 0, {name = 'Foo', create = false}))
+ eq({}, nvim('get_hl', 0, { name = 'Foo', create = false }))
eq(0, funcs.hlexists('Foo'))
- meths.get_hl(0, {name = 'Bar', create = true})
+ meths.get_hl(0, { name = 'Bar', create = true })
eq(1, funcs.hlexists('Bar'))
- meths.get_hl(0, {name = 'FooBar'})
+ meths.get_hl(0, { name = 'FooBar' })
eq(1, funcs.hlexists('FooBar'))
end)
@@ -454,11 +477,11 @@ describe('API: get highlight', function()
meths.set_hl(ns, 'Test_hl_link', { link = 'Test_hl' })
eq({
Test_hl = {
- bg = 11845374
+ bg = 11845374,
},
Test_hl_link = {
- link = 'Test_hl'
- }
+ link = 'Test_hl',
+ },
}, meths.get_hl(ns, {}))
end)
@@ -502,8 +525,7 @@ describe('API: get highlight', function()
undercurl = true,
},
})
- eq({ underdotted = true, cterm = { undercurl = true} },
- meths.get_hl(ns, { name = 'Test_hl' }))
+ eq({ underdotted = true, cterm = { undercurl = true } }, meths.get_hl(ns, { name = 'Test_hl' }))
end)
it('can get a highlight in the global namespace', function()
@@ -533,8 +555,13 @@ describe('API: get highlight', function()
command(
'hi NewHighlight cterm=underline ctermbg=green guifg=red guibg=yellow guisp=blue gui=bold'
)
- eq({ fg = 16711680, bg = 16776960, sp = 255, bold = true,
- ctermbg = 10, cterm = { underline = true },
+ eq({
+ fg = 16711680,
+ bg = 16776960,
+ sp = 255,
+ bold = true,
+ ctermbg = 10,
+ cterm = { underline = true },
}, meths.get_hl(0, { id = hl_id }))
-- Test 0 argument
@@ -547,16 +574,30 @@ describe('API: get highlight', function()
-- Test all highlight properties.
command('hi NewHighlight gui=underline,bold,italic,reverse,strikethrough,altfont,nocombine')
- eq({ fg = 16711680, bg = 16776960, sp = 255,
- altfont = true, bold = true, italic = true, nocombine = true, reverse = true, strikethrough = true, underline = true,
- ctermbg = 10, cterm = {underline = true},
+ eq({
+ fg = 16711680,
+ bg = 16776960,
+ sp = 255,
+ altfont = true,
+ bold = true,
+ italic = true,
+ nocombine = true,
+ reverse = true,
+ strikethrough = true,
+ underline = true,
+ ctermbg = 10,
+ cterm = { underline = true },
}, meths.get_hl(0, { id = hl_id }))
-- Test undercurl
command('hi NewHighlight gui=undercurl')
- eq({ fg = 16711680, bg = 16776960, sp = 255, undercurl = true,
- ctermbg = 10,
- cterm = {underline = true},
+ eq({
+ fg = 16711680,
+ bg = 16776960,
+ sp = 255,
+ undercurl = true,
+ ctermbg = 10,
+ cterm = { underline = true },
}, meths.get_hl(0, { id = hl_id }))
end)
@@ -573,7 +614,10 @@ describe('API: get highlight', function()
command('hi Bar guifg=red')
command('hi Foo guifg=#00ff00 gui=bold,underline')
command('hi! link Foo Bar')
- eq({ link = 'Bar', fg = tonumber('00ff00', 16), bold = true, underline = true }, meths.get_hl(0, { name = 'Foo', link = true }))
+ eq(
+ { link = 'Bar', fg = tonumber('00ff00', 16), bold = true, underline = true },
+ meths.get_hl(0, { name = 'Foo', link = true })
+ )
end)
it('can set link as well as other attributes', function()
@@ -584,57 +628,57 @@ describe('API: get highlight', function()
end)
it("doesn't contain unset groups", function()
- local id = meths.get_hl_id_by_name "@foobar.hubbabubba"
+ local id = meths.get_hl_id_by_name '@foobar.hubbabubba'
ok(id > 0)
local data = meths.get_hl(0, {})
- eq(nil, data["@foobar.hubbabubba"])
- eq(nil, data["@foobar"])
+ eq(nil, data['@foobar.hubbabubba'])
+ eq(nil, data['@foobar'])
command 'hi @foobar.hubbabubba gui=bold'
data = meths.get_hl(0, {})
- eq({bold = true}, data["@foobar.hubbabubba"])
- eq(nil, data["@foobar"])
+ eq({ bold = true }, data['@foobar.hubbabubba'])
+ eq(nil, data['@foobar'])
-- @foobar.hubbabubba was explicitly cleared and thus shows up
-- but @foobar was never touched, and thus doesn't
command 'hi clear @foobar.hubbabubba'
data = meths.get_hl(0, {})
- eq({}, data["@foobar.hubbabubba"])
- eq(nil, data["@foobar"])
+ eq({}, data['@foobar.hubbabubba'])
+ eq(nil, data['@foobar'])
end)
it('should return default flag', function()
- meths.set_hl(0, 'Tried', { fg = "#00ff00", default = true })
+ meths.set_hl(0, 'Tried', { fg = '#00ff00', default = true })
eq({ fg = tonumber('00ff00', 16), default = true }, meths.get_hl(0, { name = 'Tried' }))
end)
it('should not output empty gui and cterm #23474', function()
- meths.set_hl(0, 'Foo', {default = true})
+ meths.set_hl(0, 'Foo', { default = true })
meths.set_hl(0, 'Bar', { default = true, fg = '#ffffff' })
- meths.set_hl(0, 'FooBar', { default = true, fg = '#ffffff', cterm = {bold = true} })
- meths.set_hl(0, 'FooBarA', { default = true, fg = '#ffffff', cterm = {bold = true,italic = true}})
+ meths.set_hl(0, 'FooBar', { default = true, fg = '#ffffff', cterm = { bold = true } })
+ meths.set_hl(
+ 0,
+ 'FooBarA',
+ { default = true, fg = '#ffffff', cterm = { bold = true, italic = true } }
+ )
- eq('Foo xxx cleared',
- exec_capture('highlight Foo'))
- eq({default = true}, meths.get_hl(0, {name = 'Foo'}))
- eq('Bar xxx guifg=#ffffff',
- exec_capture('highlight Bar'))
- eq('FooBar xxx cterm=bold guifg=#ffffff',
- exec_capture('highlight FooBar'))
- eq('FooBarA xxx cterm=bold,italic guifg=#ffffff',
- exec_capture('highlight FooBarA'))
+ eq('Foo xxx cleared', exec_capture('highlight Foo'))
+ eq({ default = true }, meths.get_hl(0, { name = 'Foo' }))
+ eq('Bar xxx guifg=#ffffff', exec_capture('highlight Bar'))
+ eq('FooBar xxx cterm=bold guifg=#ffffff', exec_capture('highlight FooBar'))
+ eq('FooBarA xxx cterm=bold,italic guifg=#ffffff', exec_capture('highlight FooBarA'))
end)
it('can override exist highlight group by force #20323', function()
local white = tonumber('ffffff', 16)
local green = tonumber('00ff00', 16)
- meths.set_hl(0, 'Foo', { fg=white })
- meths.set_hl(0, 'Foo', { fg=green, force = true })
- eq({ fg = green },meths.get_hl(0, {name = 'Foo'}))
- meths.set_hl(0, 'Bar', {link = 'Comment', default = true})
- meths.set_hl(0, 'Bar', {link = 'Foo',default = true, force = true})
- eq({link ='Foo', default = true}, meths.get_hl(0, {name = 'Bar'}))
+ meths.set_hl(0, 'Foo', { fg = white })
+ meths.set_hl(0, 'Foo', { fg = green, force = true })
+ eq({ fg = green }, meths.get_hl(0, { name = 'Foo' }))
+ meths.set_hl(0, 'Bar', { link = 'Comment', default = true })
+ meths.set_hl(0, 'Bar', { link = 'Foo', default = true, force = true })
+ eq({ link = 'Foo', default = true }, meths.get_hl(0, { name = 'Bar' }))
end)
end)
@@ -647,9 +691,9 @@ describe('API: set/get highlight namespace', function()
end)
it('set/get window highlight namespace', function()
- eq(-1, meths.get_hl_ns({winid = 0}))
+ eq(-1, meths.get_hl_ns({ winid = 0 }))
local ns = meths.create_namespace('')
meths.win_set_hl_ns(0, ns)
- eq(ns, meths.get_hl_ns({winid = 0}))
+ eq(ns, meths.get_hl_ns({ winid = 0 }))
end)
end)