Difference between revisions of "Module:ApplyPattern"
Jump to navigation
Jump to search
m |
m |
||
Line 31: | Line 31: | ||
local newSep = '' | local newSep = '' | ||
− | if #frame.args > 3 then | + | if #paris(frame.args) > 3 then |
newSep = frame.args[4] | newSep = frame.args[4] | ||
end | end |
Revision as of 20:08, 21 August 2019
Custom module to apply either some wiki markup or a template to each item in a comma delimited list. Look at Template:Class for examples.
local p = {} function split(instr,sep) local sep, fields = sep or ":", {} local pattern = string.format("([^%s]+)", sep) string.gsub(instr, pattern, function(c) fields[#fields+1] = c end) return fields end function trim(s) return (s:gsub("^%s*(.-)%s*$", "%1")) end function p.apply(frame) local list = frame.args[1] local pattern = frame.args[2] local result = {} local sep = ',' for key,entry in pairs(split(list,sep)) do result[#result+1] = string.gsub(pattern, '%%pattern%%', trim(entry)) end return table.concat(result,"") end function p.applyTemplate(frame) local list = frame.args[1] local template = frame.args[2] local substArg = frame.args[3] local newSep = '' if #paris(frame.args) > 3 then newSep = frame.args[4] end local result = {} local sep = ',' for key,entry in pairs(split(list,sep)) do local argTable = {} argTable[substArg] = entry result[#result+1] = frame:expandTemplate{title = template, args = argTable} end return table.concat(result,newSep) end return p