diff options
| author | William Boman <william@redwill.se> | 2022-04-21 12:09:59 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-04-21 12:09:59 +0200 |
| commit | b68fcc6bb2c770495ff8e2508c06dfdd49abcc80 (patch) | |
| tree | df7c71efb59958deb21a18eeccf3e3c43c4cd704 /lua/nvim-lsp-installer/servers/solang/init.lua | |
| parent | run autogen_metadata.lua (diff) | |
| download | mason-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.lua | 69 |
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 { |
