Module:maintenance category

From Linguifex
Jump to navigation Jump to search

Documentation for this module may be created at Module:maintenance category/doc

local format_categories = require("Module:utilities").format_categories
local match = string.match
local process_params = require("Module:parameters").process

local title

local export = {}

local function ret(name, cat)
	return cat and format_categories({name}, nil, "-", nil, true) or name
end

function export.get_category(name, cat)
	title = title or mw.title.getCurrentTitle()
	-- All talkpages.
	if title.isTalkPage then
		return ret(name .. "/hidden", cat)
	end
	local namespace = title.namespace
	-- User:, Thread:, and Summary:
	if namespace == 2 or namespace == 90 or namespace == 92 then
		return ret(name .. "/hidden", cat)
	-- Template: and Module:.
	elseif not (namespace == 10 or namespace == 828) then
		return ret(name, cat)
	end
	local title_text = title.text
	if (
		-- Template:User: and Module:User:.
		match(title_text, "^User:") or
		-- Any template/module sandboxes (which can be numbered and/or followed by further subpages), including any templates/modules with the name sandbox.
		match(title_text, "%f[^%z/][sS][aA][nN][dD][bB][oO][xX] ?%d*%f[%z/]") or
		-- Any template/module testcases (which can be numbered and/or followed by further subpages).
		match(title_text, "/[tT][eE][sS][tT][cC][aA][sS][eE][sS]? ?%d*%f[%z/]")
	) then
		return ret(name .. "/hidden", cat)
	end
	return ret(name, cat)
end

function export.template(frame)
	local args = process_params(frame:getParent().args, {
		[1] = {required = true, default = ""},
		["cat"] = {type = "boolean", default = false}
	})
	return export.get_category(args[1], args.cat)
end

return export