local M = {} local disable = pcode.disable_null_ls or false if require("user.utils.cfgstatus").cheack() then disable = true end if disable then -- M = { -- "stevearc/conform.nvim", -- event = { "BufReadPre", "BufNewFile", "VeryLazy" }, -- opts = function(_, opts) -- local mason_reg = require("mason-registry") -- -- opts.formatters = opts.formatters or {} -- opts.formatters_by_ft = opts.formatters_by_ft or {} -- opts.ensure_installed = opts.ensure_installed or {} -- vim.list_extend(opts.ensure_installed, pcode.null_ls_ensure_installed or {}) -- -- -- add diff langue vs filetype -- local keymap = { -- ["c++"] = "cpp", -- ["c#"] = "cs", -- ["jsx"] = "javascriptreact", -- } -- -- -- add diff conform vs mason -- local name_map = { -- ["cmakelang"] = "cmake_format", -- ["deno"] = "deno_fmt", -- ["elm-format"] = "elm_format", -- ["gdtoolkit"] = "gdformat", -- ["nixpkgs-fmt"] = "nixpkgs_fmt", -- ["opa"] = "opa_fmt", -- ["php-cs-fixer"] = "php_cs_fixer", -- ["ruff"] = "ruff_format", -- ["sql-formatter"] = "sql_formatter", -- ["xmlformatter"] = "xmlformat", -- } -- -- -- add new mapping filetype -- local addnew = { -- ["jsonc"] = "prettier", -- ["json"] = "prettier", -- ["typescriptreact"] = "prettier", -- } -- -- -- add ignore filetype -- local ignore = { -- ["php"] = "tlint", -- ["lua"] = "ast-grep", -- ["kotlin"] = "ktlint", -- } -- -- for _, pkg in pairs(mason_reg.get_installed_packages()) do -- for _, type in pairs(pkg.spec.categories) do -- -- only act upon a formatter -- if type == "Formatter" then -- -- if formatter doesn't have a builtin config, create our own from a generic template -- if not require("conform").get_formatter_config(pkg.spec.name) then -- -- the key of the entry to this table -- -- is the name of the bare executable -- -- the actual value may not be the absolute path -- -- in some cases -- local bin = next(pkg.spec.bin) -- -- this should be replaced by a function -- -- that quieries the configured mason install path -- local prefix = vim.fn.stdpath("data") .. "/mason/bin/" -- -- opts.formatters[pkg.spec.name] = { -- command = prefix .. bin, -- args = { "$FILENAME" }, -- stdin = true, -- require_cwd = false, -- } -- end -- -- -- local listtest = {} -- -- finally add the formatter to it's compatible filetype(s) -- for _, ft in pairs(pkg.spec.languages) do -- local ftl = string.lower(ft) -- -- register only ready installed package -- local ready = mason_reg.get_package(pkg.spec.name):is_installed() -- if ready then -- if keymap[ftl] ~= nil then -- ftl = keymap[ftl] -- end -- if name_map[pkg.spec.name] ~= nil then -- pkg.spec.name = name_map[pkg.spec.name] -- end -- -- -- if substring(pkg.spec.name, "ktfmt") then -- -- table.insert(listtest, ftl) -- -- end -- -- -- add new mapping language -- for key, value in pairs(addnew) do -- if value == pkg.spec.name then -- opts.formatters_by_ft[key] = opts.formatters_by_ft[key] or {} -- table.insert(opts.formatters_by_ft[key], pkg.spec.name) -- end -- end -- -- if ignore[ftl] ~= pkg.spec.name then -- opts.formatters_by_ft[ftl] = opts.formatters_by_ft[ftl] or {} -- table.insert(opts.formatters_by_ft[ftl], pkg.spec.name) -- end -- end -- end -- -- print(table.concat(listtest, ",")) -- end -- end -- end -- -- local onsave = pcode.format_on_save or false -- if onsave then -- return { -- ensure_installed = opts.ensure_installed, -- format_on_save = { -- lsp_fallback = true, -- timeout_ms = pcode.format_timeout_ms or 5000, -- }, -- formatters = opts.formatters, -- formatters_by_ft = opts.formatters_by_ft, -- } -- else -- return { -- ensure_installed = opts.ensure_installed, -- formatters = opts.formatters, -- formatters_by_ft = opts.formatters_by_ft, -- } -- end -- end, -- config = function(_, opts) -- for _, value in pairs(opts.ensure_installed) do -- require("user.utils.masoncfg").try_install(value) -- end -- local conform = require("conform") -- conform.setup(opts) -- vim.keymap.set({ "n", "v" }, "lF", function() -- conform.format({ -- lsp_fallback = true, -- async = false, -- timeout_ms = pcode.format_timeout_ms or 5000, -- }) -- end, { desc = "Format file or range (in visual mode)" }) -- end, -- } end return M