A modult a Modul:accel/fi/doc lapon tudod dokumentálni
return {generate = function (params, entry)
local headparam = {}
local formparam = {
= 'case=nominative|pl=plural',
= 'case=genitive|pl=singular',
= 'case=genitive|pl=plural',
= 'case=partitive|pl=singular',
= 'case=partitive|pl=plural',
= 'case=accusative|pl=singular',
= 'case=accusative|pl=plural',
= 'case=inessive|pl=singular',
= 'case=inessive|pl=plural',
= 'case=elative|pl=singular',
= 'case=elative|pl=plural',
= 'case=illative|pl=singular',
= 'case=illative|pl=plural',
= 'case=adessive|pl=singular',
= 'case=adessive|pl=plural',
= 'case=ablative|pl=singular',
= 'case=ablative|pl=plural',
= 'case=allative|pl=singular',
= 'case=allative|pl=plural',
= 'case=essive|pl=singular',
= 'case=essive|pl=plural',
= 'case=translative|pl=singular',
= 'case=translative|pl=plural',
= 'case=instructive|pl=plural',
= 'case=comitative|pl=plural', -- needs alt forms
= 'case=abessive|pl=singular',
= 'case=abessive|pl=plural'}
local participle_heads = {
= 'present active participle',
= 'present passive participle',
= 'past active participle',
= 'past passive participle',
= 'agent participle',
= 'negative participle',
}
local function scan_vowel_harmony(word)
for pos = #word, 1, -1 do
local char = mw.ustring.sub(word, pos, pos)
if mw.ustring.match(char, "") then
return "a"
elseif mw.ustring.match(char, "") then
return "ä"
end
end
return "ä"
end
local function generate_participle_declension(word, type)
local vhua = { = "a", = "ä" }
local lword = mw.ustring.len(word)
if type == "pres|actv" then -- ...vA
return "{{fi-decl-koira|pos=adj|" .. mw.ustring.sub(word, 1, lword - 1) .. "|||" .. mw.ustring.sub(word, lword, lword) .. "}}"
elseif type == "pres|pasv" then -- ...(t)tAvA
return "{{fi-decl-koira|pos=adj|" .. mw.ustring.sub(word, 1, lword - 1) .. "|||" .. mw.ustring.sub(word, lword, lword) .. "}}"
elseif type == "past|actv" then -- ...(n)Ut
return "{{fi-decl-kuollut|pos=adj|" .. mw.ustring.sub(word, 1, lword - 2) .. "|" .. vhua .. "}}"
elseif type == "past|pasv" then -- ...tU
-- this is the most complicated one
local special = mw.ustring.sub(word, lword - 2, lword - 2)
local final = mw.ustring.sub(word, lword, lword) -- U
final = final .. "|" .. vhua -- U|A
if special == "l" or special == "n" or special == "r" then
return "{{fi-decl-valo|pos=adj|" .. mw.ustring.sub(word, 1, lword - 3) .. "|" .. special .. "t|" .. special .. special .. "|" .. final .. "}}"
elseif special == "t" then
return "{{fi-decl-valo|pos=adj|" .. mw.ustring.sub(word, 1, lword - 3) .. "|tt|t|" .. final .. "}}"
elseif special == "s" then
return "{{fi-decl-valo|pos=adj|" .. mw.ustring.sub(word, 1, lword - 1) .. "|||" .. final .. "}}"
else
return "{{fi-decl-valo|pos=adj|" .. mw.ustring.sub(word, 1, lword - 2) .. "|t|d|" .. final .. "}}"
end
elseif type == "agent" then -- ...mA
return "{{fi-decl-koira|pos=adj|" .. mw.ustring.sub(word, 1, lword - 1) .. "|||" .. mw.ustring.sub(word, lword, lword) .. "}}"
elseif type == "neg" then -- ...mAtOn
return "{{fi-decl-onneton|pos=adj|" .. mw.ustring.sub(word, 1, lword - 3) .. "|" .. mw.ustring.sub(word, lword - 3, lword - 3) .. "}}"
else
return nil -- ????
end
end
local was_rare = false
if params.form:sub(1, 5) == "rare-" then
was_rare = true
params.form = params.form:sub(6)
end
if params.form:sub(1, 11) == "comparative" then
local form, vh = unpack(mw.text.split(params.form, '|', true))
local vhfooter = scan_vowel_harmony(params.origin) .. "}} {{attention|fi|verify that vowel harmony is correct}}"
if vh == "a" or vh == "ä" then
vhfooter = vh .. "}}"
end
entry.head = '{{head|' .. params.lang .. '|comparative ' .. params.pos .. '}}'
entry.def = '{{comparative of|fi|' .. params.origin .. '|nocat=1}}'
if params.pos == "adjective" then
if mw.ustring.sub(params.target, -3) == "mpi" then
entry.declension = "{{fi-decl-vanhempi|pos=adj|" ..
mw.ustring.sub(params.target, 1, -4) .. "|" .. vhfooter
elseif mw.ustring.sub(params.target, -4) == "inen" then
entry.declension = "{{fi-decl-nainen|pos=adj|" ..
mw.ustring.sub(params.target, 1, -4) .. "|" .. vhfooter
else
entry.declension = "{{rfinfl|fi}}"
end
end
elseif params.form:sub(1, 11) == "superlative" then
local form, vh = unpack(mw.text.split(params.form, '|', true))
local vhfooter = scan_vowel_harmony(params.origin) .. "}} {{attention|fi|verify that vowel harmony is correct}}"
if vh == "a" or vh == "ä" then
vhfooter = vh .. "}}"
end
entry.head = '{{head|' .. params.lang .. '|superlative ' .. params.pos .. '}}'
entry.def = '{{superlative of|fi|' .. params.origin .. '|nocat=1}}'
if params.pos == "adjective" then
entry.declension = "{{fi-decl-sisin|pos=adj|" ..
mw.ustring.sub(params.target, 1, -3) .. "|" .. vhfooter
end
elseif params.form:sub(1, 15) == "part-possessive" then
-- possessive form of adverbial
entry.head = '{{head|' .. params.lang .. '|' .. params.pos .. ' form}}'
local form, poss = unpack(mw.text.split(params.form, '|', true))
-- replace 3s,3p => 3, because 3rd person singular and plural are identical and "third-person" is thus enough
entry.def = '{{inflection of|fi|' .. params.origin .. '||' .. poss:gsub("(%d)(%a)", "%1|%2|form"):gsub("3%|%a", "3") .. '}}'
elseif params.form:sub(1, 10) == "possessive" then
-- possessive form of nominal
if params.pos == "noun" then
entry.head = '{{head|' .. params.lang .. '|noun possessive form}}'
else
entry.head = '{{head|' .. params.lang .. '|' .. params.pos .. ' form}}'
end
local form, poss, decltype, inflection = unpack(mw.text.split(params.form, '|', true))
inflection = require('Module:base64').decode(inflection)
entry.def = '{{inflection of|fi|' .. params.origin .. '||' .. poss:gsub("(%d)(%a)", "%1|%2|poss"):gsub("3%|%a", "3") .. '}}'
-- copy declension for possessive from original entry
entry.declension = "{{fi-decl-" .. decltype .. "|poss=" .. poss .. "|" .. inflection .. "}}"
elseif params.form:sub(1, 11) == "participle-" then
-- participles; require declension
local infl = mw.ustring.sub(params.form, #"participle-" + 1)
local declension = generate_participle_declension(params.target, infl)
if declension == nil then error("Unsupported participle") end
entry.def = '{{inflection of|fi|' .. params.origin .. '||' .. infl .. '|part}}'
entry.head = '{{head|fi|' .. (participle_heads or 'participle') .. '}}'
entry.pos_header = "Participle"
entry.declension = declension
elseif mw.ustring.match(params.form, "^inf1l-") then
-- long first infinitive; requires alt forms for other persons
local vh = mw.ustring.match(params.form, "()$")
if vh ~= "a" and vh ~= "ä" then error("Invalid vowel harmony") end
if not params.target:match("en$") then
error("Unsupported long first infinitive form")
end
entry.head = '{{head|fi|infinitive}}'
entry.def = '{{inflection of|fi|' .. params.origin .. '||3|form|of the|long|first|inf}}'
entry.altforms = '{{fi-alt-personal|' .. mw.ustring.sub(params.target, 1, mw.ustring.len(params.target) - 2) .. '|e|' .. vh .. '}}'
elseif mw.ustring.match(params.form, "^inf5-") then
-- fifth infinitive; requires alt forms for other persons
local vh = mw.ustring.match(params.form, "()$")
if vh ~= "a" and vh ~= "ä" then error("Invalid vowel harmony") end
if not params.target:match("n$") then
error("Unsupported fifth infinitive form")
end
entry.head = '{{head|fi|infinitive}}'
entry.def = '{{inflection of|fi|' .. params.origin .. '||3|form|of the|fifth|inf}}'
entry.altforms = '{{fi-alt-personal|' .. mw.ustring.sub(params.target, 1, mw.ustring.len(params.target) - 2) .. '|' .. vh .. '|' .. vh .. '}}'
elseif mw.ustring.match(params.form, "|inf") then
entry.head = '{{head|fi|infinitive}}'
entry.def = '{{inflection of|fi|' .. params.origin .. '||' .. params.form .. '}}'
elseif mw.ustring.match(params.form, "com%-pl%-") then
-- comitative (plural only); requires alt forms for other persons
local vh = mw.ustring.match(params.form, "com%-pl%-()")
if vh ~= "a" and vh ~= "ä" then error("Invalid vowel harmony") end
entry.head = '{{head|' .. params.lang .. '|'
.. (headparam or params.pos .. ' form') .. '}}'
if params.target:match("en$") then
entry.altforms = '{{fi-alt-personal|' .. params.target:sub(1, (#params.target) - 2) .. '|e|' .. vh .. '}}'
entry.def = '{{inflection of|fi|' .. params.origin .. '||3|poss|form|of|com|p}}'
elseif params.target:match("ne$") then
entry.def = '{{inflection of|fi|' .. params.origin .. '||com|p}}'
else
error("Unsupported comitative form")
end
elseif formparam then
entry.head = '{{head|' .. params.lang .. '|'
.. (headparam or params.pos .. ' form') .. '}}'
entry.def = '{{fi-form of|' .. params.origin .. '|' .. formparam .. '}}'
else
-- needed here because of code below
entry.def = '{{inflection of|fi|' .. params.origin .. '||' .. params.form .. '}}'
end
if was_rare then
entry.def = '{{lb|fi|nocat=1|rare}} ' .. entry.def
end
end}