diff options
| author | kylo252 <[email protected]> | 2022-11-05 16:46:52 +0100 | 
|---|---|---|
| committer | GitHub <[email protected]> | 2022-11-05 16:46:52 +0100 | 
| commit | 222a872dccea6c56783a3e3728d5bb4f5ab3447c (patch) | |
| tree | e9f2feb479356a3067cd23e4fcce2db5f64d17b4 | |
| parent | 58e0555b4c6813c9f5f4532ffb88f8c429e2d2e2 (diff) | |
fix(config): use a minimal bootstrap for mason (#3427)
| -rw-r--r-- | lua/lvim/bootstrap.lua | 2 | ||||
| -rw-r--r-- | lua/lvim/core/mason.lua | 47 | 
2 files changed, 49 insertions, 0 deletions
| diff --git a/lua/lvim/bootstrap.lua b/lua/lvim/bootstrap.lua index 3fd000e3..5385e8a8 100644 --- a/lua/lvim/bootstrap.lua +++ b/lua/lvim/bootstrap.lua @@ -106,6 +106,8 @@ function M:init(base_dir)      install_path = self.packer_install_dir,    } +  require("lvim.core.mason").bootstrap() +    return self  end diff --git a/lua/lvim/core/mason.lua b/lua/lvim/core/mason.lua index 19dee633..75b12229 100644 --- a/lua/lvim/core/mason.lua +++ b/lua/lvim/core/mason.lua @@ -1,5 +1,7 @@  local M = {} +local join_paths = require("lvim.utils").join_paths +  function M.config()    lvim.builtin.mason = {      ui = { @@ -16,7 +18,27 @@ function M.config()          apply_language_filter = "<C-f>",        },      }, + +    -- 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 = { +      -- 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,      github = { @@ -30,12 +52,37 @@ function M.config()    }  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)  end | 
