aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lua/mason-registry/index/clj-kondo/init.lua38
-rw-r--r--lua/mason-registry/index/init.lua1
-rw-r--r--lua/mason/mappings/language.lua4
3 files changed, 41 insertions, 2 deletions
diff --git a/lua/mason-registry/index/clj-kondo/init.lua b/lua/mason-registry/index/clj-kondo/init.lua
new file mode 100644
index 00000000..6ac007bc
--- /dev/null
+++ b/lua/mason-registry/index/clj-kondo/init.lua
@@ -0,0 +1,38 @@
+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 = "clj-kondo",
+ desc = [[Static analyzer and linter for Clojure code that sparks joy]],
+ homepage = "https://github.com/clj-kondo/clj-kondo",
+ languages = { Pkg.Lang.Clojure, Pkg.Lang.ClojureScript },
+ categories = { Pkg.Cat.Linter },
+ ---@async
+ ---@param ctx InstallContext
+ install = function(ctx)
+ local function format_release_file(file)
+ return _.compose(_.format(file), _.gsub("^v", ""))
+ end
+
+ github
+ .unzip_release_file({
+ repo = "clj-kondo/clj-kondo",
+ asset_file = coalesce(
+ when(platform.is.mac_arm64, format_release_file "clj-kondo-%s-macos-aarch64.zip"),
+ when(platform.is.mac_x64, format_release_file "clj-kondo-%s-macos-amd64.zip"),
+ when(platform.is.linux_x64_gnu, format_release_file "clj-kondo-%s-linux-amd64.zip"),
+ when(platform.is.linux_x64, format_release_file "clj-kondo-%s-linux-static-amd64.zip"),
+ when(platform.is.linux_arm64, format_release_file "clj-kondo-%s-linux-aarch64.zip"),
+ when(platform.is.win_x64, format_release_file "clj-kondo-%s-windows-amd64.zip")
+ ),
+ })
+ .with_receipt()
+ std.chmod("+x", { "clj-kondo" })
+ ctx:link_bin("clj-kondo", platform.is.win and "clj-kondo.exe" or "clj-kondo")
+ end,
+}
diff --git a/lua/mason-registry/index/init.lua b/lua/mason-registry/index/init.lua
index 68b42201..a943c7b4 100644
--- a/lua/mason-registry/index/init.lua
+++ b/lua/mason-registry/index/init.lua
@@ -37,6 +37,7 @@ return {
["clang-format"] = "mason-registry.index.clang-format",
clangd = "mason-registry.index.clangd",
["clarity-lsp"] = "mason-registry.index.clarity-lsp",
+ ["clj-kondo"] = "mason-registry.index.clj-kondo",
["clojure-lsp"] = "mason-registry.index.clojure-lsp",
["cmake-language-server"] = "mason-registry.index.cmake-language-server",
cmakelang = "mason-registry.index.cmakelang",
diff --git a/lua/mason/mappings/language.lua b/lua/mason/mappings/language.lua
index a8bfe75c..686ff57f 100644
--- a/lua/mason/mappings/language.lua
+++ b/lua/mason/mappings/language.lua
@@ -22,8 +22,8 @@ return {
["c#"] = { "clang-format", "csharp-language-server", "csharpier", "netcoredbg", "omnisharp", "omnisharp-mono", "semgrep" },
["c++"] = { "clang-format", "clangd", "codelldb", "cpplint", "cpptools" },
clarity = { "clarity-lsp" },
- clojure = { "clojure-lsp", "joker" },
- clojurescript = { "clojure-lsp", "joker" },
+ clojure = { "clj-kondo", "clojure-lsp", "joker" },
+ clojurescript = { "clj-kondo", "clojure-lsp", "joker" },
cmake = { "cmake-language-server", "cmakelang", "cmakelint", "gersemi", "neocmakelsp" },
codeql = { "codeql" },
crystal = { "crystalline" },