aboutsummaryrefslogtreecommitdiffstats
path: root/lua/nvim-lsp-installer/servers/solang/init.lua
diff options
context:
space:
mode:
authorWilliam Boman <william@redwill.se>2022-04-21 12:09:59 +0200
committerGitHub <noreply@github.com>2022-04-21 12:09:59 +0200
commitb68fcc6bb2c770495ff8e2508c06dfdd49abcc80 (patch)
treedf7c71efb59958deb21a18eeccf3e3c43c4cd704 /lua/nvim-lsp-installer/servers/solang/init.lua
parentrun autogen_metadata.lua (diff)
downloadmason-b68fcc6bb2c770495ff8e2508c06dfdd49abcc80.tar
mason-b68fcc6bb2c770495ff8e2508c06dfdd49abcc80.tar.gz
mason-b68fcc6bb2c770495ff8e2508c06dfdd49abcc80.tar.bz2
mason-b68fcc6bb2c770495ff8e2508c06dfdd49abcc80.tar.lz
mason-b68fcc6bb2c770495ff8e2508c06dfdd49abcc80.tar.xz
mason-b68fcc6bb2c770495ff8e2508c06dfdd49abcc80.tar.zst
mason-b68fcc6bb2c770495ff8e2508c06dfdd49abcc80.zip
chore: refactor remaining installers to async impl (#616)
Diffstat (limited to 'lua/nvim-lsp-installer/servers/solang/init.lua')
-rw-r--r--lua/nvim-lsp-installer/servers/solang/init.lua69
1 files changed, 34 insertions, 35 deletions
diff --git a/lua/nvim-lsp-installer/servers/solang/init.lua b/lua/nvim-lsp-installer/servers/solang/init.lua
index e8223def..8a382cf3 100644
--- a/lua/nvim-lsp-installer/servers/solang/init.lua
+++ b/lua/nvim-lsp-installer/servers/solang/init.lua
@@ -1,64 +1,63 @@
local server = require "nvim-lsp-installer.server"
local path = require "nvim-lsp-installer.path"
-local std = require "nvim-lsp-installer.installers.std"
-local context = require "nvim-lsp-installer.installers.context"
local Data = require "nvim-lsp-installer.data"
local platform = require "nvim-lsp-installer.platform"
-local installers = require "nvim-lsp-installer.installers"
local process = require "nvim-lsp-installer.process"
+local std = require "nvim-lsp-installer.core.managers.std"
+local github = require "nvim-lsp-installer.core.managers.github"
local coalesce, when = Data.coalesce, Data.when
return function(name, root_dir)
- local solang_executable_installer = installers.pipe {
- context.use_github_release_file(
- "hyperledger-labs/solang",
- coalesce(
+ ---@async
+ local function download_solang()
+ local source = github.release_file {
+ repo = "hyperledger-labs/solang",
+ asset_file = coalesce(
when(platform.is_mac and platform.arch == "x64", "solang-mac-intel"),
when(platform.is_mac and platform.arch == "arm64", "solang-mac-arm"),
when(platform.is_linux and platform.arch == "arm64", "solang-linux-arm64"),
when(platform.is_linux and platform.arch == "x64", "solang-linux-x86-64"),
when(platform.is_win, "solang.exe")
- )
- ),
- context.capture(function(ctx)
- return std.download_file(ctx.github_release_file, platform.is_win and "solang.exe" or "solang")
- end),
- std.chmod("+x", { "solang" }),
- context.receipt(function(receipt, ctx)
- receipt:with_primary_source(receipt.github_release_file(ctx))
- end),
- }
+ ),
+ }
+ source.with_receipt()
+ std.download_file(source.download_url, platform.is_win and "solang.exe" or "solang")
+ std.chmod("+x", { "solang" })
+ return source
+ end
- local llvm_installer = installers.pipe {
- context.use_github_release_file(
- "hyperledger-labs/solang",
- coalesce(
+ ---@async
+ local function download_llvm()
+ local source = github.release_file {
+ repo = "hyperledger-labs/solang",
+ asset_file = coalesce(
when(platform.is_mac and platform.arch == "x64", "llvm13.0-mac-intel.tar.xz"),
when(platform.is_mac and platform.arch == "arm64", "llvm13.0-mac-arm.tar.xz"),
when(platform.is_linux and platform.arch == "x64", "llvm13.0-linux-x86-64.tar.xz"),
when(platform.is_linux and platform.arch == "arm64", "llvm13.0-linux-arm64.tar.xz"),
when(platform.is_win, "llvm13.0-win.zip")
- )
- ),
- context.capture(function(ctx)
- if platform.is_win then
- return std.unzip_remote(ctx.github_release_file)
- else
- return std.untarxz_remote(ctx.github_release_file)
- end
- end),
- }
+ ),
+ }
+ if platform.is_win then
+ std.download_file(source.download_url, "llvm.zip")
+ std.unzip("llvm.zip", ".")
+ else
+ std.download_file(source.download_url, "llvm.tar.xz")
+ std.untar "llvm.tar.xz"
+ end
+ end
return server.Server:new {
name = name,
root_dir = root_dir,
homepage = "https://solang.readthedocs.io/en/latest/",
languages = { "solidity" },
- installer = {
- solang_executable_installer,
- llvm_installer,
- },
+ async = true,
+ ---@param ctx InstallContext
+ installer = function(ctx)
+ ctx:run_concurrently { download_solang, download_llvm }
+ end,
default_options = {
cmd_env = {
PATH = process.extend_path {