aboutsummaryrefslogtreecommitdiffstats
path: root/lua/mason-registry/index/solidity/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/solidity/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/solidity/init.lua')
-rw-r--r--lua/mason-registry/index/solidity/init.lua32
1 files changed, 32 insertions, 0 deletions
diff --git a/lua/mason-registry/index/solidity/init.lua b/lua/mason-registry/index/solidity/init.lua
new file mode 100644
index 00000000..d3b0385c
--- /dev/null
+++ b/lua/mason-registry/index/solidity/init.lua
@@ -0,0 +1,32 @@
+local Pkg = require "mason-core.package"
+local _ = require "mason-core.functional"
+local platform = require "mason-core.platform"
+local github = require "mason-core.managers.github"
+local std = require "mason-core.managers.std"
+
+local coalesce, when = _.coalesce, _.when
+
+return Pkg.new {
+ name = "solidity",
+ desc = [[Solidity, the Smart Contract Programming Language]],
+ homepage = "https://github.com/ethereum/solidity",
+ categories = { Pkg.Cat.Compiler, Pkg.Cat.LSP },
+ languages = { Pkg.Lang.Solidity },
+ ---@async
+ ---@param ctx InstallContext
+ install = function(ctx)
+ github
+ .download_release_file({
+ repo = "ethereum/solidity",
+ out_file = platform.is.win and "solc.exe" or "solc",
+ asset_file = coalesce(
+ when(platform.is.mac, "solc-macos"),
+ when(platform.is.linux, "solc-static-linux"),
+ when(platform.is.win, "solc-windows.exe")
+ ),
+ })
+ .with_receipt()
+ std.chmod("+x", { "solc" })
+ ctx:link_bin("solc", platform.is.win and "solc.exe" or "solc")
+ end,
+}