aboutsummaryrefslogtreecommitdiffstats
path: root/lua
diff options
context:
space:
mode:
Diffstat (limited to 'lua')
-rw-r--r--lua/mason-core/installer/registry/expr.lua44
-rw-r--r--lua/mason-core/result.lua9
2 files changed, 53 insertions, 0 deletions
diff --git a/lua/mason-core/installer/registry/expr.lua b/lua/mason-core/installer/registry/expr.lua
new file mode 100644
index 00000000..be704156
--- /dev/null
+++ b/lua/mason-core/installer/registry/expr.lua
@@ -0,0 +1,44 @@
+local _ = require "mason-core.functional"
+local string_funs = require "mason-core.functional.string"
+local Result = require "mason-core.result"
+
+local M = {}
+
+local parse_expr = _.compose(
+ _.apply_spec {
+ value_expr = _.head,
+ filters = _.drop(1),
+ },
+ _.filter(_.complement(_.equals "")),
+ _.map(_.trim),
+ _.split "|"
+)
+
+---@param str string
+---@param ctx table<string, any>
+function M.eval(str, ctx)
+ return Result.pcall(function()
+ return _.gsub("{{([^}]+)}}", function(expr)
+ local components = parse_expr(expr)
+ local value =
+ assert(ctx[components.value_expr], ("Unable to interpolate value: %q."):format(components.value_expr))
+ return _.reduce(
+ _.apply_to,
+ value,
+ _.map(function(filter_expr)
+ local filter = setfenv(
+ assert(
+ loadstring("return " .. filter_expr),
+ ("Failed to parse filter: %q."):format(filter_expr)
+ ),
+ string_funs
+ )()
+ assert(type(filter) == "function", ("Invalid filter expression: %q."):format(filter_expr))
+ return filter
+ end, components.filters)
+ )
+ end, str)
+ end)
+end
+
+return M
diff --git a/lua/mason-core/result.lua b/lua/mason-core/result.lua
index c598b967..2521fff1 100644
--- a/lua/mason-core/result.lua
+++ b/lua/mason-core/result.lua
@@ -176,4 +176,13 @@ function Result.run_catching(fn)
end
end
+function Result.pcall(fn, ...)
+ local ok, res = pcall(fn, ...)
+ if ok then
+ return Result.success(res)
+ else
+ return Result.failure(res)
+ end
+end
+
return Result