Iterating on null-ls formatting
Had to disable the format on save since it was fighting with some other linter.
This commit is contained in:
parent
4a948b02e1
commit
3310dbec07
@ -22,6 +22,7 @@ local on_attach = function(_, bufnr)
|
||||
vim.keymap.set('v', '<leader>a', vim.lsp.buf.code_action, bufopts)
|
||||
vim.keymap.set('n', 'ga', vim.lsp.buf.code_action, bufopts)
|
||||
vim.keymap.set('n', '<leader>f', function() vim.lsp.buf.format { async = true } end, bufopts)
|
||||
vim.keymap.set('n', '<leader>F', function() vim.lsp.buf.format { async = true } end, bufopts)
|
||||
-- vim.keymap.set('n', 'gr', vim.lsp.buf.references, bufopts)
|
||||
-- vim.keymap.set('n', 'gd', vim.lsp.buf.definition, bufopts)
|
||||
-- vim.keymap.set('n', '<leader>D', vim.lsp.buf.type_definition, bufopts)
|
||||
|
@ -1,10 +1,57 @@
|
||||
local null_ls = require('null-ls')
|
||||
local null_ls = require("null-ls")
|
||||
|
||||
-- From: https://github.com/jose-elias-alvarez/null-ls.nvim/wiki/Formatting-on-save
|
||||
local async_formatting = function(bufnr)
|
||||
bufnr = bufnr or vim.api.nvim_get_current_buf()
|
||||
|
||||
vim.lsp.buf_request(
|
||||
bufnr,
|
||||
"textDocument/formatting",
|
||||
vim.lsp.util.make_formatting_params({}),
|
||||
function(err, res, ctx)
|
||||
if err then
|
||||
local err_msg = type(err) == "string" and err or err.message
|
||||
-- you can modify the log message / level (or ignore it completely)
|
||||
vim.notify("formatting: " .. err_msg, vim.log.levels.WARN)
|
||||
return
|
||||
end
|
||||
|
||||
-- don't apply results if buffer is unloaded or has been modified
|
||||
if not vim.api.nvim_buf_is_loaded(bufnr) or vim.api.nvim_buf_get_option(bufnr, "modified") then
|
||||
return
|
||||
end
|
||||
|
||||
if res then
|
||||
local client = vim.lsp.get_client_by_id(ctx.client_id)
|
||||
vim.lsp.util.apply_text_edits(res, bufnr, client and client.offset_encoding or "utf-16")
|
||||
vim.api.nvim_buf_call(bufnr, function()
|
||||
vim.cmd("silent noautocmd update")
|
||||
end)
|
||||
end
|
||||
end
|
||||
)
|
||||
end
|
||||
|
||||
local augroup = vim.api.nvim_create_augroup("LspFormatting", {})
|
||||
|
||||
null_ls.setup({
|
||||
-- thallada: broken
|
||||
-- on_attach = function(client, bufnr)
|
||||
-- if client.supports_method("textDocument/formatting") then
|
||||
-- vim.api.nvim_clear_autocmds({ group = augroup, buffer = bufnr })
|
||||
-- vim.api.nvim_create_autocmd("BufWritePost", {
|
||||
-- group = augroup,
|
||||
-- buffer = bufnr,
|
||||
-- callback = function()
|
||||
-- async_formatting(bufnr)
|
||||
-- end,
|
||||
-- })
|
||||
-- end
|
||||
-- end,
|
||||
sources = {
|
||||
-- Linter
|
||||
-- null_ls.builtins.diagnostics.eslint_d,
|
||||
null_ls.builtins.diagnostics.jsonlint,
|
||||
-- null_ls.builtins.diagnostics.jsonlint,
|
||||
null_ls.builtins.diagnostics.markdownlint,
|
||||
null_ls.builtins.diagnostics.stylelint,
|
||||
null_ls.builtins.diagnostics.tidy,
|
||||
@ -15,7 +62,7 @@ null_ls.setup({
|
||||
-- Formatter
|
||||
null_ls.builtins.formatting.eslint_d,
|
||||
null_ls.builtins.formatting.markdownlint,
|
||||
null_ls.builtins.formatting.prettierd,
|
||||
-- null_ls.builtins.formatting.prettierd,
|
||||
null_ls.builtins.formatting.sqlfluff.with({
|
||||
extra_args = { "--dialect", "postgres" },
|
||||
}),
|
||||
|
Loading…
Reference in New Issue
Block a user