Module:vro-nominals
Appearance
- The following documentation is located at Module:vro-nominals/documentation. [edit] Categories were auto-generated by Module:module categorization. [edit]
- Useful links: subpage list • links • transclusions • testcases • sandbox
local m_utilities = require("Module:utilities")
local m_links = require("Module:links")
local export = {}
local lang = require("Module:languages").getByCode("vro")
-- Functions that do the actual inflecting by creating the forms of a basic term.
local inflections = {}
-- The main entry point.
-- This is the only function that can be invoked from a template.
function export.show(frame)
local infl_type = frame.args[1] or error("Inflection type has not been specified. Please pass parameter 1 to the module invocation")
local args = frame:getParent().args
if not inflections[infl_type] then
error("Unknown inflection type '" .. infl_type .. "'")
end
local data = {forms = {}, title = nil, categories = {}}
-- Generate the forms
inflections[infl_type](args, data)
-- Postprocess
postprocess(args, data)
if args["nosg"] then
table.insert(data.categories, "et-decl with nosg")
end
if args["nopl"] then
table.insert(data.categories, "et-decl with nopl")
end
if args["type"] then
table.insert(data.categories, "et-decl with type")
end
return make_table(data) .. m_utilities.format_categories(data.categories, lang)
end
--[=[
Inflection functions
]=]--
local stem_endings = {}
-- Singular
stem_endings["nom_sg"] = {{stem = "nom_sg", ending = ""}}
stem_endings["gen_sg"] = {{stem = "gen_sg", ending = ""}}
stem_endings["par_sg"] = {{stem = "par_sg", ending = ""}}
stem_endings["ill_sg"] = {{stem = "ill_sg", ending = ""}}
stem_endings["ine_sg"] = {{stem = "gen_sg", ending = "n"}, {stem = "gen_sg", ending = "hn"}}
stem_endings["ela_sg"] = {{stem = "gen_sg", ending = "st"}}
stem_endings["all_sg"] = {{stem = "gen_sg", ending = "lõ"}}
stem_endings["ade_sg"] = {{stem = "gen_sg", ending = "l"}}
stem_endings["abl_sg"] = {{stem = "gen_sg", ending = "lt"}}
stem_endings["tra_sg"] = {{stem = "gen_sg", ending = "s"}}
stem_endings["ter_sg"] = {{stem = "gen_sg", ending = "niq"}}
stem_endings["abe_sg"] = {{stem = "gen_sg", ending = "ldaq"}}
stem_endings["com_sg"] = {{stem = "gen_sg", ending = "gaq"}}
-- Plural
stem_endings["nom_pl"] = {{stem = "gen_sg", ending = "q"}}
stem_endings["gen_pl"] = {{stem = "gen_pl", ending = ""}}
stem_endings["par_pl"] = {{stem = "par_pl", ending = ""}}
stem_endings["ill_pl"] = {{stem = "ill_pl", ending = ""}}
stem_endings["ine_pl"] = {{stem = "all_pl", ending = "n"}, {stem = "all_pl", ending = "hn"}}
stem_endings["ela_pl"] = {{stem = "all_pl", ending = "st"}}
stem_endings["all_pl"] = {{stem = "all_pl", ending = "lõ"}}
stem_endings["ade_pl"] = {{stem = "all_pl", ending = "l"}}
stem_endings["abl_pl"] = {{stem = "all_pl", ending = "lt"}}
stem_endings["tra_pl"] = {{stem = "all_pl", ending = "s"}}
stem_endings["ter_pl"] = {{stem = "all_pl", ending = "niq"}}
stem_endings["abe_pl"] = {{stem = "all_pl", ending = "ldaq"}}
stem_endings["com_pl"] = {{stem = "gen_pl", ending = "gaq"}}
-- Make a copy of the endings, with front vowels
stem_endings = {["a"] = stem_endings, ["ä"] = mw.clone(stem_endings)}
for form_key, subforms in pairs(stem_endings["ä"]) do
for _, form in pairs(subforms) do
form.ending = mw.ustring.gsub(form.ending, "([aouõ])", {["a"] = "ä", ["o"] = "ö", ["u"] = "ü", ["õ"] = "e"})
end
end
-- Create forms based on each stem, by adding endings to it
local function process_stems(data, stems, vh)
-- For each of the case-and-number combinations that is defined above...
for form_key, subforms in pairs(stem_endings[vh]) do
--- ...and each subform defined for it
for _, form in ipairs(subforms) do
-- If the required stem has been provided, then...
if stems[form.stem] and #stems[form.stem] > 0 then
if not data.forms[form_key] then
data.forms[form_key] = {}
end
-- ...add the ending to each provided stem
for _, stem in ipairs(stems[form.stem]) do
table.insert(data.forms[form_key], stem .. form.ending)
end
end
end
end
end
local function get_param(args, first, prefix)
local param = args[first]; if param == "" then param = nil end
if not param then
return {mw.title.getCurrentTitle().nsText == "Template" and "{{{" .. first .. "}}}" or nil}
end
local ret = {param}
local i = 2
while args[prefix .. i] do
param = args[prefix .. i]; if param == "" then param = nil end
table.insert(ret, param)
i = i + 1
end
return ret
end
inflections["stems"] = function(args, data)
local vh = args[1] or (mw.title.getCurrentTitle().nsText == "Template" and "a"); if not (vh == "a" or vh == "ä") then error("Parameter 9 must be \"a\" or \"ä\".") end
local stems = {}
stems["nom_sg"] = get_param(args, 2, "nom_sg")
stems["gen_sg"] = get_param(args, 3, "gen_sg")
stems["par_sg"] = get_param(args, 4, "par_sg")
stems["ill_sg"] = get_param(args, 5, "ill_sg")
stems["gen_pl"] = get_param(args, 6, "gen_pl")
stems["par_pl"] = get_param(args, 7, "par_pl")
stems["ill_pl"] = get_param(args, 8, "ill_pl")
stems["all_pl"] = get_param(args, 9, "all_pl")
process_stems(data, stems, vh)
end
-- Helper functions
function postprocess(args, data)
local n = args["n"]; if n == "" then n = nil end
if n == "pl" then
table.insert(data.categories, lang:getCanonicalName() .. " pluralia tantum")
end
-- TODO: This says "nouns", but this module is also used for adjectives!
if n == "sg" then
table.insert(data.categories, lang:getCanonicalName() .. " uncountable nouns")
end
for key, form in pairs(data.forms) do
-- Do not show singular or plural forms for nominals that don't have them
if (n == "pl" and key:find("_sg$")) or (n == "sg" and key:find("_pl$")) then
form = nil
end
data.forms[key] = form
end
-- Check if the lemma form matches the page name
local lemma_key = n == "pl" and "nom_pl" or "nom_sg"
if data.forms[lemma_key] and data.forms[lemma_key][1] and (lang:makeEntryName(data.forms[lemma_key][1])) ~= mw.title.getCurrentTitle().text then
table.insert(data.categories, lang:getCanonicalName() .. " entries with inflection not matching pagename")
end
end
-- Make the table
function make_table(data)
local function show_form(form)
if not form then
return "—"
elseif type(form) ~= "table" then
error("a non-table value was given in the list of inflected forms.")
end
local ret = {}
for key, subform in ipairs(form) do
table.insert(ret, m_links.full_link({lang = lang, term = subform}))
end
return table.concat(ret, "<br/>")
end
local function repl(param)
if param == "lemma" then
return m_links.full_link({lang = lang, alt = mw.title.getCurrentTitle().text}, "term")
elseif param == "info" then
return data.title and " (" .. data.title .. ")" or ""
else
return show_form(data.forms[param])
end
end
local wikicode = [=[<div class="NavFrame" style="width: 40%">
<div class="NavHead" style="background:var(--wikt-palette-blue-2,#ccccff);">Inflection of {{{lemma}}}{{{info}}}</div>
<div class="NavContent">
{| class="inflection-table" style="width:100%; border:solid 1px var(--wikt-palette-blue-2,#ccccff); text-align:left;" cellspacing="1" cellpadding="2"
|- style="background:var(--wikt-palette-blue-2,#ccccff);vertical-align:top;"
! style="width:30%;" |
! style="width:35%;" | singular
! style="width:35%;" | plural
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | nominative
| {{{nom_sg}}}
| {{{nom_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | accusative
| {{{gen_sg}}}
| {{{nom_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | genitive
| {{{gen_sg}}}
| {{{gen_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | partitive
| {{{par_sg}}}
| {{{par_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | illative
| {{{ill_sg}}}
| {{{ill_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | inessive
| {{{ine_sg}}}
| {{{ine_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | elative
| {{{ela_sg}}}
| {{{ela_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | allative
| {{{all_sg}}}
| {{{all_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | adessive
| {{{ade_sg}}}
| {{{ade_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | ablative
| {{{abl_sg}}}
| {{{abl_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | translative
| {{{tra_sg}}}
| {{{tra_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | terminative
| {{{ter_sg}}}
| {{{ter_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | abessive
| {{{abe_sg}}}
| {{{abe_pl}}}
|- style="background:var(--wikt-palette-blue-0,#f2ffff);vertical-align:top;"
! style="background:var(--wikt-palette-blue-2,#ccccff);" | comitative
| {{{com_sg}}}
| {{{com_pl}}}
|}
</div>
</div>]=]
return mw.ustring.gsub(wikicode, "{{{([a-z0-9_]+)}}}", repl)
end
return export