local export = {}
local m_languages = require("Module:languages")
local scripts_module = "Module:scripts"
local rsplit = mw.text.split
local function categorize(lang, source, root, id)
local categories = {}
local root_suffix = " root " .. root .. (id and " (" .. id .. ")" or "")
if source then
root_suffix = "the " .. source:getCanonicalName() .. root_suffix
else
root_suffix = "the" .. root_suffix
end
if not lang then
return "Terms derived from " .. root_suffix
elseif source then
return lang:getCanonicalName() .. " terms derived from " .. root_suffix
else
return lang:getCanonicalName() .. " terms belonging to " .. root_suffix
end
end
function export.rootsee(frame)
local params = {
= {template_default = "en"},
= {template_default = "ine"},
= {template_default = "gʷem"},
= {},
= {}, -- one of "categories", "pages", "all" or "parents"; defaults to "all"; see ].
= {}, -- for testing and documentation pages
= {}, -- override the presence of a hyphen in Latin-script roots
}
local args = require("Module:parameters").process(frame:getParent().args, params)
local title
if args.pagename then -- for testing, doc pages, etc.
title = mw.title.new(args.pagename)
if not title then
error(("Bad value for pagename=: '%s'"):format(args.pagename))
end
else
title = mw.title.getCurrentTitle()
end
local function convert_plus(val)
if val == "+" then
return nil
else
return val
end
end
local lang = convert_plus(args)
if lang then
lang = m_languages.getByCode(lang, 1)
end
local source = convert_plus(args)
local orig_source = source
if source then
source = m_languages.getByCode(source, 2, nil, "allow family")
if source:hasType("family") then
source = source:getProtoLanguage()
if not source then
error(("Family '%s' has no proto-language"):format(args))
end
end
elseif lang then
source = lang
elseif title:inNamespace("Reconstruction") or title:inNamespace("Appendix") then
local langname = title.text:match("^(.-)/")
if not langname then
error(("Unable to infer source from pagename '%s' as it isn't doesn't have a current language in it (no slash)")
:format(title.fullText))
end
source = m_languages.getByCanonicalName(langname)
if not source then
error(("Unable to infer source from pagename '%s' as current language '%s' isn't recognized as a language name")
:format(title.fullText, langname))
end
else
error(("Unable to infer source from pagename '%s' as it isn't a Reconstruction or Appendix page"):format(
title.fullText))
end
local sourcecode = source:getCode()
local root = convert_plus(args)
if not root then
root = title.subpageText
-- If none of dest lang, source lang and root were given, we're being asked to display a category of the form
-- ] where `root` comes from the current page. If this
-- page is a Reconstruction page, make the root reconstructed even if the source language isn't
-- reconstruction-only. This is definitely an edge case but is parallel to the derivsee() code in
-- ].
if not lang and not orig_source and title:inNamespace("Reconstruction") and not root:find("^%*") then
root = "*" .. root
end
end
local hyphpos = args.hyphen
if hyphpos then
if hyphpos ~= "before" and hyphpos ~= "after" and hyphpos ~= "both" and hyphpos ~= "none" and hyphpos ~= "no" then
error(("|hyphen=%s should be 'before', 'after', 'both', 'none' or 'no'"):format(hyphpos))
end
if hyphpos == "no" then
hyphpos = "none"
end
end
if not hyphpos then
if not root:find(" ") and not root:find("%-") then
local is_latin = root:find("^$")
if not is_latin then
local sc = require(scripts_module).findBestScriptWithoutLang(root)
if sc and sc:getCode():find("Lat") then -- Latn, Latf, Latg, pjt-Latn
is_latin = true
end
end
if is_latin then
if sourcecode == "nv" then -- Navajo
hyphpos = "before"
elseif sourcecode == "pi" then -- Pali
hyphpos = "none"
else
hyphpos = "after"
end
end
end
end
local root_asterisk = not not root:find("^%*")
if hyphpos == "before" then
root = "-" .. root
elseif hyphpos == "after" then
root = root .. "-"
elseif hyphpos == "both" then
root = "-" .. root .. "-"
end
if source:hasType("reconstructed") and not root_asterisk then
root = "*" .. root
end
if lang and sourcecode == lang:getCode() then
source = nil
end
return frame:callParserFunction{
name = "#categorytree",
args = {
categorize(lang, source, root, args.id),
depth = 0,
class = '"columns-bg"',
mode = args.mode or "all",
hideprefix = "always",
showcount = "on",
}
}
end
return export