Module:glossary

Revision as of 16:31, 24 March 2021 by Sware (talk | contribs) (Created page with "local export = {} local gsub = mw.ustring.gsub function format_def (term, definition) local anchor = gsub(term, "%[%[([^%]]+)%]%]", "%1") -- Remove wikilinks anchor = gsub...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)


local export = {}

local gsub = mw.ustring.gsub

function format_def (term, definition)
	local anchor = gsub(term, "%[%[([^%]]+)%]%]", "%1") -- Remove wikilinks
	anchor = gsub(anchor, "^%w+:", "") -- Remove interwiki prefixes
	
	return "; <span id=\""..anchor.."\">"..term.."</span>\n: "..definition
end

function export.def (frame)
	local params = {
		[1] = { required = true, default = "", },
		[2] = { required = true, default = "", },
	}
	
	local args = require("Module:parameters").process(frame:getParent().args, params)
	
	local term = args[1]
	local definition = args[2]
	
	return format_def (term, definition)
end

function export.link(frame)
	local args = frame:getParent().args
	for k, v in pairs(args) do
		if not (k == 1 or k == 2) then
			require "Module:debug".track "glossary/invalid argument"
			require "Module:debug".track("glossary/invalid argument/" .. k)
			mw.log("invalid argument in {{glossary}}: " .. k)
		end
	end
	
	local anchor, text = args[1] or "", args[2]
	if text and text:match "^%s*$" then
		text = nil
	end
	
	-- This won't work if the initial letter is non-ASCII.
	local lower_anchor = anchor:lower()
	
	local data = mw.loadData("Module:glossary/data")
	if data[anchor] then
		return "[[wikt:Appendix:Glossary#" .. anchor .. "|" .. (text or anchor) .. "]]"
	else
		local link = "[[wikt:Appendix:Glossary#" .. lower_anchor .. "|" .. (text or anchor) .. "]]"
		if data[lower_anchor] or lower_anchor:find "^%s*$" then
			return link
		else
			mw.log("The anchor " .. lower_anchor
				.. (lower_anchor ~= anchor and " or " .. anchor or "")
				.. " does not exist in Appendix:Glossary.")
			return link
		end
	end
end

return export