fix(diagnostic): make docs agree with code (#29561)

Problem: the code and docs for vim.diagnostic.JumpOpts.float send mixed
signals about what the default should be. When the option is first set,
in the global_diagnostic_options table, the comment clearly says that
the default is false. Later in the code, in goto_diagnostic, there's
a line that sets the default to true if no default is present. Finally,
the docs say that the default is true.

Solution: Change the docs to reflect the new default of false and fix
the goto_diagnostic function.
This commit is contained in:
Peter Aronoff 2024-07-04 13:15:35 -04:00 committed by GitHub
parent 7e099cf3eb
commit 4b3be56a03
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 4 additions and 5 deletions

View File

@ -401,7 +401,7 @@ Lua module: vim.diagnostic *diagnostic-api*
file or not. Similar to 'wrapscan'. file or not. Similar to 'wrapscan'.
• {severity}? (`vim.diagnostic.SeverityFilter`) See • {severity}? (`vim.diagnostic.SeverityFilter`) See
|diagnostic-severity|. |diagnostic-severity|.
• {float}? (`boolean|vim.diagnostic.Opts.Float`, default: `true`) • {float}? (`boolean|vim.diagnostic.Opts.Float`, default: `false`)
If `true`, call |vim.diagnostic.open_float()| after If `true`, call |vim.diagnostic.open_float()| after
moving. If a table, pass the table as the {opts} moving. If a table, pass the table as the {opts}
parameter to |vim.diagnostic.open_float()|. Unless parameter to |vim.diagnostic.open_float()|. Unless

View File

@ -972,9 +972,8 @@ local function goto_diagnostic(diagnostic, opts)
vim.cmd('normal! zv') vim.cmd('normal! zv')
end) end)
local float = if_nil(opts.float, true) if opts.float then
if float then local float_opts = type(opts.float) == 'table' and opts.float or {}
local float_opts = type(float) == 'table' and float or {}
vim.schedule(function() vim.schedule(function()
M.open_float(vim.tbl_extend('keep', float_opts, { M.open_float(vim.tbl_extend('keep', float_opts, {
bufnr = api.nvim_win_get_buf(winid), bufnr = api.nvim_win_get_buf(winid),
@ -1271,7 +1270,7 @@ end
--- If a table, pass the table as the {opts} parameter to |vim.diagnostic.open_float()|. --- If a table, pass the table as the {opts} parameter to |vim.diagnostic.open_float()|.
--- Unless overridden, the float will show diagnostics at the new cursor --- Unless overridden, the float will show diagnostics at the new cursor
--- position (as if "cursor" were passed to the "scope" option). --- position (as if "cursor" were passed to the "scope" option).
--- (default: `true`) --- (default: `false`)
--- @field float? boolean|vim.diagnostic.Opts.Float --- @field float? boolean|vim.diagnostic.Opts.Float
--- ---
--- Window ID --- Window ID