aboutsummaryrefslogtreecommitdiffstats
path: root/lua/nvim-lsp-installer/servers/terraformls/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/terraformls/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/terraformls/init.lua')
-rw-r--r--lua/nvim-lsp-installer/servers/terraformls/init.lua59
1 files changed, 30 insertions, 29 deletions
diff --git a/lua/nvim-lsp-installer/servers/terraformls/init.lua b/lua/nvim-lsp-installer/servers/terraformls/init.lua
index 8bcb7f32..bf9e6cb5 100644
--- a/lua/nvim-lsp-installer/servers/terraformls/init.lua
+++ b/lua/nvim-lsp-installer/servers/terraformls/init.lua
@@ -2,9 +2,8 @@ local server = require "nvim-lsp-installer.server"
local process = require "nvim-lsp-installer.process"
local path = require "nvim-lsp-installer.path"
local platform = require "nvim-lsp-installer.platform"
-local std = require "nvim-lsp-installer.installers.std"
-local context = require "nvim-lsp-installer.installers.context"
local Data = require "nvim-lsp-installer.data"
+local github = require "nvim-lsp-installer.core.managers.github"
local coalesce, when = Data.coalesce, Data.when
@@ -14,34 +13,36 @@ return function(name, root_dir)
root_dir = root_dir,
homepage = "https://github.com/hashicorp/terraform-ls",
languages = { "terraform" },
- installer = {
- context.use_github_release_file("hashicorp/terraform-ls", function(version)
- return Data.coalesce(
- when(
- platform.is_mac,
- coalesce(
- when(platform.arch == "arm64", "terraform-ls_%s_darwin_arm64.zip"),
- when(platform.arch == "x64", "terraform-ls_%s_darwin_amd64.zip")
+ async = true,
+ installer = function()
+ github.unzip_release_file({
+ repo = "hashicorp/terraform-ls",
+ asset_file = function(version)
+ local target = coalesce(
+ when(
+ platform.is_mac,
+ coalesce(
+ when(platform.arch == "arm64", "terraform-ls_%s_darwin_arm64.zip"),
+ when(platform.arch == "x64", "terraform-ls_%s_darwin_amd64.zip")
+ )
+ ),
+ when(
+ platform.is_linux,
+ coalesce(
+ when(platform.arch == "arm64", "terraform-ls_%s_linux_arm64.zip"),
+ when(platform.arch == "arm", "terraform-ls_%s_linux_arm.zip"),
+ when(platform.arch == "x64", "terraform-ls_%s_linux_amd64.zip")
+ )
+ ),
+ when(
+ platform.is_win,
+ coalesce(when(platform.arch == "x64", "terraform-ls_%s_windows_amd64.zip"))
)
- ),
- when(
- platform.is_linux,
- coalesce(
- when(platform.arch == "arm64", "terraform-ls_%s_linux_arm64.zip"),
- when(platform.arch == "arm", "terraform-ls_%s_linux_arm.zip"),
- when(platform.arch == "x64", "terraform-ls_%s_linux_amd64.zip")
- )
- ),
- when(platform.is_win, coalesce(when(platform.arch == "x64", "terraform-ls_%s_windows_amd64.zip")))
- ):format(version:gsub("^v", ""))
- end),
- context.capture(function(ctx)
- return std.unzip_remote(ctx.github_release_file, "terraform-ls")
- end),
- context.receipt(function(receipt, ctx)
- receipt:with_primary_source(receipt.github_release_file(ctx))
- end),
- },
+ )
+ return target and target:format(version:gsub("^v", ""))
+ end,
+ }).with_receipt()
+ end,
default_options = {
cmd_env = {
PATH = process.extend_path { path.concat { root_dir, "terraform-ls" } },