Homepage
Games
News
News βΎ
All
Transfers
Drama
Business
Sponsors
Mergers
Investors
Hires
Companies
More
People
Tournaments
Brands
Brands βΎ
Companies
Organizations
Sponsors
Other
Locations
Search
Editing
Module:Table
From TwogPedia
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
local Table = {} function Table.randomize(tbl) math.randomseed(os.time()) for i = #tbl, 2, -1 do local j = math.random(i) tbl[i], tbl[j] = tbl[j], tbl[i] end return tbl end function Table.size(tbl) local i = 0 for _ in pairs(tbl) do i = i + 1 end return i end function Table.includes(tbl, value) for _, entry in ipairs(tbl) do if entry == value then return true end end return false end function Table.filter(tbl, predicate, argument) local filteredTbl = {} local foundMatches = 1 for _, entry in pairs(tbl) do if predicate(entry, argument) then filteredTbl[foundMatches] = entry foundMatches = foundMatches + 1 end end return filteredTbl end function Table.isEmpty(tbl) if tbl == nil then return true end -- luacheck: push ignore --it is intended that the loop is executed at most once for _, _ in pairs(tbl) do return false end -- luacheck: pop return true end function Table.isNotEmpty(tbl) return not Table.isEmpty(tbl) end function Table.copy(tbl) local result = {} for key, entry in pairs(tbl) do result[key] = entry end return result end --[[ Recursively copies a table. Specifically: for each entry, the value is deep copied and the key is not. Entries provided by the __pairs metamethod are copied. Metatables are not copied (unless enabled by options.copyMetatable). options.copyMetatable If enabled, deep copies the metatable of tables. Disabled by default. options.reuseRef If a table reference exists at two locations in the input, then this option will allow the locations to share a reference in the output. Enabled by default. ]] function Table.deepCopy(tbl_, options) options = options or {} assert(type(tbl_) == 'table', 'Table.deepCopy: Input must be a table') local function deepCopy(tbl) local result = {} for key, value in pairs(tbl) do result[key] = type(value) == 'table' and deepCopy(value) or value end if options.copyMetatable then local metatable = getmetatable(tbl) if type(metatable) == 'table' then setmetatable(result, deepCopy(metatable)) end end return result end if options.reuseRef ~= false then deepCopy = require('Module:FnUtil').memoize(deepCopy) end return deepCopy(tbl_) end --[[ Determines whether two tables are equal, by comparing their entries. Table values are compared recursively. ]] function Table.deepEquals(xTable, yTable) local Logic = require('Module:Logic') assert(type(xTable) == 'table', 'Table.deepEquals: First argument must be a table') assert(type(yTable) == 'table', 'Table.deepEquals: Second argument must be a table') for key, value in pairs(xTable) do if not Logic.deepEquals(value, yTable[key]) then return false end end for key, _ in pairs(yTable) do if xTable[key] == nil then return false end end return true end --[[ Copies entries from the second table into the first table, overriding existing entries. The first table is mutated in the process. Can be called with more than two tables. The additional tables are merged into the first table in succession. ]] function Table.mergeInto(target, ...) local objs = Table.pack(...) for i = 1, objs.n do if type(objs[i]) == 'table' then for key, value in pairs(objs[i]) do target[key] = value end end end return target end --[[ Creates a table with entries merged from the input tables, with entries from the later tables given precedence. Input tables are not mutated. ]] function Table.merge(...) return Table.mergeInto({}, ...) end --[[ Recursively merges entries from the second table into the first table, overriding existing entries. The first table is mutated in the process. Can be called with more than two tables. The additional tables are merged into the first table in succession. All tables except the last table may be mutated. Example: Table.deepMergeInto({a = {x = 3, y = 4}}, {a = {y = 5}}) -- Returns {a = {x = 3, y = 5}} ]] function Table.deepMergeInto(target, ...) local tbls = Table.pack(...) for i = 1, tbls.n do if type(tbls[i]) == 'table' then for key, value in pairs(tbls[i]) do if type(target[key]) == 'table' and type(value) == 'table' then Table.deepMergeInto(target[key], value) else target[key] = value end end end end return target end --[[ Applies a function to each entry in a table and places the results as entries in a new table. Example: Table.map({a = 3, b = 4, c = 5}, function(k, v) return 2 * v, k end) -- Returns {6 = 'a', 8 = 'b', 10 = 'c'} ]] function Table.map(xTable, f) local yTable = {} for xKey, xValue in pairs(xTable) do local yKey, yValue = f(xKey, xValue) yTable[yKey] = yValue end return yTable end --[[ Extracts prefixed keys interleaved with numeric indexes from an arguments table, and applies a transform to each key or index. Used for template calls that support both prefixed and indexed params. See Module:ParticipantTable/Starcraft, Module:GroupTableLeague for examples of how it is used. Example: In the template call {{Foo |A |p2=B |C |player4=D }} Table.mapArgumentsByPrefix(args, {'p', 'player'}, f) will invoke f(1, 1) f('p2', 2, 'p') f(2, 3) f('player4', 4, 'player') ]] function Table.mapArgumentsByPrefix(args, prefixes, f) local function indexFromKey(key) local prefix, index = key:match('^([%a_]+)(%d+)$') if Table.includes(prefixes, prefix) then return tonumber(index), prefix else return nil end end return Table.mapArguments(args, indexFromKey, f) end --[[ Extracts keys based on a passed `indexFromKey` function interleaved with numeric indexes from an arguments table, and applies a transform to each key or index. Most common use-case will be `Table.mapArgumentsByPrefix` where the `indexFromKey` function retrieves keys based on a prefix. ]] function Table.mapArguments(args, indexFromKey, f) local entriesByIndex = {} -- Non-numeric args for key, _ in pairs(args) do local function post(index, ...) if index and not entriesByIndex[index] then entriesByIndex[index] = f(key, index, ...) end end if type(key) == 'string' then post(indexFromKey(key)) end end -- Numeric index entries fills in gaps of prefixN= entries local entryIndex = 1 for argIndex = 1, math.huge do if not args[argIndex] then break end while entriesByIndex[entryIndex] do entryIndex = entryIndex + 1 end entriesByIndex[entryIndex] = f(argIndex, entryIndex) end return entriesByIndex end --[[ Applies a function to each value in a table and places the results in a new table under the same keys. Example: Table.mapValues({1, 2, 3}, function(x) return 2 * x end) -- Returns {2, 4, 6} ]] function Table.mapValues(xTable, f) local yTable = {} for xKey, xValue in pairs(xTable) do yTable[xKey] = f(xValue) end return yTable end --[[ Whether all entries of a table satisfy a predicate. ]] function Table.all(tbl, predicate) for key, value in pairs(tbl) do if not predicate(key, value) then return false end end return true end --[[ Whether any entry of a table satisfies a predicate. ]] function Table.any(tbl, predicate) for key, value in pairs(tbl) do if predicate(key, value) then return true end end return false end --[[ Groups entries of a table according to a grouping function. Example: local function parity(_, x) return x % 2 end Table.groupBy({a = 3, b = 4, c = 5}, parity) -- Returns { 0 = {b = 4}, 1 = {a = 3, c = 5}, } ]] function Table.groupBy(tbl, f) local groups = {} for key, value in pairs(tbl) do local groupKey = f(key, value) if not groups[groupKey] then groups[groupKey] = {} end groups[groupKey][key] = value end return groups end -- Removes a key from a table and returns its value. function Table.extract(tbl, key) local value = tbl[key] tbl[key] = nil return value end function Table.getByPath(tbl, path) for _, fieldName in ipairs(path) do tbl = tbl[fieldName] end return tbl end function Table.getByPathOrNil(tbl, path) for _, fieldName in ipairs(path) do if type(tbl) ~= 'table' then return nil end tbl = tbl[fieldName] end return tbl end function Table.setByPath(tbl, path, value) for i = 1, #path - 1 do if tbl[path[i]] == nil then tbl[path[i]] = {} end tbl = tbl[path[i]] end tbl[path[#path]] = value end --[[ Returns the unique key in a table. Returns nil if the table is empty or has multiple keys. ]] function Table.uniqueKey(tbl) local key0 = nil for key, _ in pairs(tbl) do if key0 ~= nil then return nil end key0 = key end return key0 end --[[ Returns the entries of a table as an array of key value pairs. The ordering of the array is not specified. ]] function Table.entries(tbl) local entries = {} for key, value in pairs(tbl) do table.insert(entries, {key, value}) end return entries end -- Polyfill of lua 5.2 table.pack function Table.pack(...) return {n = select('#', ...), ...} end -- -- iterator functions -- Table.iter = {} -- iterate over table in a sorted order function Table.iter.spairs(tbl, order) -- collect the keys local keys = {} for k in pairs(tbl) do keys[#keys+1] = k end -- if order function given, sort by it by passing the table and keys a, b, -- otherwise just sort the keys if order then table.sort(keys, function(a,b) return order(tbl, a, b) end) else table.sort(keys) end -- return the iterator function local i = 0 return function() i = i + 1 if keys[i] then return keys[i], tbl[keys[i]] end end end --[[ Iterates over table entries whose keys are prefixed numbers. The entries are visited in order, starting from 1. The iteration stops upon a skipped number. Example: local args = { p1 = {}, p2 = {}, p3 = {}, foo = {}, p10 = {}, } for key, player, index in Table.iter.pairsByPrefix(args, 'p') do mw.log(key) end will print out 'p1 p2 p3' ]] function Table.iter.pairsByPrefix(tbl, prefix) local i = 1 return function() local key = prefix .. i local value = tbl[key] i = i + 1 if value then return key, value, (i - 1) else return nil end end end function Table.iter.forEach(tbl, lambda) for _, item in ipairs(tbl) do lambda(item) end end function Table.iter.forEachIndexed(tbl, lambda) for index, item in ipairs(tbl) do lambda(index, item) end end function Table.iter.forEachPair(tbl, lambda) for key, val in pairs(tbl) do lambda(key, val) end end return Table
Summary:
Please note that all contributions to TwogPedia may be edited, altered, or removed by other contributors. If you do not want your writing to be edited mercilessly, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource (see
TwogPedia:Copyrights
for details).
Do not submit copyrighted work without permission!
Cancel
Editing help
(opens in new window)
Preview page with this template
Template used on this page:
Module:Table/doc
(
edit
)
No categories
Edit