Module:qlu-nouns: Difference between revisions

From Linguifex
Jump to navigation Jump to search
No edit summary
No edit summary
 
(23 intermediate revisions by the same user not shown)
Line 4: Line 4:


local export = {}
local export = {}
local branch_links = {
["L"] = "[[Luthic|Standard Ravennese Luthic]]",
}
local decl_names = {
["a"] = "a-stem",
["o"] = "o-stem",
["o-N"] = "o-stem neuter",
["i"] = "i-stem",
["r"] = "r-stem",
["d"] = "d-stem",
["u"] = "u-stem",
["u-N"] = "u-stem neuter",
}


local decls = {}
local decls = {}


-- a-stem
decls["a"] = {
decls["a"] = {
params = {
params = { [1] = {} },
[1] = {},
},
}
}
setmetatable(decls["a"], {__call = function(self, args, data)
setmetatable(decls["a"], { __call = function(self, args, data)
data.forms["nom-sg"] = args[1] .. "a"
local r = args[1]
data.forms["nom-pl"] = args[1] .. "e"
data.forms["nom-sg"] = r .. "a"
data.forms["nom-pl"] = r .. "e"
data.forms["gen-sg"] = args[1] .. "e"
data.forms["gen-sg"] = r .. "e"
data.forms["gen-pl"] = args[1] .. "aro"
data.forms["gen-pl"] = r .. "aro"
data.forms["dat-sg"] = r .. "a"
data.forms["dat-sg"] = args[1] .. "a"
data.forms["dat-pl"] = r .. "evo"
data.forms["dat-pl"] = args[1] .. "evo"
data.forms["acc-sg"] = r .. "a"
data.forms["acc-pl"] = r .. "e"
data.forms["acc-sg"] = args[1] .. "a"
end })
data.forms["acc-pl"] = args[1] .. "as"
end
})


-- o-stem
decls["o"] = {
decls["o"] = {
params = {
params = { [1] = {} },
[1] = {},
},
}
}
setmetatable(decls["o"], {__call = function(self, args, data)
setmetatable(decls["o"], { __call = function(self, args, data)
data.forms["nom-sg"] = args[1] .. "u"
local r = args[1]
data.forms["nom-pl"] = args[1] .. "i"
data.forms["nom-sg"] = r .. "u"
data.forms["nom-pl"] = r .. "i"
data.forms["gen-sg"] = args[1] .. "i"
data.forms["gen-sg"] = r .. "i"
data.forms["gen-pl"] = args[1] .. "oro"
data.forms["gen-pl"] = r .. "oro"
data.forms["dat-sg"] = r .. "a"
data.forms["dat-sg"] = args[1] .. "a"
data.forms["dat-pl"] = r .. "evo"
data.forms["dat-pl"] = args[1] .. "evo"
data.forms["acc-sg"] = r .. "o"
data.forms["acc-pl"] = r .. "i"
data.forms["acc-sg"] = args[1] .. "o"
end })
data.forms["acc-pl"] = args[1] .. "os"
end
})


-- o-stem neuter
decls["o-N"] = {
decls["o-N"] = {
params = {
params = { [1] = {} },
[1] = {},
},
}
}
setmetatable(decls["o-N"], {__call = function(self, args, data)
setmetatable(decls["o-N"], { __call = function(self, args, data)
data.forms["nom-sg"] = args[1] .. "o"
local r = args[1]
data.forms["nom-pl"] = args[1] .. "a"
data.forms["nom-sg"] = r .. "o"
data.forms["nom-pl"] = r .. "a"
data.forms["gen-sg"] = args[1] .. "i"
data.forms["gen-sg"] = r .. "i"
data.forms["gen-pl"] = args[1] .. "oro"
data.forms["gen-pl"] = r .. "oro"
data.forms["dat-sg"] = r .. "a"
data.forms["dat-sg"] = args[1] .. "a"
data.forms["dat-pl"] = r .. "evo"
data.forms["dat-pl"] = args[1] .. "evo"
data.forms["acc-sg"] = r .. "o"
data.forms["acc-pl"] = r .. "a"
data.forms["acc-sg"] = args[1] .. "o"
end })
data.forms["acc-pl"] = args[1] .. "a"
end
})


-- i-stem
decls["i"] = {
decls["i"] = {
params = {
params = { [1] = {} },
[1] = {},
},
}
}
setmetatable(decls["i"], {__call = function(self, args, data)
setmetatable(decls["i"], { __call = function(self, args, data)
data.forms["nom-sg"] = args[1] .. "e"
local r = args[1]
data.forms["nom-pl"] = args[1] .. "i"
data.forms["nom-sg"] = r .. "e"
data.forms["nom-pl"] = r .. "i"
data.forms["gen-sg"] = args[1] .. "i"
data.forms["gen-sg"] = r .. "i"
data.forms["gen-pl"] = args[1] .. "e"
data.forms["gen-pl"] = r .. "e"
data.forms["dat-sg"] = r .. "i"
data.forms["dat-sg"] = args[1] .. "i"
data.forms["dat-pl"] = r .. "evo"
data.forms["dat-pl"] = args[1] .. "evo"
data.forms["acc-sg"] = r .. "e"
data.forms["acc-pl"] = r .. "i"
data.forms["acc-sg"] = args[1] .. "e"
end })
data.forms["acc-pl"] = args[1] .. "es"
end
})


-- r-stem (updated)
decls["r"] = {
decls["r"] = {
params = {
params = { [1] = {} },
[1] = {},
[2] = {},
},
}
}
setmetatable(decls["r"], {__call = function(self, args, data)
setmetatable(decls["r"], { __call = function(self, args, data)
data.forms["nom-sg"] = args[1]
local r = args[1]
data.forms["nom-pl"] = args[2] .. "i"
data.forms["nom-sg"] = r .. "ar"
data.forms["nom-pl"] = r .. "aiu"
data.forms["gen-sg"] = args[2] .. "i"
data.forms["gen-sg"] = r .. "eri"
data.forms["gen-pl"] = args[2] .. "e"
data.forms["gen-pl"] = r .. "are"
data.forms["dat-sg"] = r .. "er"
data.forms["dat-sg"] = args[2] .. "i"
data.forms["dat-pl"] = r .. "arevo"
data.forms["dat-pl"] = args[2] .. "evo"
data.forms["acc-sg"] = r .. "ar"
data.forms["acc-pl"] = r .. "aru"
data.forms["acc-sg"] = args[2] .. "e"
end })
data.forms["acc-pl"] = args[2] .. "es"
end
})


decls["d"] = {
-- d1-stem
params = {
decls["d1"] = {
[1] = {},
params = { [1] = {} },
[2] = {},
},
}
}
setmetatable(decls["d"], {__call = function(self, args, data)
setmetatable(decls["d1"], { __call = function(self, args, data)
data.forms["nom-sg"] = args[1] .. "ê"
local r = args[1]
data.forms["nom-pl"] = args[2] .. "edi"
data.forms["nom-sg"] = r .. "ê"
data.forms["nom-pl"] = r .. "edi"
data.forms["gen-sg"] = args[2] .. "edi"
data.forms["gen-sg"] = r .. "edi"
data.forms["gen-pl"] = args[2] .. "ede"
data.forms["gen-pl"] = r .. "ede"
data.forms["dat-sg"] = r .. "edi"
data.forms["dat-sg"] = args[2] .. "edi"
data.forms["dat-pl"] = r .. "edevo"
data.forms["dat-pl"] = args[2] .. "edevo"
data.forms["acc-sg"] = r .. "ede"
data.forms["acc-pl"] = r .. "edi"
data.forms["acc-sg"] = args[2] .. "ede"
end })
data.forms["acc-pl"] = args[2] .. "edes"
end
})


-- d2-stem
decls["d2"] = {
params = { [1] = {} },
}
setmetatable(decls["d2"], { __call = function(self, args, data)
local r = args[1]
data.forms["nom-sg"] = r .. "â"
data.forms["nom-pl"] = r .. "adi"
data.forms["gen-sg"] = r .. "adi"
data.forms["gen-pl"] = r .. "ade"
data.forms["dat-sg"] = r .. "adi"
data.forms["dat-pl"] = r .. "adevo"
data.forms["acc-sg"] = r .. "ade"
data.forms["acc-pl"] = r .. "adi"
end })
-- u-stem
decls["u"] = {
decls["u"] = {
params = {
params = { [1] = {} },
[1] = {},
},
}
}
setmetatable(decls["u"], {__call = function(self, args, data)
setmetatable(decls["u"], { __call = function(self, args, data)
data.forms["nom-sg"] = args[1] .. "u"
local r = args[1]
data.forms["nom-pl"] = args[1] .. "us"
data.forms["nom-sg"] = r .. "u"
data.forms["nom-pl"] = r .. "ui"
data.forms["gen-sg"] = args[1] .. "aus"
data.forms["gen-sg"] = r .. "aui"
data.forms["gen-pl"] = args[1] .. "eve"
data.forms["gen-pl"] = r .. "ove"
data.forms["dat-sg"] = r .. "au"
data.forms["dat-sg"] = args[1] .. "au"
data.forms["dat-pl"] = r .. "ovo"
data.forms["dat-pl"] = args[1] .. "evo"
data.forms["acc-sg"] = r .. "u"
data.forms["acc-pl"] = r .. "ui"
data.forms["acc-sg"] = args[1] .. "u"
end })
data.forms["acc-pl"] = args[1] .. "us"
end
})


-- u-stem neuter
decls["u-N"] = {
decls["u-N"] = {
params = {
params = { [1] = {} },
[1] = {},
},
}
}
setmetatable(decls["u-N"], {__call = function(self, args, data)
setmetatable(decls["u-N"], { __call = function(self, args, data)
data.forms["nom-sg"] = args[1] .. "u"
local r = args[1]
data.forms["nom-pl"] = args[1] .. "ua"
data.forms["nom-sg"] = r .. "u"
data.forms["nom-pl"] = r .. "ua"
data.forms["gen-sg"] = args[1] .. "aus"
data.forms["gen-sg"] = r .. "aui"
data.forms["gen-pl"] = args[1] .. "eve"
data.forms["gen-pl"] = r .. "ove"
data.forms["dat-sg"] = r .. "au"
data.forms["dat-sg"] = args[1] .. "au"
data.forms["dat-pl"] = r .. "ovo"
data.forms["dat-pl"] = args[1] .. "evo"
data.forms["acc-sg"] = r .. "u"
data.forms["acc-pl"] = r .. "ua"
data.forms["acc-sg"] = args[1] .. "u"
end })
data.forms["acc-pl"] = args[1] .. "ua"
end
})


-- Display metadata
local cases = {
local cases = {
["nominative"] = {short_form = "nom", link = "''[[nominative case|nominative]]''"},
["nominative"] = { short_form = "nom", link = "''[[w:nominative case|nominative]]''" },
["accusative"] = {short_form = "acc", link = "''[[accusative case|accusative]]''"},
["accusative"] = { short_form = "acc", link = "''[[w:accusative case|accusative]]''" },
["genitive"] = {short_form = "gen", link = "''[[genitive case|genitive]]''"},
["genitive"] = { short_form = "gen", link = "''[[w:genitive case|genitive]]''" },
["dative"] = {short_form = "dat", link = "''[[dative case|dative]]''"},
["dative"] = { short_form = "dat", link = "''[[w:dative case|dative]]''" },
}
}


local function make_headers(data, wikicode)
-- Main output function
table.insert(wikicode, '|- class="vsHide"\n')
function export.show(frame)
table.insert(wikicode, '! style="background:#' .. '; font-style:italic;" | Number\n')
local args = frame.args
table.insert(wikicode, '! style="background:#' .. '; font-style:italic;" | Singular\n')
local root = args[1] or error("No root provided.")
table.insert(wikicode, '! style="background:#' .. '; font-style:italic;" | Plural\n')
local decltype = args["type"] or error("No declension type provided.")
end


local function show_form(form, data, branch)
local decl = decls[decltype]
local function convert_word(form, branch)
if not decl then
if mw.ustring.find(form, "{{{") then
error("Unknown declension type: " .. decltype)
return form
else
return m_vl_translit.convert_words(form, branch)
end
end
end


if not form then
local data = { forms = {} }
return "—"
decl({ root }, data)
 
local function showForm(case, number)
local key = cases[case].short_form .. "-" .. number
return data.forms[key] or ""
end
end
 
local function small(text)
if title:inNamespace("") then
return frame:preprocess("{{small|" .. text .. "}}")
return m_links.full_link({lang = lang, alt = convert_word(form, branch), term = form})
else
return m_links.full_link({lang = lang, alt = convert_word(form, branch), term = "*" .. form})
end
end
end


local function make_case(data, wikicode, case)
local out = {}
local case_short = cases[case].short_form
table.insert(out, '{| class="wikitable" style="text-align:center;"')
table.insert(wikicode, '|- class="vsHide"\n')
table.insert(out, '|-')
table.insert(wikicode, '! style="background:#' .. ';" | ' .. cases[case].link .. '\n')
table.insert(out, '! Number !! Case !! Declension')
table.insert(wikicode, '| style="background:#' .. ';" | ' .. show_form(data.forms[case_short .. '-sg'], data) .. '\n')
table.insert(wikicode, '| style="background:#' .. ';" | ' .. show_form(data.forms[case_short .. '-pl'], data) .. '\n')
end


local function make_table(data)
-- Singular rows
local wikicode = {'{| class="prettytable inflection-table vsSwitcher" data-toggle-category="inflection"\n'}
table.insert(out, '|-')
table.insert(wikicode, '! colspan="5" class="vsToggleElement" style="text-align:left;min-width: 25em;background:#' ..
table.insert(out, '! rowspan=4 | Singular')
  '" | ')
table.insert(out, '! ' .. small("nom."))
table.insert(out, '| ' .. showForm("nominative", "sg"))


make_headers(data, wikicode)
table.insert(out, '|-')
make_case(data, wikicode, "nominative")
table.insert(out, '! ' .. small("acc."))
make_case(data, wikicode, "genitive")
table.insert(out, '| ' .. showForm("accusative", "sg"))
make_case(data, wikicode, "dative")
make_case(data, wikicode, "accusative")


table.insert(wikicode, "|}")
table.insert(out, '|-')
table.insert(out, '! ' .. small("dat."))
return table.concat(wikicode)
table.insert(out, '| ' .. showForm("dative", "sg"))
end


-- The main entry point.
table.insert(out, '|-')
-- This is the only function that can be invoked from a template.
table.insert(out, '! ' .. small("gen."))
function export.show(frame)
table.insert(out, '| ' .. showForm("genitive", "sg"))
local parent_args = frame:getParent().args
 
-- Plural rows
table.insert(out, '|-')
table.insert(out, '! rowspan=4 | Plural')
table.insert(out, '! ' .. small("nom."))
table.insert(out, '| ' .. showForm("nominative", "pl"))
 
table.insert(out, '|-')
table.insert(out, '! ' .. small("acc."))
table.insert(out, '| ' .. showForm("accusative", "pl"))
 
table.insert(out, '|-')
table.insert(out, '! ' .. small("dat."))
table.insert(out, '| ' .. showForm("dative", "pl"))


local decl_type = (frame.args["decl"] or parent_args["decl"]) or "a"
table.insert(out, '|-')
table.insert(out, '! ' .. small("gen."))
if not decls[decl_type] then
table.insert(out, '| ' .. showForm("genitive", "pl"))
error("Unknown declension type '" .. decl_type .. "'")
end
local data = {forms = {}}
data.head = parent_args["head"] or nil
data.latincolour = {
frame:expandTemplate({title = "Latincolour1"}),
frame:expandTemplate({title = "Latincolour2"}),
frame:expandTemplate({title = "Latincolour3"}),
}


local args = require("Module:parameters").process(parent_args, decls[decl_type].params, true)
table.insert(out, '|}')
return table.concat(out, '\n')
if not args[1] then
setmetatable(args, {__index = function(self, key)
return "{{{" .. key .. "}}}"
end
})
end
-- Generate the forms
decls[decl_type](args, data)
data["decl"] = decl_type
-- Make the table
t = decl_names[data.decl] .. '.\n\n'
if parent_args.family then
t = t .. make_table(data, parent_args.family)
if parent_args.family2 then
t = t .. "\n" .. make_table(data, parent_args.family2)
end
else
t = t .. make_table(data, "It-W") .. "\n" .. make_table(data, "E") .. "\n" .. make_table(data, "S")
end
if title:inNamespace("") then
t = mw.ustring.gsub(t, "#head", m_links.full_link({lang = lang, alt = data.forms["nom-sg"]}, "term"))
else
t = mw.ustring.gsub(t, "#head", m_links.full_link({lang = lang, alt = "*" .. data.forms["nom-sg"]}, "term"))
end
return t
end
end


return export
return export

Latest revision as of 20:05, 29 June 2025

Documentation for this module may be created at Module:qlu-nouns/doc

local m_utilities = require("Module:utilities")
local m_links = require("Module:links")
local lang = require("Module:languages").getByCode("qlu")

local export = {}

local decls = {}

-- a-stem
decls["a"] = {
	params = { [1] = {} },
}
setmetatable(decls["a"], { __call = function(self, args, data)
	local r = args[1]
	data.forms["nom-sg"] = r .. "a"
	data.forms["nom-pl"] = r .. "e"
	data.forms["gen-sg"] = r .. "e"
	data.forms["gen-pl"] = r .. "aro"
	data.forms["dat-sg"] = r .. "a"
	data.forms["dat-pl"] = r .. "evo"
	data.forms["acc-sg"] = r .. "a"
	data.forms["acc-pl"] = r .. "e"
end })

-- o-stem
decls["o"] = {
	params = { [1] = {} },
}
setmetatable(decls["o"], { __call = function(self, args, data)
	local r = args[1]
	data.forms["nom-sg"] = r .. "u"
	data.forms["nom-pl"] = r .. "i"
	data.forms["gen-sg"] = r .. "i"
	data.forms["gen-pl"] = r .. "oro"
	data.forms["dat-sg"] = r .. "a"
	data.forms["dat-pl"] = r .. "evo"
	data.forms["acc-sg"] = r .. "o"
	data.forms["acc-pl"] = r .. "i"
end })

-- o-stem neuter
decls["o-N"] = {
	params = { [1] = {} },
}
setmetatable(decls["o-N"], { __call = function(self, args, data)
	local r = args[1]
	data.forms["nom-sg"] = r .. "o"
	data.forms["nom-pl"] = r .. "a"
	data.forms["gen-sg"] = r .. "i"
	data.forms["gen-pl"] = r .. "oro"
	data.forms["dat-sg"] = r .. "a"
	data.forms["dat-pl"] = r .. "evo"
	data.forms["acc-sg"] = r .. "o"
	data.forms["acc-pl"] = r .. "a"
end })

-- i-stem
decls["i"] = {
	params = { [1] = {} },
}
setmetatable(decls["i"], { __call = function(self, args, data)
	local r = args[1]
	data.forms["nom-sg"] = r .. "e"
	data.forms["nom-pl"] = r .. "i"
	data.forms["gen-sg"] = r .. "i"
	data.forms["gen-pl"] = r .. "e"
	data.forms["dat-sg"] = r .. "i"
	data.forms["dat-pl"] = r .. "evo"
	data.forms["acc-sg"] = r .. "e"
	data.forms["acc-pl"] = r .. "i"
end })

-- r-stem (updated)
decls["r"] = {
	params = { [1] = {} },
}
setmetatable(decls["r"], { __call = function(self, args, data)
	local r = args[1]
	data.forms["nom-sg"] = r .. "ar"
	data.forms["nom-pl"] = r .. "aiu"
	data.forms["gen-sg"] = r .. "eri"
	data.forms["gen-pl"] = r .. "are"
	data.forms["dat-sg"] = r .. "er"
	data.forms["dat-pl"] = r .. "arevo"
	data.forms["acc-sg"] = r .. "ar"
	data.forms["acc-pl"] = r .. "aru"
end })

-- d1-stem
decls["d1"] = {
	params = { [1] = {} },
}
setmetatable(decls["d1"], { __call = function(self, args, data)
	local r = args[1]
	data.forms["nom-sg"] = r .. "ê"
	data.forms["nom-pl"] = r .. "edi"
	data.forms["gen-sg"] = r .. "edi"
	data.forms["gen-pl"] = r .. "ede"
	data.forms["dat-sg"] = r .. "edi"
	data.forms["dat-pl"] = r .. "edevo"
	data.forms["acc-sg"] = r .. "ede"
	data.forms["acc-pl"] = r .. "edi"
end })

-- d2-stem
decls["d2"] = {
	params = { [1] = {} },
}
setmetatable(decls["d2"], { __call = function(self, args, data)
	local r = args[1]
	data.forms["nom-sg"] = r .. "â"
	data.forms["nom-pl"] = r .. "adi"
	data.forms["gen-sg"] = r .. "adi"
	data.forms["gen-pl"] = r .. "ade"
	data.forms["dat-sg"] = r .. "adi"
	data.forms["dat-pl"] = r .. "adevo"
	data.forms["acc-sg"] = r .. "ade"
	data.forms["acc-pl"] = r .. "adi"
end })

-- u-stem
decls["u"] = {
	params = { [1] = {} },
}
setmetatable(decls["u"], { __call = function(self, args, data)
	local r = args[1]
	data.forms["nom-sg"] = r .. "u"
	data.forms["nom-pl"] = r .. "ui"
	data.forms["gen-sg"] = r .. "aui"
	data.forms["gen-pl"] = r .. "ove"
	data.forms["dat-sg"] = r .. "au"
	data.forms["dat-pl"] = r .. "ovo"
	data.forms["acc-sg"] = r .. "u"
	data.forms["acc-pl"] = r .. "ui"
end })

-- u-stem neuter
decls["u-N"] = {
	params = { [1] = {} },
}
setmetatable(decls["u-N"], { __call = function(self, args, data)
	local r = args[1]
	data.forms["nom-sg"] = r .. "u"
	data.forms["nom-pl"] = r .. "ua"
	data.forms["gen-sg"] = r .. "aui"
	data.forms["gen-pl"] = r .. "ove"
	data.forms["dat-sg"] = r .. "au"
	data.forms["dat-pl"] = r .. "ovo"
	data.forms["acc-sg"] = r .. "u"
	data.forms["acc-pl"] = r .. "ua"
end })

-- Display metadata
local cases = {
	["nominative"] = { short_form = "nom", link = "''[[w:nominative case|nominative]]''" },
	["accusative"] = { short_form = "acc", link = "''[[w:accusative case|accusative]]''" },
	["genitive"] = { short_form = "gen", link = "''[[w:genitive case|genitive]]''" },
	["dative"] = { short_form = "dat", link = "''[[w:dative case|dative]]''" },
}

-- Main output function
function export.show(frame)
	local args = frame.args
	local root = args[1] or error("No root provided.")
	local decltype = args["type"] or error("No declension type provided.")

	local decl = decls[decltype]
	if not decl then
		error("Unknown declension type: " .. decltype)
	end

	local data = { forms = {} }
	decl({ root }, data)

	local function showForm(case, number)
		local key = cases[case].short_form .. "-" .. number
		return data.forms[key] or "—"
	end

	local function small(text)
		return frame:preprocess("{{small|" .. text .. "}}")
	end

	local out = {}
	table.insert(out, '{| class="wikitable" style="text-align:center;"')
	table.insert(out, '|-')
	table.insert(out, '! Number !! Case !! Declension')

	-- Singular rows
	table.insert(out, '|-')
	table.insert(out, '! rowspan=4 | Singular')
	table.insert(out, '! ' .. small("nom."))
	table.insert(out, '| ' .. showForm("nominative", "sg"))

	table.insert(out, '|-')
	table.insert(out, '! ' .. small("acc."))
	table.insert(out, '| ' .. showForm("accusative", "sg"))

	table.insert(out, '|-')
	table.insert(out, '! ' .. small("dat."))
	table.insert(out, '| ' .. showForm("dative", "sg"))

	table.insert(out, '|-')
	table.insert(out, '! ' .. small("gen."))
	table.insert(out, '| ' .. showForm("genitive", "sg"))

	-- Plural rows
	table.insert(out, '|-')
	table.insert(out, '! rowspan=4 | Plural')
	table.insert(out, '! ' .. small("nom."))
	table.insert(out, '| ' .. showForm("nominative", "pl"))

	table.insert(out, '|-')
	table.insert(out, '! ' .. small("acc."))
	table.insert(out, '| ' .. showForm("accusative", "pl"))

	table.insert(out, '|-')
	table.insert(out, '! ' .. small("dat."))
	table.insert(out, '| ' .. showForm("dative", "pl"))

	table.insert(out, '|-')
	table.insert(out, '! ' .. small("gen."))
	table.insert(out, '| ' .. showForm("genitive", "pl"))

	table.insert(out, '|}')
	return table.concat(out, '\n')
end

return export