formatters.lua 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. local M = {}
  2. local null_ls = require "null-ls"
  3. local services = require "lvim.lsp.null-ls.services"
  4. local Log = require "lvim.core.log"
  5. local is_registered = function(name)
  6. local query = {
  7. name = name,
  8. method = require("null-ls").methods.FORMATTING,
  9. }
  10. return require("null-ls.sources").is_registered(query)
  11. end
  12. function M.list_registered_providers(filetype)
  13. local null_ls_methods = require "null-ls.methods"
  14. local formatter_method = null_ls_methods.internal["FORMATTING"]
  15. local registered_providers = services.list_registered_providers_names(filetype)
  16. return registered_providers[formatter_method] or {}
  17. end
  18. function M.list_available(filetype)
  19. local formatters = {}
  20. local tbl = require "lvim.utils.table"
  21. for _, provider in pairs(null_ls.builtins.formatting) do
  22. if tbl.contains(provider.filetypes or {}, function(ft)
  23. return ft == "*" or ft == filetype
  24. end) then
  25. table.insert(formatters, provider.name)
  26. end
  27. end
  28. table.sort(formatters)
  29. return formatters
  30. end
  31. function M.list_configured(formatter_configs)
  32. local formatters, errors = {}, {}
  33. for _, fmt_config in ipairs(formatter_configs) do
  34. local name = fmt_config.exe:gsub("-", "_")
  35. local formatter = null_ls.builtins.formatting[name]
  36. if not formatter then
  37. Log:error("Not a valid formatter: " .. fmt_config.exe)
  38. errors[name] = {} -- Add data here when necessary
  39. elseif is_registered(fmt_config.exe) then
  40. Log:trace "Skipping registering the source more than once"
  41. else
  42. local formatter_cmd = services.find_command(formatter._opts.command)
  43. if not formatter_cmd then
  44. Log:warn("Not found: " .. formatter._opts.command)
  45. errors[name] = {} -- Add data here when necessary
  46. else
  47. Log:debug("Using formatter: " .. formatter_cmd)
  48. table.insert(
  49. formatters,
  50. formatter.with {
  51. command = formatter_cmd,
  52. extra_args = fmt_config.args,
  53. filetypes = fmt_config.filetypes,
  54. }
  55. )
  56. end
  57. end
  58. end
  59. return { supported = formatters, unsupported = errors }
  60. end
  61. function M.setup(formatter_configs)
  62. if vim.tbl_isempty(formatter_configs) then
  63. return
  64. end
  65. local formatters = M.list_configured(formatter_configs)
  66. null_ls.register { sources = formatters.supported }
  67. end
  68. return M