From afc08188052f1b5a7ff40055b8ae0d49f228a5dd Mon Sep 17 00:00:00 2001 From: Ottatop Date: Thu, 20 Jul 2023 16:54:26 -0500 Subject: [PATCH] Merge tag.add and tag.add_table --- api/lua/output.lua | 7 +---- api/lua/tag.lua | 66 +++++++++++++++++++---------------------- api/lua/test_config.lua | 6 ++-- 3 files changed, 35 insertions(+), 44 deletions(-) diff --git a/api/lua/output.lua b/api/lua/output.lua index 0e7ef27..c7492bc 100644 --- a/api/lua/output.lua +++ b/api/lua/output.lua @@ -22,16 +22,11 @@ end ---Add tags to this output. See `tag.add`. ---@param ... string The names of the tags you want to add. +---@overload fun(self: self, tag_names: string[]) function op:add_tags(...) require("tag").add(self, ...) end ----Add tags to this output as a table. See `tag.add_table`. ----@param names string[] The names of the tags you want to add, as a table. -function op:add_tags_table(names) - require("tag").add_table(self, names) -end - ---Get this output's make. ---@return string|nil function op:make() diff --git a/api/lua/tag.lua b/api/lua/tag.lua index 1879085..d66b43e 100644 --- a/api/lua/tag.lua +++ b/api/lua/tag.lua @@ -83,13 +83,11 @@ end ----------------------------------------------------------- ----Add tags. +---Add tags to the specified output. --- ----If you need to add the names as a table, use `tag.add_table` instead. +---You can also do `output_object:add_tags(...)`. --- ----You can also do `op:add_tags(...)`. ---- ----### Example +---### Examples --- ---```lua ---local op = output.get_by_name("DP-1") @@ -97,40 +95,36 @@ end --- tag.add(op, "1", "2", "3", "4", "5") -- Add tags with names 1-5 ---end ---``` ----@param output Output The output you want these tags to be added to. ----@param ... string The names of the new tags you want to add. -function tag.add(output, ...) - local tag_names = table.pack(...) - tag_names["n"] = nil -- remove the length to make it a true array for serializing - - SendMsg({ - AddTags = { - output_name = output:name(), - tag_names = tag_names, - }, - }) -end - ----Like `tag.add`, but with a table of strings instead. ---- ----### Example ---- +---You can also pass in a table. ---```lua ----local tags = { "Terminal", "Browser", "Mail", "Gaming", "Potato" } ----local output = output.get_by_name("DP-1") ----if output ~= nil then ---- tag.add(output, tags) -- Add tags with the names above ----end +---local tags = {"Terminal", "Browser", "Code", "Potato", "Email"} +---tag.add(op, tags) -- Add tags with those names ---``` ---@param output Output The output you want these tags to be added to. ----@param names string[] The names of the new tags you want to add, as a table. -function tag.add_table(output, names) - SendMsg({ - AddTags = { - output_name = output:name(), - tag_names = names, - }, - }) +---@param ... string The names of the new tags you want to add. +---@overload fun(output: Output, tag_names: string[]) +function tag.add(output, ...) + local varargs = { ... } + if type(varargs[1]) == "string" then + local tag_names = varargs + tag_names["n"] = nil -- remove the length to make it a true array for serializing + + SendMsg({ + AddTags = { + output_name = output:name(), + tag_names = tag_names, + }, + }) + else + local tag_names = varargs[1] --[=[@as string[]]=] + + SendMsg({ + AddTags = { + output_name = output:name(), + tag_names = tag_names, + }, + }) + end end ---Toggle a tag on the specified output. If `output` isn't specified, toggle it on the currently focused output instead. diff --git a/api/lua/test_config.lua b/api/lua/test_config.lua index 0fc204b..c2756aa 100644 --- a/api/lua/test_config.lua +++ b/api/lua/test_config.lua @@ -138,9 +138,11 @@ require("pinnacle").setup(function(pinnacle) -- Tags --------------------------------------------------------------------------- output.connect_for_all(function(op) - op:add_tags("1", "2", "3", "4", "5") + -- op:add_tags("1", "2", "3", "4", "5") -- Same as tag.add(op, "1", "2", "3", "4", "5") - tag.toggle("1", op) + + local tags_table = { "Terminal", "Browser", "Code", "Email", "Potato" } + op:add_tags(tags_table) end) ---@type Layout[]