aboutsummaryrefslogtreecommitdiffstats
path: root/lua/mason-registry/index/ada-language-server/init.lua
diff options
context:
space:
mode:
authorWilliam Boman <william@redwill.se>2023-02-20 22:19:39 +0100
committerGitHub <noreply@github.com>2023-02-20 22:19:39 +0100
commitb8a6632a0f2d263199d5d480ca85477fe0f414ab (patch)
tree57e1ee0f3cef078ec144ecdf1b2fa861acf47755 /lua/mason-registry/index/ada-language-server/init.lua
parentchore: autogenerate (#1015) (diff)
downloadmason-b8a6632a0f2d263199d5d480ca85477fe0f414ab.tar
mason-b8a6632a0f2d263199d5d480ca85477fe0f414ab.tar.gz
mason-b8a6632a0f2d263199d5d480ca85477fe0f414ab.tar.bz2
mason-b8a6632a0f2d263199d5d480ca85477fe0f414ab.tar.lz
mason-b8a6632a0f2d263199d5d480ca85477fe0f414ab.tar.xz
mason-b8a6632a0f2d263199d5d480ca85477fe0f414ab.tar.zst
mason-b8a6632a0f2d263199d5d480ca85477fe0f414ab.zip
feat: configurable registries (#1016)
Diffstat (limited to 'lua/mason-registry/index/ada-language-server/init.lua')
-rw-r--r--lua/mason-registry/index/ada-language-server/init.lua40
1 files changed, 40 insertions, 0 deletions
diff --git a/lua/mason-registry/index/ada-language-server/init.lua b/lua/mason-registry/index/ada-language-server/init.lua
new file mode 100644
index 00000000..da870817
--- /dev/null
+++ b/lua/mason-registry/index/ada-language-server/init.lua
@@ -0,0 +1,40 @@
+local Pkg = require "mason-core.package"
+local path = require "mason-core.path"
+local platform = require "mason-core.platform"
+local _ = require "mason-core.functional"
+local github = require "mason-core.managers.github"
+local std = require "mason-core.managers.std"
+
+local coalesce, when = _.coalesce, _.when
+
+return Pkg.new {
+ name = "ada-language-server",
+ desc = [[Ada/SPARK language server]],
+ homepage = "https://github.com/AdaCore/ada_language_server",
+ languages = { Pkg.Lang.Ada },
+ categories = { Pkg.Cat.LSP },
+ ---@async
+ ---@param ctx InstallContext
+ install = function(ctx)
+ github
+ .unzip_release_file({
+ repo = "AdaCore/ada_language_server",
+ asset_file = function(release)
+ local target = coalesce(
+ when(platform.is.mac, "als-%s-macOS_amd64.zip"),
+ when(platform.is.linux_x64, "als-%s-Linux_amd64.zip"),
+ when(platform.is.win_x64, "als-%s-Windows_amd64.zip")
+ )
+ return target and target:format(release)
+ end,
+ })
+ .with_receipt()
+
+ local binary = coalesce(
+ when(platform.is.mac, path.concat { "darwin", "ada_language_server" }),
+ when(platform.is.linux_x64, path.concat { "linux", "ada_language_server" }),
+ when(platform.is.win_x64, path.concat { "win32", "ada_language_server.exe" })
+ )
+ ctx:link_bin("ada_language_server", binary)
+ end,
+}