|
|
| Line 190: |
Line 190: |
| ["dative"] = {short_form = "dat", link = "''[[dative case|dative]]''"}, | | ["dative"] = {short_form = "dat", link = "''[[dative case|dative]]''"}, |
| } | | } |
|
| |
| local function make_headers(data, wikicode)
| |
| table.insert(wikicode, '|- class="vsHide"\n')
| |
| table.insert(wikicode, '! style="background:#' .. '; font-style:italic;" | Number\n')
| |
| table.insert(wikicode, '! style="background:#' .. '; font-style:italic;" | Singular\n')
| |
| table.insert(wikicode, '! style="background:#' .. '; font-style:italic;" | Plural\n')
| |
| end
| |
|
| |
| local function show_form(form, data, branch)
| |
| local function convert_word(form, branch)
| |
| if mw.ustring.find(form, "{{{") then
| |
| return form
| |
| else
| |
| return m_vl_translit.convert_words(form, branch)
| |
| end
| |
| end
| |
|
| |
| if not form then
| |
| return "—"
| |
| end
| |
|
| |
| end
| |
|
| |
| local function make_case(data, wikicode, case)
| |
| local case_short = cases[case].short_form
| |
| table.insert(wikicode, '|- class="vsHide"\n')
| |
| table.insert(wikicode, '! ' .. cases[case].link .. '\n')
| |
| table.insert(wikicode, '| ' .. show_form(data.forms[case_short .. '-sg'], data) .. '\n')
| |
| table.insert(wikicode, '| ' .. show_form(data.forms[case_short .. '-pl'], data) .. '\n')
| |
| end
| |
|
| |
| local function make_table(data, branch)
| |
| local wikicode = {'{| class="prettytable inflection-table vsSwitcher" data-toggle-category="inflection"\n'}
| |
| table.insert(wikicode, '! colspan="5" class="vsToggleElement" style="text-align:left;min-width: 25em;background:#'
| |
| )
| |
|
| |
| make_headers(data, wikicode)
| |
| make_case(data, wikicode, "nominative", branch)
| |
| make_case(data, wikicode, "genitive", branch)
| |
| make_case(data, wikicode, "dative", branch)
| |
| make_case(data, wikicode, "accusative-ablative", branch)
| |
|
| |
| table.insert(wikicode, "|}")
| |
|
| |
| return table.concat(wikicode)
| |
| end
| |
|
| |
| -- The main entry point.
| |
| -- This is the only function that can be invoked from a template.
| |
| function export.show(frame)
| |
| local parent_args = frame:getParent().args
| |
|
| |
| local decl_type = (frame.args["decl"] or parent_args["decl"]) or "a"
| |
|
| |
| if not decls[decl_type] then
| |
| error("Unknown declension type '" .. decl_type .. "'")
| |
| end
| |
|
| |
| local data = {forms = {}}
| |
| data.head = parent_args["head"] or nil
| |
|
| |
| local args = require("Module:parameters").process(parent_args, decls[decl_type].params, true)
| |
|
| |
| 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
| |
|
| |
| return export
| |