Module:qlu-nouns: Difference between revisions

From Linguifex
Jump to navigation Jump to search
No edit summary
No edit summary
Line 3: Line 3:
local export = {}
local export = {}


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


-- a-stem
-- a-stem
decls["a"] = setmetatable({}, { __call = function(self, args, data)
decls["a"] = setmetatable({}, { __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 .. "as"
end})
end})


-- o-stem masculine
-- o-stem masculine
decls["o"] = setmetatable({}, { __call = function(self, args, data)
decls["o"] = setmetatable({}, { __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 .. "os"
end})
end})


-- o-stem neuter
-- o-stem neuter
decls["o-N"] = setmetatable({}, { __call = function(self, args, data)
decls["o-N"] = setmetatable({}, { __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"] = setmetatable({}, { __call = function(self, args, data)
decls["i"] = setmetatable({}, { __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 .. "es"
end})
end})


-- r-stem (updated new form)
-- r-stem (new)
decls["r"] = setmetatable({}, { __call = function(self, args, data)
decls["r"] = setmetatable({}, { __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})


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


-- d-stem type 2 (d2)
-- d-stem type 2 (d2)
decls["d2"] = setmetatable({}, { __call = function(self, args, data)
decls["d2"] = setmetatable({}, { __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 masculine
-- u-stem masculine
decls["u"] = setmetatable({}, { __call = function(self, args, data)
decls["u"] = setmetatable({}, { __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 .. "us"
data.forms["gen_sg"] = r .. "aui"
  data.forms["gen_sg"] = r .. "aus"
data.forms["gen_pl"] = r .. "ove"
  data.forms["gen_pl"] = r .. "eve"
data.forms["dat_sg"] = r .. "au"
  data.forms["dat_sg"] = r .. "au"
data.forms["dat_pl"] = r .. "ovo"
  data.forms["dat_pl"] = r .. "evo"
data.forms["acc_sg"] = r .. "u"
  data.forms["acc_sg"] = r .. "u"
data.forms["acc_pl"] = r .. "ui"
  data.forms["acc_pl"] = r .. "us"
end})
end})


-- u-stem neuter
-- u-stem neuter
decls["u-N"] = setmetatable({}, { __call = function(self, args, data)
decls["u-N"] = setmetatable({}, { __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 .. "aus"
data.forms["gen_pl"] = r .. "ove"
  data.forms["gen_pl"] = r .. "eve"
data.forms["dat_sg"] = r .. "au"
  data.forms["dat_sg"] = r .. "au"
data.forms["dat_pl"] = r .. "ovo"
  data.forms["dat_pl"] = r .. "evo"
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})


-- Helper to substitute forms into wikicode
-- Table generator - no external templates needed
local function add_forms(wikitable, forms)
function export.make_table(data)
if type(wikitable) ~= "string" then
  local forms = data.forms
error("Expected string, got " .. type(wikitable))
 
end
  local rows = {
return wikitable:gsub("{{{([^}]+)}}}", forms)
    { label = "[[dative case|dative]]", sg = forms["dat_sg"], pl = forms["dat_pl"] },
end
    { label = "[[genitive case|genitive]]", sg = forms["gen_sg"], pl = forms["gen_pl"] },
    { label = "[[accusative case|accusative]]", sg = forms["acc_sg"], pl = forms["acc_pl"] },
    { label = "[[nominative case|nominative]]", sg = forms["nom_sg"], pl = forms["nom_pl"] },
  }
 
  local function cell(content, isHeader, extraStyle)
    local tag = isHeader and "th" or "td"
    local style = extraStyle or ""
    return string.format('<%s style="%s">%s</%s>', tag, style, content or "—", tag)
  end
 
  local out = {}
  table.insert(out, '<table class="inflection-table" style="border-collapse:collapse; width:40%; font-size:90%;">')
 
  -- Header row
  table.insert(out, "<thead><tr>")
  table.insert(out, cell("", true, "background:#444; color:#fff; padding:4px;"))
  table.insert(out, cell("singular", true, "background:#444; color:#fff; padding:4px;"))
  table.insert(out, cell("plural", true, "background:#444; color:#fff; padding:4px;"))
  table.insert(out, "</tr></thead>")
 
  -- Body rows
  table.insert(out, "<tbody>")
  for _, row in ipairs(rows) do
    table.insert(out, "<tr>")
    -- Case name column with light gray background
    table.insert(out, cell(row.label, false, "background:#ddd; padding:4px; font-weight:bold; white-space:nowrap;"))
    -- Singular form
    table.insert(out, cell(row.sg, false, "background:#fff; padding:4px; text-align:center;"))
    -- Plural form
    table.insert(out, cell(row.pl, false, "background:#fff; padding:4px; text-align:center;"))
    table.insert(out, "</tr>")
  end
  table.insert(out, "</tbody>")


-- Table builder using inflection-table-top/bottom templates for nice style
  table.insert(out, "</table>")
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
  -- Append footnotes if any
output:insert("\n" .. data.footnotes)
  if data.footnotes and data.footnotes ~= "" then
end
    table.insert(out, '<div class="footnotes" style="font-size:80%; margin-top:0.5em;">' .. data.footnotes .. "</div>")
  end


return add_forms(output:concat(), data.forms)
  return table.concat(out, "\n")
end
end


-- Main show function
-- Main show function: receives root and declension type, outputs full table HTML
function export.show(frame)
function export.show(frame)
local args = frame.args
  local args = frame.args
local root = args[1] or error("No root provided.")
  local root = args[1] or error("No root provided.")
local decltype = args["type"] or error("No declension type provided.")
  local decltype = args["type"] or error("No declension type provided.")


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


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


return export.make_table(data)
  return export.make_table(data)
end
end


return export
return export

Revision as of 19:26, 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
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 .. "as"
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 .. "os"
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 .. "es"
end})

-- r-stem (new)
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 .. "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"] = 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 .. "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})

-- Table generator - no external templates needed
function export.make_table(data)
  local forms = data.forms

  local rows = {
    { label = "[[dative case|dative]]", sg = forms["dat_sg"], pl = forms["dat_pl"] },
    { label = "[[genitive case|genitive]]", sg = forms["gen_sg"], pl = forms["gen_pl"] },
    { label = "[[accusative case|accusative]]", sg = forms["acc_sg"], pl = forms["acc_pl"] },
    { label = "[[nominative case|nominative]]", sg = forms["nom_sg"], pl = forms["nom_pl"] },
  }

  local function cell(content, isHeader, extraStyle)
    local tag = isHeader and "th" or "td"
    local style = extraStyle or ""
    return string.format('<%s style="%s">%s</%s>', tag, style, content or "—", tag)
  end

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

  -- Header row
  table.insert(out, "<thead><tr>")
  table.insert(out, cell("", true, "background:#444; color:#fff; padding:4px;"))
  table.insert(out, cell("singular", true, "background:#444; color:#fff; padding:4px;"))
  table.insert(out, cell("plural", true, "background:#444; color:#fff; padding:4px;"))
  table.insert(out, "</tr></thead>")

  -- Body rows
  table.insert(out, "<tbody>")
  for _, row in ipairs(rows) do
    table.insert(out, "<tr>")
    -- Case name column with light gray background
    table.insert(out, cell(row.label, false, "background:#ddd; padding:4px; font-weight:bold; white-space:nowrap;"))
    -- Singular form
    table.insert(out, cell(row.sg, false, "background:#fff; padding:4px; text-align:center;"))
    -- Plural form
    table.insert(out, cell(row.pl, false, "background:#fff; padding:4px; text-align:center;"))
    table.insert(out, "</tr>")
  end
  table.insert(out, "</tbody>")

  table.insert(out, "</table>")

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

  return table.concat(out, "\n")
end

-- Main show function: receives root and declension type, outputs full table HTML
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