可在模組:languages/templates/doc建立此模組的說明文件

local export = {}

function export.exists(frame)
	local args = frame.args
	local lang = args[1] or error("Language code has not been specified. Please pass parameter 1 to the module invocation.")
	
	lang = require("Module:languages").getByCode(lang)
	
	if lang then
		return "1"
	else
		return ""
	end
end

local function getByCode(frame, allow_etym)
	local iparams = {
		[1] = {required = true},
		[2] = {required = true},
		[3] = {},
		[4] = {},
		[5] = {},
	}
	
	local iargs = require("Module:parameters").process(frame.args, iparams, nil, "languages/templates", "getByCode")
	local langcode = iargs[1]
	
	local lang = require("Module:languages").getByCode(langcode, true, allow_etym)
	
	return require("Module:language-like").templateGetByCode(lang, iargs,
		function(itemname)
			local list
			if itemname == "getWikimediaLanguages" then
				list = lang:getWikimediaLanguages()
			elseif itemname == "getScripts" then
				list = lang:getScriptCodes()
			elseif itemname == "getAncestors" then
				list = lang:getAncestors()
			end
			if list then
				local index = iargs[3]
				index = tonumber(index) or error("Please specify the numeric index of the desired item.")
				local retval = list[index]
				if retval then
					if type(retval) == "string" then
						return retval
					else
						return retval:getCode()
					end
				else
					return ""
				end
			end
			if itemname == "transliterate" then
				local text = iargs[3]
				local module_override = iargs[5]
				local sc = require("Module:scripts").getByCode(iargs[4], 4)
				return (lang:transliterate(text, sc, module_override)) or ""
			elseif itemname == "makeDisplayText" then
				local text = iargs[3]
				local sc = require("Module:scripts").getByCode(iargs[4], 4)
				return (lang:makeDisplayText(text, sc)) or ""
			elseif itemname == "makeEntryName" then
				local text = iargs[3]
				local sc = require("Module:scripts").getByCode(iargs[4], 4)
				return (lang:makeEntryName(text, sc)) or ""
			elseif itemname == "makeSortKey" then
				local text = iargs[3]
				local sc = require("Module:scripts").getByCode(iargs[4], 4)
				return (lang:makeSortKey(text, sc)) or ""
			elseif itemname == "countCharacters" then
				local text = iargs[3] or ""
				local sc = require("Module:scripts").getByCode(iargs[4], 4, "disallow nil")
				return sc:countCharacters(text)
			elseif itemname == "findBestScript" then
				local text = iargs[3] or ""
				return lang:findBestScript(text):getCode()
			end
		end
	)
end

-- Used by the following JS:
-- * [[WT:ACCEL]]
-- * [[WT:EDIT]]
-- * [[WT:NEC]]
function export.getByCode(frame)
	return getByCode(frame, false)
end

function export.getByCodeAllowEtym(frame)
	return getByCode(frame, true)
end

function export.getByCanonicalName(frame)
	local args = frame.args
	local langname = args[1] or error("Language name has not been specified. Please pass parameter 1 to the module invocation.")
	
	local lang = require("Module:languages").getByCanonicalName(langname)
	
	if lang then
		return lang:getCode()
	else
		return ""
	end
end

function export.getByName(frame)
	local args = frame.args
	local langname = args[1] or error("Language name has not been specified. Please pass parameter 1 to the module invocation.")
	
	local lang = require("Module:languages").getByName(langname)
	
	if lang then
		return lang:getCode()
	else
		return ""
	end
end

function export.makeEntryName(frame)
	local args = frame.args
	local langname = args[1] or error("Language name has not been specified. Please pass parameter 1 to the module invocation.")
	
	local lang = require("Module:languages").getByCode(langname)
	
	if lang then
		return lang:makeEntryName(args[2])
	else
		return ""
	end
end

function export.getCanonicalName(frame)
	local langCode, args
	if require("Module:yesno")(frame.args.parent) then
		args = frame:getParent().args
	else
		args = frame.args
	end
	langCode = args[1]
	
	if not langCode or langCode == "" then
		error("Supply a language code in parameter 1.")
	end
	
	return mw.loadData("Module:languages/code to canonical name")[langCode]
		or not args.return_if_invalid and "" or langCode
end

function export.getNonEtymological(frame)
	local langCode, args
	if require("Module:yesno")(frame.args.parent) then
		args = frame:getParent().args
	else
		args = frame.args
	end
	langCode = args[1]
	
	if not langCode or langCode == "" then
		error("Supply a language code in parameter 1.")
	end
	
	local lang = require("Module:languages").getByCode(langCode, nil, true)
	local nonEtym_lang = lang:getNonEtymological()
	
	return nonEtym_lang:getCode()
		or not args.return_if_invalid and "" or langCode
end

return export