refactor(config): replace array preset syntax with preset_name = true
Problem: setup() mixed array entries (preset names) and hash entries (custom providers keyed by filetype), requiring verbose vim.tbl_deep_extend boilerplate to override presets. Solution: unify under a single key=value model. Keys are preset names or filetypes; true registers the preset as-is, a table deep-merges with the matching preset (or registers a custom provider if no preset matches), and false is a no-op. Array entries are dropped. Also adds -f gfm to presets.github args so pandoc parses input as GFM.
This commit is contained in:
parent
673573044f
commit
859f04e010
6 changed files with 67 additions and 50 deletions
|
|
@ -139,16 +139,31 @@ describe('presets', function()
|
|||
local args = presets.github.args(md_ctx)
|
||||
assert.is_table(args)
|
||||
assert.are.same({
|
||||
'-f',
|
||||
'gfm',
|
||||
'/tmp/document.md',
|
||||
'-s',
|
||||
'--embed-resources',
|
||||
'--css',
|
||||
'https://cdn.jsdelivr.net/gh/pixelbrackets/gfm-stylesheet@master/github.css',
|
||||
'https://cdn.jsdelivr.net/gh/pixelbrackets/gfm-stylesheet@master/dist/gfm.css',
|
||||
'-o',
|
||||
'/tmp/document.html',
|
||||
}, args)
|
||||
end)
|
||||
|
||||
it('args include -f and gfm flags', function()
|
||||
local args = presets.github.args(md_ctx)
|
||||
local idx = nil
|
||||
for i, v in ipairs(args) do
|
||||
if v == '-f' then
|
||||
idx = i
|
||||
break
|
||||
end
|
||||
end
|
||||
assert.is_not_nil(idx)
|
||||
assert.are.equal('gfm', args[idx + 1])
|
||||
end)
|
||||
|
||||
it('returns html output path', function()
|
||||
local output = presets.github.output(md_ctx)
|
||||
assert.is_string(output)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue