aboutsummaryrefslogtreecommitdiffstats
path: root/lua/mason-core/managers/gem/init.lua
diff options
context:
space:
mode:
authorWilliam Boman <william@redwill.se>2022-07-31 00:45:17 +0200
committerGitHub <noreply@github.com>2022-07-31 00:45:17 +0200
commit116a825929fa3066f32afc77f7459630419bc347 (patch)
treea695ae708b67b420d750f2dbc3bb76b0eb713735 /lua/mason-core/managers/gem/init.lua
parentfeat(taplo): use prebuilt binary if available (#201) (diff)
downloadmason-116a825929fa3066f32afc77f7459630419bc347.tar
mason-116a825929fa3066f32afc77f7459630419bc347.tar.gz
mason-116a825929fa3066f32afc77f7459630419bc347.tar.bz2
mason-116a825929fa3066f32afc77f7459630419bc347.tar.lz
mason-116a825929fa3066f32afc77f7459630419bc347.tar.xz
mason-116a825929fa3066f32afc77f7459630419bc347.tar.zst
mason-116a825929fa3066f32afc77f7459630419bc347.zip
fix(gem): write shim executables that enhance GEM_PATH appropriately (#202)
Diffstat (limited to 'lua/mason-core/managers/gem/init.lua')
-rw-r--r--lua/mason-core/managers/gem/init.lua51
1 files changed, 36 insertions, 15 deletions
diff --git a/lua/mason-core/managers/gem/init.lua b/lua/mason-core/managers/gem/init.lua
index 8b64d68a..da9b800b 100644
--- a/lua/mason-core/managers/gem/init.lua
+++ b/lua/mason-core/managers/gem/init.lua
@@ -9,9 +9,38 @@ local platform = require "mason-core.platform"
local M = {}
+---@param install_dir string
+local function env(install_dir)
+ return {
+ GEM_HOME = install_dir,
+ GEM_PATH = install_dir,
+ PATH = process.extend_path { path.concat { install_dir, "bin" } },
+ }
+end
+
local create_bin_path = _.compose(path.concat, function(executable)
return _.append(executable, { "bin" })
-end, _.if_else(_.always(platform.is.win), _.format "%s.cmd", _.identity))
+end, _.if_else(_.always(platform.is.win), _.format "%s.bat", _.identity))
+
+---@async
+---@param executable string
+local function link_executable(executable)
+ local ctx = installer.context()
+ local bin_path = create_bin_path(executable)
+ ctx:link_bin(
+ executable,
+ ctx:write_shell_exec_wrapper(executable, path.concat { ctx.package:get_install_path(), bin_path }, {
+ GEM_PATH = platform.when {
+ unix = function()
+ return ("%s:$GEM_PATH"):format(ctx.package:get_install_path())
+ end,
+ win = function()
+ return ("%s;%%GEM_PATH%%"):format(ctx.package:get_install_path())
+ end,
+ },
+ })
+ )
+end
---@param packages string[]
local function with_receipt(packages)
@@ -49,12 +78,13 @@ function M.install(packages)
"--bindir=bin",
"--no-document",
pkgs,
+ env = {
+ GEM_HOME = ctx.cwd:get(),
+ },
}
if packages.bin then
- _.each(function(executable)
- ctx:link_bin(executable, create_bin_path(executable))
- end, packages.bin)
+ _.each(link_executable, packages.bin)
end
return {
@@ -109,7 +139,7 @@ function M.check_outdated_primary_package(receipt, install_dir)
if receipt.primary_source.type ~= "gem" then
return Result.failure "Receipt does not have a primary source of type gem"
end
- return spawn.gem({ "outdated", cwd = install_dir, env = M.env(install_dir) }):map_catching(function(result)
+ return spawn.gem({ "outdated", cwd = install_dir, env = env(install_dir) }):map_catching(function(result)
---@type string[]
local lines = vim.split(result.stdout, "\n")
local outdated_gems = vim.tbl_map(M.parse_outdated_gem, vim.tbl_filter(not_empty, lines))
@@ -138,7 +168,7 @@ function M.get_installed_primary_package_version(receipt, install_dir)
.gem({
"list",
cwd = install_dir,
- env = M.env(install_dir),
+ env = env(install_dir),
})
:map_catching(function(result)
local gems = M.parse_gem_list_output(result.stdout)
@@ -147,13 +177,4 @@ function M.get_installed_primary_package_version(receipt, install_dir)
end)
end
----@param install_dir string
-function M.env(install_dir)
- return {
- GEM_HOME = install_dir,
- GEM_PATH = install_dir,
- PATH = process.extend_path { path.concat { install_dir, "bin" } },
- }
-end
-
return M