aboutsummaryrefslogtreecommitdiffstats
path: root/lua/mason-core
diff options
context:
space:
mode:
authorWilliam Boman <william@redwill.se>2023-01-02 06:47:41 +0100
committerGitHub <noreply@github.com>2023-01-02 06:47:41 +0100
commit2953751d1beda5eeec54fd7bb743614c56febc18 (patch)
treea98799e3d0cd836f5317ed33e14bc8f47123f716 /lua/mason-core
parentfix(ui): do not override existing MasonNormal hl group (#833) (diff)
downloadmason-2953751d1beda5eeec54fd7bb743614c56febc18.tar
mason-2953751d1beda5eeec54fd7bb743614c56febc18.tar.gz
mason-2953751d1beda5eeec54fd7bb743614c56febc18.tar.bz2
mason-2953751d1beda5eeec54fd7bb743614c56febc18.tar.lz
mason-2953751d1beda5eeec54fd7bb743614c56febc18.tar.xz
mason-2953751d1beda5eeec54fd7bb743614c56febc18.tar.zst
mason-2953751d1beda5eeec54fd7bb743614c56febc18.zip
feat(functional): add split_every and default_to (#835)
Diffstat (limited to 'lua/mason-core')
-rw-r--r--lua/mason-core/functional/init.lua2
-rw-r--r--lua/mason-core/functional/list.lua15
-rw-r--r--lua/mason-core/functional/logic.lua12
3 files changed, 29 insertions, 0 deletions
diff --git a/lua/mason-core/functional/init.lua b/lua/mason-core/functional/init.lua
index 153c40aa..9b52047c 100644
--- a/lua/mason-core/functional/init.lua
+++ b/lua/mason-core/functional/init.lua
@@ -62,6 +62,7 @@ _.take = list.take
_.drop = list.drop
_.drop_last = list.drop_last
_.reduce = list.reduce
+_.split_every = list.split_every
---@module "mason-core.functional.relation"
local relation = lazy_require "mason-core.functional.relation"
@@ -80,6 +81,7 @@ _.if_else = logic.if_else
_.is_not = logic.is_not
_.complement = logic.complement
_.cond = logic.cond
+_.default_to = logic.default_to
---@module "mason-core.functional.number"
local number = lazy_require "mason-core.functional.number"
diff --git a/lua/mason-core/functional/list.lua b/lua/mason-core/functional/list.lua
index 8c216c4d..275bc61a 100644
--- a/lua/mason-core/functional/list.lua
+++ b/lua/mason-core/functional/list.lua
@@ -269,4 +269,19 @@ _.reduce = fun.curryN(function(fn, acc, list)
return acc
end, 3)
+---@generic T
+---@param n integer
+---@param list T[]
+---@return T[][]
+_.split_every = fun.curryN(function(n, list)
+ assert(n > 0, "n needs to be greater than 0.")
+ local res = {}
+ local idx = 1
+ while idx <= #list do
+ table.insert(res, { unpack(list, idx, idx + n - 1) })
+ idx = idx + n
+ end
+ return res
+end, 2)
+
return _
diff --git a/lua/mason-core/functional/logic.lua b/lua/mason-core/functional/logic.lua
index 125a94ee..79e02361 100644
--- a/lua/mason-core/functional/logic.lua
+++ b/lua/mason-core/functional/logic.lua
@@ -69,4 +69,16 @@ _.cond = fun.curryN(function(predicate_transformer_pairs, value)
end
end, 2)
+---@generic T
+---@param default_val T
+---@param val T?
+---@return T
+_.default_to = fun.curryN(function(default_val, val)
+ if val ~= nil then
+ return val
+ else
+ return default_val
+ end
+end, 2)
+
return _