doc(g.table): Improve documentation

Signed-off-by: Lucas Schwiderski <lucas@lschwiderski.de>
This commit is contained in:
Lucas Schwiderski 2021-06-16 19:51:54 +02:00
parent b94cb51770
commit 16df93370f
No known key found for this signature in database
GPG Key ID: AA12679AAA6DF4D8
1 changed files with 31 additions and 20 deletions

View File

@ -39,27 +39,31 @@ function gtable.join(...)
return ret return ret
end end
--- Override elements in the first table by the one in the second. --- Override elements in the target table with values from the source table.
-- --
-- Note that this method doesn't copy entries found in `__index`. -- Note that this method doesn't copy entries found in `__index`.
-- Nested tables are copied by reference and not recursed into.
-- --
-- @tparam table t the table to be overriden -- @tparam table target The target table. Values from `source` will be copied
-- @tparam table set the table used to override members of `t` -- into this table.
-- @tparam[opt=false] bool raw Use rawset (avoid the metatable) -- @tparam table source The source table. Its values will be copied into
-- @treturn table t (for convenience) -- `target`.
-- @tparam[opt=false] bool raw If `true`, values will be assigned with `rawset`.
-- This will bypass metamethods on `target`.
-- @treturn table The target table.
-- @staticfct gears.table.crush -- @staticfct gears.table.crush
function gtable.crush(t, set, raw) function gtable.crush(target, source, raw)
if raw then if raw then
for k, v in pairs(set) do for k, v in pairs(source) do
rawset(t, k, v) rawset(target, k, v)
end end
else else
for k, v in pairs(set) do for k, v in pairs(source) do
t[k] = v target[k] = v
end end
end end
return t return target
end end
--- Pack all elements with an integer key into a new table. --- Pack all elements with an integer key into a new table.
@ -225,7 +229,8 @@ end
--- Clone a table. --- Clone a table.
-- --
-- @tparam table t The table to clone. -- @tparam table t The table to clone.
-- @tparam[opt=true] bool deep Create a deep clone? -- @tparam[opt=true] bool deep If `true`, recurse into nested tables to create
-- a deep clone.
-- @treturn table A clone of `t`. -- @treturn table A clone of `t`.
-- @staticfct gears.table.clone -- @staticfct gears.table.clone
function gtable.clone(t, deep) function gtable.clone(t, deep)
@ -306,17 +311,23 @@ function gtable.iterate(t, filter, start)
end end
end end
--- Merge items from one table to another one. --- Merge items from one table into another one.
-- --
-- @tparam table t The container table -- Note that this only considers the array part of `source` (same semantics
-- @tparam table set The mixin table. -- as `ipairs`).
-- @treturn table (for convenience). -- Nested tables are copied by reference and not recursed into.
--
-- @tparam table target The target table. Values from `source` will be copied
-- into this table.
-- @tparam table source The source table. Its values will be copied into
-- `target`.
-- @treturn table The target table.
-- @staticfct gears.table.merge -- @staticfct gears.table.merge
function gtable.merge(t, set) function gtable.merge(target, source)
for _, v in ipairs(set) do for _, v in ipairs(source) do
table.insert(t, v) table.insert(target, v)
end end
return t return target
end end
--- Update the `target` table with entries from the `new` table. --- Update the `target` table with entries from the `new` table.