Module:qlu-nouns: Difference between revisions

From Linguifex
Jump to navigation Jump to search
No edit summary
No edit summary
Line 1: Line 1:
local Array = require 'Module:array'
local m_utilities = require("Module:utilities")
local m_links = require("Module:links")
local lang = require("Module:languages").getByCode("qlu")


local export = {}
local export = {}


-- Declension paradigms for your conlang
local decls = {}
local decls = {}


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


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


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


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


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


-- d-stem type 1 (d1)
-- d1-stem
decls["d1"] = setmetatable({}, { __call = function(self, args, data)
decls["d1"] = {
  local r = args[1]
params = { [1] = {} },
  data.forms["nom_sg"] = r .. "ê"
}
  data.forms["nom_pl"] = r .. "edi"
setmetatable(decls["d1"], { __call = function(self, args, data)
  data.forms["gen_sg"] = r .. "edi"
local r = args[1]
  data.forms["gen_pl"] = r .. "ede"
data.forms["nom-sg"] = r .. "ê"
  data.forms["dat_sg"] = r .. "edi"
data.forms["nom-pl"] = r .. "edi"
  data.forms["dat_pl"] = r .. "edevo"
data.forms["gen-sg"] = r .. "edi"
  data.forms["acc_sg"] = r .. "ede"
data.forms["gen-pl"] = r .. "ede"
  data.forms["acc_pl"] = r .. "edi"
data.forms["dat-sg"] = r .. "edi"
end})
data.forms["dat-pl"] = r .. "edevo"
data.forms["acc-sg"] = r .. "ede"
data.forms["acc-pl"] = r .. "edi"
end })


-- d-stem type 2 (d2)
-- d2-stem
decls["d2"] = setmetatable({}, { __call = function(self, args, data)
decls["d2"] = {
  local r = args[1]
params = { [1] = {} },
  data.forms["nom_sg"] = r .. "â"
}
  data.forms["nom_pl"] = r .. "adi"
setmetatable(decls["d2"], { __call = function(self, args, data)
  data.forms["gen_sg"] = r .. "adi"
local r = args[1]
  data.forms["gen_pl"] = r .. "ade"
data.forms["nom-sg"] = r .. "â"
  data.forms["dat_sg"] = r .. "adi"
data.forms["nom-pl"] = r .. "adi"
  data.forms["dat_pl"] = r .. "adevo"
data.forms["gen-sg"] = r .. "adi"
  data.forms["acc_sg"] = r .. "ade"
data.forms["gen-pl"] = r .. "ade"
  data.forms["acc_pl"] = r .. "adi"
data.forms["dat-sg"] = r .. "adi"
end})
data.forms["dat-pl"] = r .. "adevo"
data.forms["acc-sg"] = r .. "ade"
data.forms["acc-pl"] = r .. "adi"
end })


-- u-stem masculine
-- u-stem
decls["u"] = setmetatable({}, { __call = function(self, args, data)
decls["u"] = {
  local r = args[1]
params = { [1] = {} },
  data.forms["nom_sg"] = r .. "u"
}
  data.forms["nom_pl"] = r .. "us"
setmetatable(decls["u"], { __call = function(self, args, data)
  data.forms["gen_sg"] = r .. "aus"
local r = args[1]
  data.forms["gen_pl"] = r .. "eve"
data.forms["nom-sg"] = r .. "u"
  data.forms["dat_sg"] = r .. "au"
data.forms["nom-pl"] = r .. "us"
  data.forms["dat_pl"] = r .. "evo"
data.forms["gen-sg"] = r .. "aus"
  data.forms["acc_sg"] = r .. "u"
data.forms["gen-pl"] = r .. "eve"
  data.forms["acc_pl"] = r .. "us"
data.forms["dat-sg"] = r .. "au"
end})
data.forms["dat-pl"] = r .. "evo"
data.forms["acc-sg"] = r .. "u"
data.forms["acc-pl"] = r .. "us"
end })


-- u-stem neuter
-- u-stem neuter
decls["u-N"] = setmetatable({}, { __call = function(self, args, data)
decls["u-N"] = {
  local r = args[1]
params = { [1] = {} },
  data.forms["nom_sg"] = r .. "u"
}
  data.forms["nom_pl"] = r .. "ua"
setmetatable(decls["u-N"], { __call = function(self, args, data)
  data.forms["gen_sg"] = r .. "aus"
local r = args[1]
  data.forms["gen_pl"] = r .. "eve"
data.forms["nom-sg"] = r .. "u"
  data.forms["dat_sg"] = r .. "au"
data.forms["nom-pl"] = r .. "ua"
  data.forms["dat_pl"] = r .. "evo"
data.forms["gen-sg"] = r .. "aus"
  data.forms["acc_sg"] = r .. "u"
data.forms["gen-pl"] = r .. "eve"
  data.forms["acc_pl"] = r .. "ua"
data.forms["dat-sg"] = r .. "au"
end})
data.forms["dat-pl"] = r .. "evo"
data.forms["acc-sg"] = r .. "u"
data.forms["acc-pl"] = r .. "ua"
end })


-- Table generator - no external templates needed
-- Display metadata
function export.make_table(data)
local cases = {
  local forms = data.forms
["nominative"] = { short_form = "nom", link = "''[[nominative case|nominative]]''" },
["accusative"] = { short_form = "acc", link = "''[[accusative case|accusative]]''" },
["genitive"] = { short_form = "gen", link = "''[[genitive case|genitive]]''" },
["dative"] = { short_form = "dat", link = "''[[dative case|dative]]''" },
}


  local rows = {
-- Main output function
    { label = "[[dative case|dative]]", sg = forms["dat_sg"], pl = forms["dat_pl"] },
function export.show(frame)
    { label = "[[genitive case|genitive]]", sg = forms["gen_sg"], pl = forms["gen_pl"] },
local args = frame:getParent().args
    { label = "[[accusative case|accusative]]", sg = forms["acc_sg"], pl = forms["acc_pl"] },
local root = args[1] or error("No root provided.")
    { label = "[[nominative case|nominative]]", sg = forms["nom_sg"], pl = forms["nom_pl"] },
local decltype = args["type"] or error("No declension type provided.")
  }


  local function cell(content, isHeader, extraStyle)
local decl = decls[decltype]
    local tag = isHeader and "th" or "td"
if not decl then
    local style = extraStyle or ""
error("Unknown declension type: " .. decltype)
    return string.format('<%s style="%s">%s</%s>', tag, style, content or "—", tag)
end
  end


  local out = {}
local data = { forms = {} }
  table.insert(out, '<table class="inflection-table" style="border-collapse:collapse; width:40%; font-size:90%;">')
decl({ root }, data)


  -- Header row (without thead)
local function showForm(case, number)
  table.insert(out, "<tr>")
local key = cases[case].short_form .. "-" .. number
  table.insert(out, cell("", true, "background:#444; color:#fff; padding:4px;"))
return data.forms[key] or ""
  table.insert(out, cell("singular", true, "background:#444; color:#fff; padding:4px;"))
end
  table.insert(out, cell("plural", true, "background:#444; color:#fff; padding:4px;"))
  table.insert(out, "</tr>")


  -- Body rows (without tbody)
local out = {}
  for _, row in ipairs(rows) do
table.insert(out, '{| class="wikitable"\n! Case !! Singular !! Plural')
    table.insert(out, "<tr>")
    table.insert(out, cell(row.label, false, "background:#ddd; padding:4px; font-weight:bold; white-space:nowrap;"))
    table.insert(out, cell(row.sg, false, "background:#fff; padding:4px; text-align:center;"))
    table.insert(out, cell(row.pl, false, "background:#fff; padding:4px; text-align:center;"))
    table.insert(out, "</tr>")
  end


  table.insert(out, "</table>")
for case, info in pairs(cases) do
table.insert(out, string.format('|-\n| %s || %s || %s', info.link, showForm(case, "sg"), showForm(case, "pl")))
end


  if data.footnotes and data.footnotes ~= "" then
table.insert(out, '|}')
    table.insert(out, '<div class="footnotes" style="font-size:80%; margin-top:0.5em;">' .. data.footnotes .. "</div>")
return table.concat(out, '\n')
  end
 
  return table.concat(out, "\n")
end
end


return export
return export

Revision as of 19:30, 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 .. "as"
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 .. "os"
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 .. "es"
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 .. "us"
	data.forms["gen-sg"] = r .. "aus"
	data.forms["gen-pl"] = r .. "eve"
	data.forms["dat-sg"] = r .. "au"
	data.forms["dat-pl"] = r .. "evo"
	data.forms["acc-sg"] = r .. "u"
	data.forms["acc-pl"] = r .. "us"
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 .. "aus"
	data.forms["gen-pl"] = r .. "eve"
	data.forms["dat-sg"] = r .. "au"
	data.forms["dat-pl"] = r .. "evo"
	data.forms["acc-sg"] = r .. "u"
	data.forms["acc-pl"] = r .. "ua"
end })

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

-- Main output function
function export.show(frame)
	local args = frame:getParent().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 out = {}
	table.insert(out, '{| class="wikitable"\n! Case !! Singular !! Plural')

	for case, info in pairs(cases) do
		table.insert(out, string.format('|-\n| %s || %s || %s', info.link, showForm(case, "sg"), showForm(case, "pl")))
	end

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

return export