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 m_utilities = require("Module:utilities")
local Array = require 'Module:array'
local m_links = require("Module:links")
local lang = require("Module:languages").getByCode("qlu")


local export = {}
local export = {}


-- Declension paradigms for your conlang (updated with your stems)
local decls = {}
local decls = {}


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


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


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


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


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


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


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


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


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


-- Display metadata
-- Helper to substitute forms into wikicode
local cases = {
local function add_forms(wikitable, forms)
["nominative"] = { short_form = "nom", link = "''[[w:nominative case|nom]]''" },
if type(wikitable) ~= "string" then
["accusative"] = { short_form = "acc", link = "''[[w:accusative case|acc]]''" },
error("Expected string, got " .. type(wikitable))
["genitive"] = { short_form = "gen", link = "''[[w:genitive case|gen]]''" },
end
["dative"] = { short_form = "dat", link = "''[[w:dative case|dat]]''" },
return wikitable:gsub("{{{([^}]+)}}}", forms)
}
end
 
-- Table builder using inflection-table-top/bottom templates for nice style
function export.make_table(data)
local output = Array(data.title or "", mw.getCurrentFrame():expandTemplate{
title = "inflection-table-top",
args = {
title = "-",
palette = "cyan",
class = "sticky-left-column",
lang = "qlu", -- your conlang language code here
}
})
output:insert([=[
! class="outer" |
! class="outer" | singular
! class="outer" | plural
|-
! [[dative case|dative]]
| {{{dat_sg}}}
| {{{dat_pl}}}
|-
! [[genitive case|genitive]]
| {{{gen_sg}}}
| {{{gen_pl}}}
|-
! [[accusative case|accusative]]
| {{{acc_sg}}}
| {{{acc_pl}}}
|-
! [[nominative case|nominative]]
| {{{nom_sg}}}
| {{{nom_pl}}}
|-]=])
output:insert("\n")
output:insert(mw.getCurrentFrame():expandTemplate{ title = "inflection-table-bottom" })
 
if data.footnotes and data.footnotes ~= "" then
output:insert("\n" .. data.footnotes)
end


-- Main output function
return add_forms(output:concat(), data.forms)
end
 
-- Main show function
function export.show(frame)
function export.show(frame)
local args = frame.args
local args = frame.args
Line 173: Line 187:
decl({ root }, data)
decl({ root }, data)


local function showForm(case, number)
return export.make_table(data)
local key = cases[case].short_form .. "-" .. number
return data.forms[key] or "—"
end
 
-- Define explicit case order
local case_order = { "dative", "genitive", "accusative", "nominative" }
 
local out = {}
table.insert(out, '{| class="wikitable" style="border-collapse:collapse; width: 40%;"')
table.insert(out, '! style="background:#444; color:white; padding:4px;" | Case')
table.insert(out, '! style="background:#444; color:white; padding:4px;" | Singular')
table.insert(out, '! style="background:#444; color:white; padding:4px;" | Plural')
 
for _, case in ipairs(case_order) do
local case_name = cases[case].link:gsub("''", "") -- remove italics for styling
table.insert(out, string.format(
'|-\n| style="background:#ddd; padding:4px;" | %s || style="background:#fff; padding:4px;" | %s || style="background:#fff; padding:4px;" | %s',
case_name,
showForm(case, "sg"),
showForm(case, "pl")
))
end
 
table.insert(out, '|}')
 
return table.concat(out, '\n')
end
end


return export
return export

Revision as of 19:21, 29 June 2025

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

local Array = require 'Module:array'

local export = {}

-- Declension paradigms for your conlang (updated with your stems)
local decls = {}

-- a-stem
decls["a"] = setmetatable({}, { __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 masculine
decls["o"] = setmetatable({}, { __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"] = setmetatable({}, { __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"] = setmetatable({}, { __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 new form)
decls["r"] = setmetatable({}, { __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})

-- d-stem type 1 (d1)
decls["d1"] = setmetatable({}, { __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})

-- d-stem type 2 (d2)
decls["d2"] = setmetatable({}, { __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 masculine
decls["u"] = setmetatable({}, { __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"] = setmetatable({}, { __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})

-- Helper to substitute forms into wikicode
local function add_forms(wikitable, forms)
	if type(wikitable) ~= "string" then
		error("Expected string, got " .. type(wikitable))
	end
	return wikitable:gsub("{{{([^}]+)}}}", forms)
end

-- Table builder using inflection-table-top/bottom templates for nice style
function export.make_table(data)
	local output = Array(data.title or "", mw.getCurrentFrame():expandTemplate{
		title = "inflection-table-top",
		args = {
			title = "-",
			palette = "cyan",
			class = "sticky-left-column",
			lang = "qlu", -- your conlang language code here
		}
	})
	output:insert([=[
! class="outer" |
! class="outer" | singular
! class="outer" | plural
|-
! [[dative case|dative]]
| {{{dat_sg}}}
| {{{dat_pl}}}
|-
! [[genitive case|genitive]]
| {{{gen_sg}}}
| {{{gen_pl}}}
|-
! [[accusative case|accusative]]
| {{{acc_sg}}}
| {{{acc_pl}}}
|-
! [[nominative case|nominative]]
| {{{nom_sg}}}
| {{{nom_pl}}}
|-]=])
	output:insert("\n")
	output:insert(mw.getCurrentFrame():expandTemplate{ title = "inflection-table-bottom" })

	if data.footnotes and data.footnotes ~= "" then
		output:insert("\n" .. data.footnotes)
	end

	return add_forms(output:concat(), data.forms)
end

-- Main show 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)

	return export.make_table(data)
end

return export