123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- local M = {}
- local join_paths = require("lvim.utils").join_paths
- function M.config()
- lvim.builtin.mason = {
- ui = {
- check_outdated_packages_on_open = true,
- width = 0.8,
- height = 0.9,
- border = "rounded",
- keymaps = {
- toggle_package_expand = "<CR>",
- install_package = "i",
- update_package = "u",
- check_package_version = "c",
- update_all_packages = "U",
- check_outdated_packages = "C",
- uninstall_package = "X",
- cancel_installation = "<C-c>",
- apply_language_filter = "<C-f>",
- },
- },
- icons = {
- package_installed = "◍",
- package_pending = "◍",
- package_uninstalled = "◍",
- },
- -- NOTE: should be available in $PATH
- install_root_dir = join_paths(vim.fn.stdpath "data", "mason"),
- -- NOTE: already handled in the bootstrap stage
- PATH = "skip",
- pip = {
- upgrade_pip = false,
- -- These args will be added to `pip install` calls. Note that setting extra args might impact intended behavior
- -- and is not recommended.
- --
- -- Example: { "--proxy", "https://proxyserver" }
- install_args = {},
- },
- -- Controls to which degree logs are written to the log file. It's useful to set this to vim.log.levels.DEBUG when
- -- debugging issues with package installations.
- log_level = vim.log.levels.INFO,
- -- Limit for the maximum amount of packages to be installed at the same time. Once this limit is reached, any further
- -- packages that are requested to be installed will be put in a queue.
- max_concurrent_installers = 4,
- -- [Advanced setting]
- -- The registries to source packages from. Accepts multiple entries. Should a package with the same name exist in
- -- multiple registries, the registry listed first will be used.
- registries = {
- "lua:mason-registry.index",
- "github:mason-org/mason-registry",
- },
- -- The provider implementations to use for resolving supplementary package metadata (e.g., all available versions).
- -- Accepts multiple entries, where later entries will be used as fallback should prior providers fail.
- providers = {
- "mason.providers.registry-api",
- "mason.providers.client",
- },
- github = {
- -- The template URL to use when downloading assets from GitHub.
- -- The placeholders are the following (in order):
- -- 1. The repository (e.g. "rust-lang/rust-analyzer")
- -- 2. The release version (e.g. "v0.3.0")
- -- 3. The asset name (e.g. "rust-analyzer-v0.3.0-x86_64-unknown-linux-gnu.tar.gz")
- download_url_template = "https://github.com/%s/releases/download/%s/%s",
- },
- on_config_done = nil,
- }
- end
- function M.get_prefix()
- local default_prefix = join_paths(vim.fn.stdpath "data", "mason")
- return vim.tbl_get(lvim.builtin, "mason", "install_root_dir") or default_prefix
- end
- ---@param append boolean|nil whether to append to prepend to PATH
- local function add_to_path(append)
- local p = join_paths(M.get_prefix(), "bin")
- if vim.env.PATH:match(p) then
- return
- end
- local string_separator = vim.loop.os_uname().version:match "Windows" and ";" or ":"
- if append then
- vim.env.PATH = vim.env.PATH .. string_separator .. p
- else
- vim.env.PATH = p .. string_separator .. vim.env.PATH
- end
- end
- function M.bootstrap()
- add_to_path()
- end
- function M.setup()
- local status_ok, mason = pcall(reload, "mason")
- if not status_ok then
- return
- end
- add_to_path(lvim.builtin.mason.PATH == "append")
- mason.setup(lvim.builtin.mason)
- if lvim.builtin.mason.on_config_done then
- lvim.builtin.mason.on_config_done(mason)
- end
- end
- return M
|