local export = {}
local m_para = require("Module:parameters")
local m_links = require("Module:links")
local m_scripts = require("Module:scripts")
local lang = require("Module:languages").getByCode("sa")
local PAGENAME = mw.title.getCurrentTitle().text
local genders = {
m = 'Masculine', f = 'Feminine', n = 'Neuter',
}
local numbers = {
sdp = '', s = 'singular', p = 'plural'
}
local cases = {
{'n', 'Nominative'}, {'v', 'Vocative'}, {'ac', 'Accusative'}, {'i', 'Instrumental'},
{'d', 'Dative'}, {'ab', 'Ablative'}, {'g', 'Genitive'}, {'l', 'Locative'},
}
local sandhi = {
Deva = {
n = '*$', -- Checks for n > ṇ conversion
m = '^(?:्)*ी$', -- Checks to see if a word is monosyllabic ending in 'ī'
},
}
local endings = {
Deva = {
$'] = 'a',
= 'ā',
= 'u',
= 'ī',
},
}
function joinSuffix(head, suffixes, sc, scCode)
local terms = {}
local term = ''
for _, suffix in ipairs(suffixes) do
if mw.ustring.match(suffix, '^⌫') then --backspace
term = mw.ustring.sub(head, 1, -2) .. mw.ustring.sub(suffix, 2, -1)
else
term = head .. suffix
end
table.insert(terms, m_links.full_link({term = term, lang = lang, sc = sc}))
end
return table.concat(terms, ', ')
end
function make_header(width, g, decl, head, number, sc)
local title = genders .. ' ' .. numbers .. ' ' .. decl .. ' declension of ' .. m_links.full_link({term = nil, alt = head, lang = lang, sc = sc})
local header = '<div class="NavFrame" style="width:' .. width .. 'em">\n'
header = header .. '<div class="NavHead" style="background:#d9ebff"> ' .. title .. '</div>\n'
header = header .. '<div class="NavContent">\n'
header = header .. '{| style="background:#F9F9F9;text-align:center;width:' .. width ..'em" class="inflection-table"\n'
header = header .. '|-\n'
header = header .. '! style="background:#eff7ff" |\n'
if number == 'sdp' then
header = header .. '! style="background:#eff7ff" | Singular\n'
header = header .. '! style="background:#eff7ff" | Dual\n'
header = header .. '! style="background:#eff7ff" | Plural\n'
elseif number == 's' then
header = header .. '! style="background:#eff7ff" | Singular\n'
elseif number == 'p' then
header = header .. '! style="background:#eff7ff" | Plural\n'
end
return header
end
function make_sing_table(head, pattern, g, sc, scCode)
local output = make_header('40', g, pattern.decl, head, 's', sc)
local stem = mw.ustring.sub(head, 1, -1 - (pattern.stem or 0))
local n = mw.ustring.match(stem, sandhi) ~= nil and 'n' or ''
local m = mw.ustring.match(head, sandhi) ~= nil and 'm' or ''
for _, case in ipairs(cases) do
local code = case
local name = case
output = output .. '|-\n'
output = output .. '| style="background-color:#eff7ff; font-style:italic;" | ' .. name ..'\n'
output = output .. '| ' .. joinSuffix(stem, pattern or pattern or pattern or pattern, sc, scCode) .. '\n'
end
output = output .. '|}</div></div>'
return output
end
function make_plur_table(head, pattern, g, sc, scCode)
local output = make_header('40', g, pattern.decl, head, 'p', sc)
local stem = mw.ustring.sub(head, 1, -1 - (pattern.stem or 0))
local n = mw.ustring.match(stem, sandhi) ~= nil and 'n' or ''
local m = mw.ustring.match(head, sandhi) ~= nil and 'm' or ''
for _, case in ipairs(cases) do
local code = case
local name = case
output = output .. '|-\n'
output = output .. '| style="background-color:#eff7ff; font-style:italic;" | ' .. name ..'\n'
output = output .. '| ' .. joinSuffix(stem, pattern or pattern or pattern or pattern, sc, scCode) .. '\n'
end
output = output .. '|}</div></div>'
return output
end
function make_full_table(head, pattern, g, sc, scCode)
local output = make_header('60', g, pattern.decl, head, 'sdp', sc)
local stem = mw.ustring.sub(head, 1, -1 - (pattern.stem or 0))
local n = mw.ustring.match(stem, sandhi) ~= nil and 'n' or ''
local m = mw.ustring.match(head, sandhi) ~= nil and 'm' or ''
for _, case in ipairs(cases) do
local code = case
local name = case
output = output .. '|-\n'
output = output .. '| style="background-color:#eff7ff; font-style:italic;" | ' .. name ..'\n'
output = output .. '| ' .. joinSuffix(stem, pattern or pattern or pattern or pattern, sc, scCode) .. '\n'
output = output .. '| ' .. joinSuffix(stem, pattern or pattern or pattern or pattern, sc, scCode) .. '\n'
output = output .. '| ' .. joinSuffix(stem, pattern or pattern or pattern or pattern, sc, scCode) .. '\n'
end
output = output .. '|}</div></div>'
return output
end
function export.show(frame)
local g = frame.args
local params = {
head = {default = PAGENAME},
decl = {default = nil},
n = {default = 'sdp'},
= {alias_of = 'head'},
= {alias_of = 'decl'},
= {alias_of = 'n'},
}
local args = m_para.process(frame:getParent().args, params)
local sc = m_scripts.findBestScript(args.head, lang)
local scCode = sc:getCode()
if scCode == 'None' then
error('No script was detected for headword ' .. args.head .. '".')
end
if args.decl == nil then
for pattern, declension in pairs(endings) do
if mw.ustring.match(args.head, pattern) ~= nil then
args.decl = declension
break
end
end
end
if args.decl == nil then
error("No declension class could be detected. Please check the lemma form or specify the declension.")
end
local m_pattern = require('Module:User:JohnC5/Sandbox/' .. scCode)
local pattern = m_pattern
local output = ''
if args.n == 'sdp' then
output = make_full_table(args.head, pattern, g, sc, scCode)
elseif args.n == 's' then
output = make_sing_table(args.head, pattern, g, sc, scCode)
elseif args.n == 'p' then
output = make_plur_table(args.head, pattern, g, sc, scCode)
else
error('The number parameter ("n" or the 3rd position) must left empty or specified as "sdp" for singular-dual-plural, "s" for singular, or "p" for plural')
end
return output
end
return export