模組解[]
--[=[

本模块由[[Template:Lua]]调用
暂无模块调用
/****************************/
本模組由[[Template:Lua]]調用
暫無模組調用

]=]--

local yesno = require('Module:Yesno')
local mList = require('Module:List')
local mTableTools = require('Module:TableTools')
local mMessageBox = require('Module:Message box')

local p = {}

function p.main(frame)
	local origArgs = frame:getParent().args
	local args = {}
	for k, v in pairs(origArgs) do
		v = v:match('^%s*(.-)%s*$')
		if v ~= '' then
			args[k] = v
		end
	end
	return p._main(frame, args)
end

function p._main(frame, args)
	local modules = mTableTools.compressSparseArray(args)
	local box = p.renderBox(modules)
	local trackingCategories = p.renderTrackingCategories(args, modules)
	return box .. trackingCategories
end
-- if action=edit 
function p.main2(frame)
	local origArgs = frame:getParent().args
	local args = {}
	for k, v in pairs(origArgs) do
		v = v:match('^%s*(.-)%s*$')
		if v ~= '' then
			args[k] = v
		end
	end
	local modules = mTableTools.compressSparseArray(args)
	return p.renderBox(modules)
end
--end

function p.renderBox(modules)
	local boxArgs = {}
	if #modules < 1 then
		boxArgs.text = '<strong class="error">錯誤:無寫模組名</strong>'
	else
		local moduleLinks = {}
		for i, module in ipairs(modules) do
			moduleLinks[i] = string.format('%s', module)
			moduleLinks[i] = '[[:Module:' .. mw.title.new(moduleLinks[i]).text .. ']]'
			local maybeSandbox = mw.title.new(module .. '/sandbox')
			if maybeSandbox.exists then
				moduleLinks[i] = moduleLinks[i] .. string.format('([[:%s|沙盤]])', maybeSandbox.fullText)
			end
		end
		local moduleList = mList.makeList('bulleted', moduleLinks)
		boxArgs.text = '呢個' .. 
			(mw.title.getCurrentTitle():inNamespaces(828,829) and '模組' or '模') ..
			'用到[[Wikipedia:Lua|Lua語言]]:\n' .. moduleList
	end
	boxArgs.type = 'notice'
	boxArgs.small = true
	boxArgs.image = '[[File:Lua-Logo.svg|30px|alt=|link=]]'
	return mMessageBox.main('mbox', boxArgs)
end

function p.renderTrackingCategories(args, modules, titleObj)
	if yesno(args.nocat) then
		return ''
	end
	
	local cats = {}
	
	-- 错误分类
	if #modules < 1 then
		cats[#cats + 1] = '有錯嘅Lua模'
	end
	
	-- Lua templates category
	titleObj = titleObj or mw.title.getCurrentTitle()
	local subpageBlacklist = {
		doc = true,
		sandbox = true,
		sandbox2 = true,
		testcases = true
	}
	subpageBlacklist["解"] = true
	if titleObj.namespace == 10 
		and not subpageBlacklist[titleObj.subpageText]
	then
		local category = args.category
		if not category then
			local categories = {
				['Module:String'] = '基於String模組嘅模',
				--['Module:Math'] = '基於Math模組嘅模',
				--['Module:BaseConvert'] = '基於BaseConvert模組嘅模',
				--['Module:Citation'] = '基於Lua嘅引用模'
			}
			categories['Module:Citation/CS1'] = categories['Module:Citation']
			category = modules[1] and categories[modules[1]]
			category = category or 'x'
		end
		cats[#cats + 1] = category
		local protLevels = {
			autoconfirmed = 1,
			extendedconfirmed = 2,
			templateeditor = 3,
			sysop = 4
		}
		local currentProt = titleObj.protectionLevels["edit"][1]
		if currentProt == nil then currentProt = 0 else currentProt = protLevels[currentProt] end
		for i, module in ipairs(modules) do
			if mw.title.new(module).protectionLevels["edit"] then
				local moduleProt = mw.title.new(module).protectionLevels["edit"][1]
				if moduleProt == nil then moduleProt = 0 else moduleProt = protLevels[moduleProt] end
				if moduleProt < currentProt then
					cats[#cats + 1] = "基於受保護Lua模組嘅模"
					break
				end
			end
		end
	end
	
	for i, cat in ipairs(cats) do
		cats[i] = string.gsub(string.format('[[Category:%s]]', cat), '%[%[Category:x%]%]', '')
	end
	return table.concat(cats) .. '[[Category:基於Lua嘅模]]'
end

return p