mirror of
https://github.com/neovim/neovim.git
synced 2024-12-29 14:41:06 -07:00
a5fe8f59d9
- Added `@inlinedoc` so single use Lua types can be inlined into the functions docs. E.g. ```lua --- @class myopts --- @inlinedoc --- --- Documentation for some field --- @field somefield integer --- @param opts myOpts function foo(opts) end ``` Will be rendered as ``` foo(opts) Parameters: - {opts} (table) Object with the fields: - somefield (integer) Documentation for some field ``` - Marked many classes with with `@nodoc` or `(private)`. We can eventually introduce these when we want to.
59 lines
1.2 KiB
Lua
59 lines
1.2 KiB
Lua
local helpers = require('test.functional.helpers')(after_each)
|
|
local exec_lua = helpers.exec_lua
|
|
local eq = helpers.eq
|
|
|
|
local function md_to_vimdoc(text, start_indent, indent, text_width)
|
|
return exec_lua(
|
|
[[
|
|
local text, start_indent, indent, text_width = ...
|
|
start_indent = start_indent or 0
|
|
indent = indent or 0
|
|
text_width = text_width or 70
|
|
local text_utils = require('scripts/text_utils')
|
|
return text_utils.md_to_vimdoc(table.concat(text, '\n'), start_indent, indent, text_width)
|
|
]],
|
|
text,
|
|
start_indent,
|
|
indent,
|
|
text_width
|
|
)
|
|
end
|
|
|
|
local function test(what, act, exp, ...)
|
|
local argc, args = select('#', ...), { ... }
|
|
it(what, function()
|
|
eq(table.concat(exp, '\n'), md_to_vimdoc(act, unpack(args, 1, argc)))
|
|
end)
|
|
end
|
|
|
|
describe('md_to_vimdoc', function()
|
|
before_each(function()
|
|
helpers.clear()
|
|
end)
|
|
|
|
test('can render para after fenced code', {
|
|
'- Para1',
|
|
' ```',
|
|
' code',
|
|
' ```',
|
|
' Para2',
|
|
}, {
|
|
'• Para1 >',
|
|
' code',
|
|
'<',
|
|
' Para2',
|
|
'',
|
|
})
|
|
|
|
test('start_indent only applies to first line', {
|
|
'para1',
|
|
'',
|
|
'para2',
|
|
}, {
|
|
'para1',
|
|
'',
|
|
' para2',
|
|
'',
|
|
}, 0, 10, 78)
|
|
end)
|