模块:Array

来自Rizline中文维基

可在模块:Array/doc创建此模块的帮助文档

local p = {}
local f = mw.getCurrentFrame()

local function stringToArray(str, separator, wrapTag, keepBlank, requireSort)
	local arr = {}
	local i = 1
	for v in mw.text.gsplit(str, separator) do
		if v ~= '' or keepBlank then
			if wrapTag ~= '' then
				arr[i] = f:extensionTag(wrapTag, v)
			else
				arr[i] = v
			end
		end
		i = i + 1
	end
	if requireSort then
		table.sort(arr)
	end
	return arr
end

local function tableToArray(tbl, wrapTag, keepBlank, requireSort)
	local arr = {}
	for k, v in pairs(tbl) do
		if type(k) == 'number' and (v ~= '' or keepBlank) then
			if wrapTag ~= '' then
				arr[k] = f:extensionTag(wrapTag, v)
			else
				arr[k] = v
			end
		end
	end
	if requireSort then
		table.sort(arr)
	end
	return arr
end

function p.main()
	local args = require('Module:ProcessArgs').merge(true)
	return p.array(args)
end

function p.array(args)
	local wrapTag = args.wrap or ''
	local delimiter = args.delimiter or args.d or ''
	local keepBlank = args.keepblank
	local requireSort = args.sort
	local outputPrefix = args.prefix or ''
	local outputSuffix = args.suffix or ''
	local arr
	if args.mode == 'single' then
		arr = stringToArray(args[1], args.sep or ',', wrapTag, keepBlank, requireSort)
	else
		arr = tableToArray(args, wrapTag, keepBlank, requireSort)
	end

	local result
	if delimiter == 'pretty' then
		result = mw.text.listToText(arr)
	elseif delimiter == 'newline' or delimiter == 'br' then
		result = table.concat(arr, '<br>')
	elseif delimiter == 'list' or delimiter == 'list-newline'
		or delimiter == 'bullet' or delimiter == '*' then
			local listLevel = args['list-level'] or '**'
			result = table.concat(arr, '\n' .. listLevel)
	else
		result = table.concat(arr, delimiter)
	end

	return outputPrefix .. result .. outputSuffix
end

return p