diff options
Diffstat (limited to 'lua')
| -rw-r--r-- | lua/mason-core/installer/managers/std.lua | 5 | ||||
| -rw-r--r-- | lua/mason/health.lua | 4 |
2 files changed, 7 insertions, 2 deletions
diff --git a/lua/mason-core/installer/managers/std.lua b/lua/mason-core/installer/managers/std.lua index d08de888..6e1a0d9e 100644 --- a/lua/mason-core/installer/managers/std.lua +++ b/lua/mason-core/installer/managers/std.lua @@ -1,5 +1,6 @@ local Result = require "mason-core.result" local _ = require "mason-core.functional" +local a = require "mason-core.async" local fetch = require "mason-core.fetch" local installer = require "mason-core.installer" local log = require "mason-core.log" @@ -108,7 +109,9 @@ end local function untar(rel_path) log.fmt_debug("std: untar %s", rel_path) local ctx = installer.context() - return ctx.spawn.tar({ "--no-same-owner", "-xvf", rel_path }):on_success(function() + a.scheduler() + local tar = vim.fn.executable "gtar" == 1 and "gtar" or "tar" + return ctx.spawn[tar]({ "--no-same-owner", "-xvf", rel_path }):on_success(function() pcall(function() ctx.fs:unlink(rel_path) end) diff --git a/lua/mason/health.lua b/lua/mason/health.lua index fdd5ea07..ade8a29d 100644 --- a/lua/mason/health.lua +++ b/lua/mason/health.lua @@ -143,7 +143,9 @@ local function check_core_utils() use_stderr = platform.is.mac, -- Apple gzip prints version string to stderr relaxed = platform.is.win, } - check { cmd = "tar", args = { "--version" }, name = "tar" } + + local tar = vim.fn.executable "gtar" == 1 and "gtar" or "tar" + check { cmd = tar, args = { "--version" }, name = tar } if platform.is.unix then check { cmd = "bash", args = { "--version" }, name = "bash" } |
