Module utils.table
Table utils.
Type utils.table
utils.table.copy(src, dst, overwrite) |
Copies a table from the source to destination table. |
utils.table.diff(t1, t2, norecurse) |
Produces a diff of two tables. |
utils.table.isArray(T) |
Checks if the table is regular array. |
utils.table.keys(T) |
Extracts the keys of a table into a list. |
utils.table.map(T, func, recursive, inplace) |
Executes a function on each element of a table. |
utils.table.pack(varargs) |
Packs a variable number of arguments into a table. |
utils.table.recursivePairs(t, prefix) |
Iterator that returns key/value pairs except walking through sub tables and concatenating the path in the key. |
utils.table.sortedPairs(t) |
Iterator that iterates on the table in key ascending order. |
Type utils.map
utils.map.multiPairs(t1, ...) |
Iterator that returns key/value on multiple tables. |
Type utils.table
Field(s)
- utils.table.copy(src, dst, overwrite)
-
Copies a table from the source to destination table.
The copy is recursive.
Parameters
-
src
: a table to be used as the source of the copy. -
dst
: a table to be used as the destination of the copy. -
overwrite
: boolean value, to enable overwrite of existing field in dst table.
Return value
the resulting dst table.
-
- utils.table.diff(t1, t2, norecurse)
-
Produces a diff of two tables.
Recursive diff by default.
Parameters
-
t1
: first table to compare. -
t2
: second table to compare. -
norecurse
: boolean value to disable recursive diff.
Return value
the diff result as a table.
Usage:
> t1 = { a = 1, b=3, c = "foo"} > t2 = { a = 1, b=3, c = "foo"} > :diff(t1, t2) = { } > t1 = { a = 1, b=3, c = "foo"} > t2 = { a = 1, b=4, c = "foo"} > :diff(t1, t2) = { "b" } > t1 = { a = 1, b=3, c = "foo"} > t2 = { a = 1, b=3} > :diff(t1, t2) = { "c" } > t1 = { b=3, c = "foo", d="bar"} > t2 = { a = 1, b=3, c = "foo"} > :diff(t1, t2) = { "a", "d" }
-
- utils.table.isArray(T)
-
Checks if the table is regular array.
Regular array is a table with only conscutive integer keys (no holes).
Parameter
-
T
: table to check.
Return value
true or false.
-
- utils.table.keys(T)
-
Extracts the keys of a table into a list.
Parameter
-
T
: the table to extract keys from.
Return value
a list of keys of T table.
-
- utils.table.map(T, func, recursive, inplace)
-
Executes a function on each element of a table.
If recursive is non false the map function will be called recursively.
If inplace is set to true, then the table is modified in place.
The function is called with key and value as a parameter.
Parameters
-
T
: the table to apply map on. -
func
: the function to call for each value of the map. -
recursive
: if non false, the map is executed recusively. -
inplace
: if non false, the table is modified in place.
Return value
the table with each value mapped by the function
Usage:
local data = { key1 = "val1", key2 = "val2"} local function foo(key, value) print("foo:" key, value) end map(data, foo) -> will print: foo: key1 val1 foo: key2 val2
-
- utils.table.pack(varargs)
-
Packs a variable number of arguments into a table.
This is a temporary function until we switch to Lua 5.2.
Returns a new table with all parameters stored into keys 1, 2, etc. and with a field "n" with the total number of parameters. Also returns, as a second result, the total number of parameters.
Note that the resulting table may not be a sequence.
Note that when loading utils.table module, this pack function is also added to global/std table module.
Parameter
-
varargs
: arguments to pack
Return value
a table that contains all the arguments followed by the number of arguments.
-
- utils.table.recursivePairs(t, prefix)
-
Iterator that returns key/value pairs except walking through sub tables and concatenating the path in the key.
This iterator break cycles: it does not recur. If it detects a cycle, the entry causing a cycle is ignored. However, if a table is repeated, its contents will be repeated by this function.
Parameters
-
t
: table to iterate. -
prefix
: path prefix to prepend to the key path returned.
Return value
iterator function.
Usage:
{toto={titi=1, tutu=2}, tata = 3, tonton={4, 5}} will iterate through ("toto.titi",1), ("toto.tutu",2), ("tata",3) ("tonton.1", 4), ("tonton.2"=5)
-
- utils.table.sortedPairs(t)
-
Iterator that iterates on the table in key ascending order.
Parameter
-
t
: table to iterate.
Return value
iterator function.
-
Type utils.map
Field(s)
- utils.map.multiPairs(t1, ...)
-
Iterator that returns key/value on multiple tables.
Parameters
-
t1
: first table to traverse. -
...
: additional tables to traverse.
Return value
iterator function.
-