Module:XfD old/sandbox

Source: Wikipedia, the free encyclopedia.

This is an old revision of this page, as edited by DannyS712 (talk | contribs) at 08:37, 1 May 2019 (frame:expandTemplate). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

local p = {}
local tableTools = require("Module:TableTools")
local ymd = require("Module:YMD to ISO")._main
local lang = mw.getContentLanguage()
local function getlog(name) 
	 return mw.ustring.match(name, "Log/(.*)")
end
function sortkey(name1, name2)
	local key1 = ymd(getlog(name1))
	local key2 = ymd(getlog(name2))
	return key1 > key2
end
function p._main(frame, makeoutput)
	local t = frame.args.title or frame:getParent():getTitle()
	local content = mw.title.new(t .. "/Old unclosed discussions"):getContent();
	local m = mw.ustring.gmatch(content, "* %[%[(" .. t .. "/Log/[^#]*)#%{%{anchorencode:([^}]*)")
	local seen = {}
	while true do
		local logpage, header = m()
		if not logpage then
			break
		end
		if seen[logpage] == nil then
			seen[logpage] = {}
		end
		seen[logpage][#seen[logpage]+1] = header
	end
	local out = ""
	for k, v in tableTools.sortedPairs(seen, sortkey) do
		out = out .. (makeoutput(k, v) or "")
	end
	return mw.text.trim(out)
end
function p.list(frame) 
	local function listoutput(k, v)  
		return "* [[" .. k .. "]] (" .. tostring(#v) .. " open) \n"
	end
	return (frame:expandTemplate{ title = 'div col' } .. "\n" .. p._main(frame, listoutput) .. "\n" .. frame:expandTemplate{ title = 'div col end' })
end
function p.onemonth(frame) 
	local month = frame.args.month
	if not month then
		error("|month= is required")
	elseif month ~= lang:formatDate("F Y",month) then
		error("Illegal month format")
	end
	local count = 0
	local function bymonthoutput(k, v)
		if lang:formatDate("F Y",ymd(getlog(k))) == month then
			count = count + #v
		end
	end
	p._main(frame, bymonthoutput)
	return count
end
function p.transclude(frame) 
	local function transoutput(k, v)
		local out = ""
		out = out .. "=== [[" .. k .. "|" .. getlog(k):sub(5) .. "]] ===\n"
		for _, discussion in pairs(v) do
			out = out .. "==== " .. discussion .. " ====\n"
			out = out .. frame:callParserFunction("#section-h", k, discussion)
			out = out .. "\n"
		end
		return out
	end
	return p._main(frame, transoutput)
end
function p.total(frame) 
	local total = 0
	local function dototal(k, v) 
		total = total + #v
	end
	p._main(frame, dototal)
	return total
end
return p