local export = {}
local m_links = require("Module:links")
local m_utils = require("Module:utilities")
local lang = require("Module:languages").getByCode("enm")
function table_find (t, pattern)
for _, v in pairs(t) do
if v == pattern then
return true
end
end
end
conj_data = {
params = {
-- Basic parameters
["class"] = {list = true, default = "ed", allow_holes = true},
["type"] = {},
["head"] = {},
[1] = {},
-- [1] = {default = string.sub(mw.title.getCurrentTitle().text, 1, -3)},
[2] = {},
[3] = {},
[4] = {},
[5] = {},
-- Form replacement parameters
["inf"] = {list = true, allow_holes = true},
["1s"] = {list = true, allow_holes = true},
["2s"] = {list = true, allow_holes = true},
["3s"] = {list = true, allow_holes = true},
["p"] = {list = true, allow_holes = true},
["sub"] = {list = true, allow_holes = true},
["imp_p"] = {list = true, allow_holes = true},
["part"] = {list = true, allow_holes = true},
["p_1s"] = {list = true, allow_holes = true},
["p_2s"] = {list = true, allow_holes = true},
["p_p"] = {list = true, allow_holes = true},
["p_sub"] = {list = true, allow_holes = true},
["p_part"] = {list = true, allow_holes = true},
-- Principal part replacement parameters
["1a"] = {list = true, allow_holes = true},
["2a"] = {list = true, allow_holes = true},
["3a"] = {list = true, allow_holes = true},
["4a"] = {list = true, allow_holes = true},
["5a"] = {list = true, allow_holes = true},
["obl"] = {list = true, allow_holes = true},
-- Weak form parameters
["w_class"] = {list = true, allow_holes = true, default = "none"},
["w_irr"] = {},
["w_p"] = {list = true, allow_holes = true},
["w_part"] = {type = "boolean", default = false},
-- Strong form parameters
["s_class"] = {list = true, allow_holes = true, default = "none"},
["s2"] = {list = "s2_", allow_holes = true},
["s3"] = {list = "s3_", allow_holes = true},
["s4"] = {list = "s4_", allow_holes = true},
-- Miscellaneous parameters
["s"] = {},
["i"] = {default = "1"},
["y"] = {},
["pf"] = {default = "0"},
["irr"] = {type = "boolean"},
["nocat"] = {type = "boolean", default = false},
-- Aliases
["c"] = {alias_of = "class", list = true, allow_holes = true},
["past"] = {alias_of = "w_p", list = true, allow_holes = true},
["t"] = {alias_of = "type"},
["w"] = {alias_of = "w_class", list = true, allow_holes = true, default = "none"},
["sc"] = {alias_of = "s_class", list = true, allow_holes = true, default = "none"},
["w_s"] = {alias_of = "s"},
},
}
setmetatable(conj_data, {__call = function(self, args, data, conj_type)
if conj_type ~= "st" and conj_type ~= "wk" and conj_type ~= "irr" then
error("Unknown conjugation '" .. conj_type .. "'")
end
if args[1]:sub(1,1) == "*" then
error("Redundant asterisks")
end
local function weak_forms(class, stem, alt_stem, irr_stem)
classnames = {}
if table_find (class, "irr") then
s_stem = alt_stem
else
s_stem = irr_stem
end
for k, v in ipairs(class) do
if conj_type == "wk" then
l = k - 1
else
l = k
end
if v == "irr" then
if not args[2] then
error("Past stem required for weak irregular verbs")
end
if table_find(classnames, "不規則") ~= true then
table.insert(classnames, "不規則")
end
table.insert(data.forms.past_ind_1s, irr_stem .. "e")
table.insert(data.forms.past_ind_2s, irr_stem .. "est")
table.insert(data.forms.past_sub_s, irr_stem .. "e")
table.insert(data.forms.past_ind_p, irr_stem .. "en")
table.insert(data.forms.past_ind_p, irr_stem .. "e")
table.insert(data.forms.past_part, irr_stem)
if args.nocat == false then
table.insert(data.categories, "中古英語不規則弱變化動詞")
end
end
if v == "sl" then
if table_find(classnames, "無後綴") ~= true then
table.insert(classnames, "無後綴")
end
table.insert(data.forms.past_ind_1s, (args.w_p[l] or s_stem or stem) .. "e")
table.insert(data.forms.past_ind_2s, (args.w_p[l] or s_stem or stem) .. "est")
table.insert(data.forms.past_sub_s, (args.w_p[l] or s_stem or stem) .. "e")
table.insert(data.forms.past_ind_p, (args.w_p[l] or s_stem or stem) .. "en")
table.insert(data.forms.past_ind_p, (args.w_p[l] or s_stem or stem) .. "e")
table.insert(data.forms.past_part, args.w_p[l] or s_stem or stem)
end
if v == "te" then
if table_find(classnames, "含-te") ~= true then
table.insert(classnames, "含-te")
end
table.insert(data.forms.past_ind_1s, (args.w_p[l] or s_stem or stem) .. "te")
table.insert(data.forms.past_ind_2s, (args.w_p[l] or s_stem or stem) .. "test")
table.insert(data.forms.past_sub_s, (args.w_p[l] or s_stem or stem) .. "te")
table.insert(data.forms.past_ind_p, (args.w_p[l] or s_stem or stem) .. "ten")
table.insert(data.forms.past_ind_p, (args.w_p[l] or s_stem or stem) .. "te")
table.insert(data.forms.past_part, (args.w_p[l] or s_stem or stem) .. "t")
end
if v == "de" then
if table_find(classnames, "含-de") ~= true then
table.insert(classnames, "含-de")
end
table.insert(data.forms.past_ind_1s, (args.w_p[l] or s_stem or stem) .. "de")
table.insert(data.forms.past_ind_2s, (args.w_p[l] or s_stem or stem) .. "dest")
table.insert(data.forms.past_sub_s, (args.w_p[l] or s_stem or stem) .. "de")
table.insert(data.forms.past_ind_p, (args.w_p[l] or s_stem or stem) .. "den")
table.insert(data.forms.past_ind_p, (args.w_p[l] or s_stem or stem) .. "de")
table.insert(data.forms.past_part, (args.w_p[l] or s_stem or stem) .. "d")
end
if v == "ed" then
if table_find(classnames, "含-ed") ~= true then
table.insert(classnames, "含-ed")
end
table.insert(data.forms.past_ind_1s, (args.w_p[l] or s_stem or stem) .. "ed")
table.insert(data.forms.past_ind_2s, (args.w_p[l] or s_stem or stem) .. "edest")
table.insert(data.forms.past_sub_s, (args.w_p[l] or s_stem or stem) .. "ed")
table.insert(data.forms.past_ind_p, (args.w_p[l] or s_stem or stem) .. "eden")
table.insert(data.forms.past_ind_p, (args.w_p[l] or s_stem or stem) .. "ede")
table.insert(data.forms.past_part, (args.w_p[l] or s_stem or stem) .. "ed")
end
end
end
local function build_wk_classnames(names)
local names = table.concat(names, "/")
local names = mw.ustring.gsub(names, "-ed/in ", "-ed/")
local names = mw.ustring.gsub(names, "-te/in ", "-te/")
local names = mw.ustring.gsub(names, "-te/in ", "-de/")
return names
end
data.forms["inf"] = {args.head or (args[1] .. "en"), (args[1] .. "e")}
data.forms["pres_ind_1s"] = {args[1] .. "e"}
data.forms["pres_ind_2s"] = {(s_23 or args[1]) .. "est"}
data.forms["pres_ind_3s"] = {(s_23 or args[1]) .. "eth"}
data.forms["pres_ind_p"] = {args[1] .. "en", args[1] .. "e"}
data.forms["pres_sub_s"] = {args[1] .. "e"}
data.forms["imp_p"] = {args[1] .. "eth", args[1] .. "e"}
data.forms["pres_part"] = {(args[1] .. "ynge"), (args[1] .. "ende")}
if conj_type == "st" then
if mw.title.getCurrentTitle().nsText == "Template" then
data.conj_type = "[[Appendix:中古英語動詞#強變化動詞|強變化第1類]]"
elseif args.class[1] == "ed" then
error("Class parameter required for strong verbs")
elseif not args[2] then
error("Past stem required for strong verbs")
elseif args.irr == true then
data.conj_type = "[[Appendix:中古英語動詞#強變化動詞|強變化第" .. table.concat(args.class, "/") .. "類,不規則]]"
if args.nocat == false then
table.insert(data.categories, "中古英語不規則強變化動詞")
end
else
data.conj_type = "[[Appendix:中古英語動詞#強變化動詞|強變化第" .. table.concat(args.class, "/") .. "類]]"
end
data.forms["past_ind_1s"] = {args[2]}
data.forms["past_ind_2s"] = {(args[3] or args[2]) .. "e"}
data.forms["past_ind_p"] = {(args[3] or args[2]) .. "en", (args[3] or args[2]) .. "e"}
data.forms["past_sub_s"] = {(args[3] or args[2]) .. "e"}
data.forms["past_part"] = {(args[4] or args[1]) .. "en", (args[4] or args[1]) .. "e"}
s_23 = args[5]
for _, v in ipairs(args["1a"]) do
table.insert(data.forms.pres_ind_1s, v .. "e")
table.insert(data.forms.pres_ind_2s, v .. "est")
table.insert(data.forms.pres_ind_3s, v .. "eth")
table.insert(data.forms.inf, v .. "en")
table.insert(data.forms.inf, v .. "e")
table.insert(data.forms.pres_ind_p, v .. "en")
table.insert(data.forms.pres_ind_p, v .. "e")
table.insert(data.forms.pres_sub_s, v .. "e")
table.insert(data.forms.pres_part, v .. "ynge")
table.insert(data.forms.pres_part, v .. "ende")
table.insert(data.forms.imp_p, v .. "eth")
table.insert(data.forms.imp_p, v .. "e")
end
for _, v in ipairs(args["3a"]) do
table.insert(data.forms.past_ind_2s, v .. "e")
table.insert(data.forms.past_sub_s, v .. "e")
table.insert(data.forms.past_ind_p, v .. "en")
table.insert(data.forms.past_ind_p, v .. "e")
end
-- Must be inserted here to keep similar second singular past forms together
table.insert(data.forms.past_ind_2s, args[2])
for _, v in ipairs(args["2a"]) do
table.insert(data.forms.past_ind_1s, v)
table.insert(data.forms.past_ind_2s, v)
end
for _, v in ipairs(args["4a"]) do
table.insert(data.forms.past_part, v .. "en")
table.insert(data.forms.past_part, v .. "e")
end
end
if conj_type == "wk" then
data.forms.past_ind_1s = {}
data.forms.past_ind_2s = {}
data.forms.past_ind_p = {}
data.forms.past_sub_s = {}
data.forms.past_part = {}
args["w_p"] = args["2a"]
s_23 = args[3]
ext_classes = args.class
for k = 1, 10 do
if ext_classes[k] == nil and ext_classes[k+1] ~= nil then
table.insert(ext_classes, k, args.class[1])
end
end
if #ext_classes < #args["2a"] + 1 then
repeat
table.insert(ext_classes, 2, args.class[1])
until #ext_classes == #args["2a"] + 1
end
weak_forms(ext_classes, args[1], args.s, args[2])
data.conj_type = "[[Appendix:中古英語動詞#弱變化動詞|弱變化," .. build_wk_classnames(classnames) .. "]]"
if args.s_class[1] == "none" and (args.s2[1] or args.s3[1] or args.s4[1]) then
error("Class parameter required for strong forms")
end
if args.s_class[1] ~= "none" then
if not (args.s2[1] or args.s3[1] or args.s4[1]) then
error("At least one strong past form must be set")
end
for _, v in ipairs(args["s3"]) do
table.insert(data.forms.past_ind_2s, v .. "e")
table.insert(data.forms.past_sub_s, v .. "e")
table.insert(data.forms.past_ind_p, v .. "en")
table.insert(data.forms.past_ind_p, v .. "e")
end
for _, v in ipairs(args["s2"]) do
table.insert(data.forms.past_ind_1s, v)
table.insert(data.forms.past_ind_2s, v)
end
for _, v in ipairs(args["s4"]) do
table.insert(data.forms.past_part, v .. "en")
table.insert(data.forms.past_part, v .. "e")
end
if s_set ~= true then
data.conj_type = data.conj_type .. "或[[Appendix:中古英語動詞#強變化動詞|強變化第 " .. table.concat(args.s_class, "/") .. "類]]"
end
local s_set = true
end
end
if conj_type == "irr" then
data.forms.past_sub_s = {}
if args.type == "been" then
data.conj_type = "[[Appendix:中古英語動詞#不規則變化動詞|不規則變化]]、[[異幹]]"
data.forms["inf"] = {"been", "be"}
data.forms["pres_ind_1s"] = {"am", "be"}
data.forms["pres_ind_2s"] = {"art", "bist"}
data.forms["pres_ind_3s"] = {"is", "bith"}
data.forms["pres_ind_p"] = {"aren", "are", "been", "be"}
data.forms["past_ind_1s"] = {"was"}
data.forms["past_ind_2s"] = {"were"}
data.forms["past_ind_p"] = {"weren", "were"}
data.forms["pres_sub_s"] = {"be"}
data.forms["pres_sub_p"] = {"been", "be"}
data.forms["imp_p"] = {"beth", "be"}
data.forms["pres_part"] = {"beynge", "beende"}
data.forms["past_part"] = {"been", "be"}
if args.nocat == false then
table.insert(data.categories, "中古英語異幹動詞")
end
elseif args.type == "don" then
data.conj_type = "[[Appendix:中古英語動詞#不規則變化動詞|不規則變化]]"
data.forms["inf"] = {"don", "do"}
data.forms["pres_ind_1s"] = {"do"}
data.forms["pres_ind_2s"] = {"dost", "dest"}
data.forms["pres_ind_3s"] = {"doth", "deth"}
data.forms["pres_ind_p"] = {"don", "do"}
data.forms["past_ind_1s"] = {"dide"}
data.forms["past_ind_2s"] = {"didest", "dide"}
data.forms["past_ind_p"] = {"diden", "dide"}
data.forms["pres_sub_s"] = {"do"}
data.forms["imp_p"] = {"doth", "do"}
data.forms["pres_part"] = {"doynge", "donde"}
data.forms["past_part"] = {"don", "do"}
if args.nocat == false then
table.insert(data.categories, "中古英語不規則變化動詞")
end
elseif args.type == "gon" then
data.conj_type = "[[Appendix:中古英語動詞#不規則變化動詞|不規則變化]],[[異幹]]"
data.forms["inf"] = {"gon", "go"}
data.forms["pres_ind_1s"] = {"go"}
data.forms["pres_ind_2s"] = {"gost", "gest"}
data.forms["pres_ind_3s"] = {"goth", "geth"}
data.forms["pres_ind_p"] = {"gon", "go"}
data.forms["past_ind_1s"] = {"yede", "wente"}
data.forms["past_ind_2s"] = {"yedest", "wentest"}
data.forms["past_ind_p"] = {"yeden", "yede", "wenten", "wente"}
data.forms["pres_sub_s"] = {"go"}
data.forms["imp_p"] = {"goth", "go"}
data.forms["pres_part"] = {"goynge", "gonde"}
data.forms["past_part"] = {"gon", "go"}
if args.nocat == false then
table.insert(data.categories, "中古英語異幹動詞")
end
elseif args.type == "willen" then
data.conj_type = "[[Appendix:中古英語動詞#不規則變化動詞|不規則變化]]"
data.forms["inf"] = {"willen", "wille", "wollen", "wolle"}
data.forms["pres_ind_1s"] = {"wille", "wolle"}
data.forms["pres_ind_2s"] = {"wilt", "wolt"}
data.forms["pres_ind_3s"] = {"wille", "wolle"}
data.forms["pres_ind_p"] = {"willen", "wille", "wollen", "wolle"}
data.forms["past_ind_1s"] = {"wolde"}
data.forms["past_ind_2s"] = {"woldest", "wolde"}
data.forms["past_ind_p"] = {"wolden", "wolde"}
data.forms["pres_sub_s"] = {"wille"}
data.forms["imp_p"] = {"—"}
data.forms["pres_part"] = {"willynge", "willende"}
data.forms["past_part"] = {"—"}
if args.nocat == false then
table.insert(data.categories, "中古英語不規則變化動詞")
table.insert(data.categories, "中古英語不完全變化動詞")
end
else
data.conj_type = "[[Appendix:中古英語動詞#過去-現在時動詞|preterite-present]]"
if not args[2] then
error("Past stem required for preterite-present verbs")
end
data.forms["inf"] = {args.head or ((args[3] or args[1]) .. "en"), ((args[3] or args[1]) .. "e")}
data.forms["pres_ind_1s"] = {args[1]}
data.forms["pres_ind_2s"] = {args[4] or (args[1] .. "st")}
data.forms["pres_ind_3s"] = {args[1]}
data.forms["pres_ind_p"] = {(args[3] or args[1]) .. "en", (args[3] or args[1]) .. "e"}
data.forms["past_ind_1s"] = {args[2] .. "e"}
data.forms["past_ind_2s"] = {args[2] .. "est"}
data.forms["past_ind_p"] = {args[2] .. "en", args[2] .. "e"}
data.forms["pres_sub_s"] = {(args[3] or args[1]) .. "e"}
data.forms["imp_p"] = {(args[3] or args[1]) .. "eth", (args[3] or args[1]) .. "e"}
data.forms["pres_part"] = {((args[3] or args[1]) .. "ynge"), ((args[3] or args[1]) .. "ende")}
data.forms["past_part"] = {(args[3] or args[1]) .. "en", (args[3] or args[1]) .. "e"}
if args.w_class[1] ~= "none" then
table.insert(data.forms.pres_ind_2s, args[2] .. "est")
table.insert(data.forms.pres_ind_3s, args[2] .. "eth")
end
if args.nocat == false then
table.insert(data.categories, "中古英語過去-現在時動詞")
end
end
for _, v in ipairs(args["1a"]) do
table.insert(data.forms.pres_ind_1s, v)
table.insert(data.forms.pres_ind_3s, v)
end
for _, v in ipairs(args["2a"]) do
table.insert(data.forms.past_ind_1s, v .. "e")
table.insert(data.forms.past_ind_2s, v .. "est")
table.insert(data.forms.past_ind_p, v .. "en")
table.insert(data.forms.past_ind_p, v .. "e")
end
for _, v in ipairs(args["obl"]) do
table.insert(data.forms.inf, v .. "e")
table.insert(data.forms.pres_ind_p, v .. "en")
table.insert(data.forms.pres_ind_p, v .. "e")
table.insert(data.forms.pres_sub_s, v .. "e")
table.insert(data.forms.imp_p, v .. "eth")
table.insert(data.forms.imp_p, v .. "e")
end
for _, v in ipairs(args["3a"]) do
table.insert(data.forms.inf, v .. "e")
table.insert(data.forms.pres_ind_p, v .. "en")
table.insert(data.forms.pres_ind_p, v .. "e")
table.insert(data.forms.pres_sub_s, v .. "e")
table.insert(data.forms.pres_part, v .. "ynge")
table.insert(data.forms.pres_part, v .. "ende")
table.insert(data.forms.past_part, v .. "en")
table.insert(data.forms.past_part, v .. "e")
table.insert(data.forms.imp_p, v .. "eth")
table.insert(data.forms.imp_p, v .. "e")
end
end
if conj_type ~= "wk" then
weak_forms(args.w_class, args[1], args.s, args.w_irr)
if args.w_class[1] ~= "none" and wk_set ~= true then
data.conj_type = data.conj_type .. "或[[Appendix:中古英語動詞#弱變化動詞|弱變化," .. build_wk_classnames(classnames) .. "]]"
end
local wk_set = true
end
local function custom_form(forms, slot)
if table_find(forms, "—") == true then
for k, _ in pairs(forms) do
slot[k] = nil
end
slot[1] = "—"
slot[2] = nil
else for k, v in pairs(forms) do
slot[k] = v
end
for k, v in pairs(slot) do
slot[k] = mw.ustring.gsub(v, "ttt", "tt")
end
for k, v in pairs(slot) do
slot[k] = mw.ustring.gsub(v, "ddd", "dd")
end
for k, v in pairs(slot) do
slot[k] = mw.ustring.gsub(v, "[nsrl][stld][td]", {
["ntt"] = "nt",
["stt"] = "st",
["rtt"] = "rt",
["ltt"] = "lt",
["ndd"] = "nd",
["sdd"] = "sd",
["rdd"] = "rd",
["ldd"] = "ld",
["lld"] = "ld",
["sdt"] = "st",
["ndt"] = "nt",
["rdt"] = "rt",
["ldt"] = "lt",
["sst"] = "st",
})
end
end
end
custom_form(args.inf, data.forms.inf)
custom_form(args["1s"], data.forms.pres_ind_1s)
custom_form(args["2s"], data.forms.pres_ind_2s)
custom_form(args["3s"], data.forms.pres_ind_3s)
custom_form(args.p, data.forms.pres_ind_p)
custom_form(args["sub"], data.forms.pres_sub_s)
custom_form(args.imp_p, data.forms.imp_p)
custom_form(args.part, data.forms.pres_part)
custom_form(args.p_1s, data.forms.past_ind_1s)
custom_form(args.p_2s, data.forms.past_ind_2s)
custom_form(args.p_p, data.forms.past_ind_p)
custom_form(args.p_sub, data.forms.past_sub_s)
custom_form(args.p_part, data.forms.past_part)
if args["i"] == "0" then
data.forms.imp_p = {"—"}
data.forms.inf = {"—"}
data.forms.pres_part = {"—"}
data.forms.past_part = {"—"}
end
if args["w_part"] == true then
table.insert(data.forms.past_part, args[2])
for _, v in ipairs(args["2a"]) do
table.insert(data.forms.past_part, v)
end
end
for k, v in pairs(data.forms.past_part) do
data.forms.past_part[k] = mw.ustring.gsub(v, "dd$", "d")
end
for k, v in pairs(data.forms.past_part) do
data.forms.past_part[k] = mw.ustring.gsub(v, "tt$", "t")
end
local function find_dash(v)
if table_find (v, "—") == true then
table.insert(data.categories, "中古英語不完全變化動詞")
if def_set ~= true then
data.conj_type = data.conj_type .. ",[[Appendix:Glossary#不完全變化|不完全變化]]"
end
def_set = true
end
end
for _, v in pairs(data.forms) do
find_dash(v)
end
if args.pf ~= "0" then
local function add_prefix(t)
for k, v in ipairs(t) do
if v ~= "0" then
t[k] = args.pf .. v
end
end
end
for _, v in pairs(data.forms) do
add_prefix(v)
end
elseif args.y == "0" or table_find (data.forms.past_part, "—") then
elseif args.y == "2" then
yforms = {}
for k, v in ipairs(data.forms.past_part) do
yforms[k] = "y" .. v
end
if data.forms.past_part[4] then
y_abbrev = 1
else for _, item in pairs(yforms) do
table.insert(data.forms.past_part, item)
end
end
elseif args.y == "p1" then
data.forms.past_part[#data.forms.past_part + 1] = "y" .. data.forms.past_part[1]
elseif args.y == "p2" then
if not data.forms.past_part[2] then
error("Parameter 'y' is set to 'p2', but only one past participle was supplied")
else
data.forms.past_part[#data.forms.past_part + 1] = "y" .. data.forms.past_part[2]
end
elseif args.y == "p3" then
if not data.forms.past_part[3] then
error("Parameter 'y' is set to 'p3', but less than three past participles were supplied")
else
data.forms.past_part[#data.forms.past_part + 1] = "y" .. data.forms.past_part[3]
end
else
if data.forms.past_part[2] then
data.forms.past_part[#data.forms.past_part + 1] = "y" .. data.forms.past_part[1]
data.forms.past_part[#data.forms.past_part + 1] = "y" .. data.forms.past_part[2]
else
data.forms.past_part[#data.forms.past_part + 1] = "y" .. data.forms.past_part[1]
end
end
if args.nocat == false then
if conj_type == "st" then
for _, v in ipairs(args.class) do
table.insert(data.categories, "中古英語" .. v .. "類強變化動詞")
end
end
if args.s_class[1] ~= "none" then
for _, v in ipairs(args.s_class) do
table.insert(data.categories, "中古英語" .. v .. "類強變化動詞")
end
end
if conj_type == "wk" or args.w_class[1] ~= "none" then
table.insert(data.categories, "中古英語弱變化動詞")
end
end
end
})
local function add_asterisks(forms, data)
for _, form in ipairs(forms) do
for i, subform in ipairs(data.forms[form]) do
data.forms[form][i] = "*" .. subform
end
end
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 conj_type = (frame.args["conj"] or parent_args["conj"]) or "st"
local data = {forms = {}, categories = {}}
data.head = parent_args["head"] or nil
local args = require("Module:parameters").process(parent_args, conj_data.params, true)
-- Override for templates
if not args[1] then
setmetatable(args, {__index = function(self, key)
return "{{{" .. key .. "}}}"
end
})
end
-- Generate the forms
conj_data(args, data, conj_type)
-- Make the table
local function show_form(form)
if not form then
return "—"
end
local ret = {}
for key, subform in ipairs(form) do
if mw.title.getCurrentTitle().nsText == "Reconstruction" and subform ~= "—" then
subform = "*" .. subform
end
if subform == "0" then
elseif subform == "y0" then
elseif subform == "—" then
table.insert(ret, "—")
elseif form == data.forms["past_sub_s"] then
table.insert(ret, m_links.full_link({lang = lang, term = subform}) .. [=[<sup style="color:red; font-weight: normal;">1</sup>]=])
elseif form == data.forms["past_part"] and y_abbrev == 1 then
table.insert(ret, "(" .. m_links.full_link({lang = lang, alt = "y", term = yforms[key]}) .. ")" .. m_links.full_link({lang = lang, term = subform}))
else
table.insert(ret, m_links.full_link({lang = lang, term = subform}))
end
end
return table.concat(ret, ", ")
end
data.forms["title"] = {}
-- table.insert(data.forms.title, mw.title.getCurrentTitle().text)
local function repl(param)
if param == "title" and mw.title.getCurrentTitle().nsText == "Reconstruction" then
return "*" .. mw.title.getCurrentTitle().subpageText
elseif param == "title" then
return mw.title.getCurrentTitle().subpageText
elseif param == "conj_type" then
return data.conj_type
elseif param == "inf" and not table_find(data.forms.inf , "—" ) then
return "(to) " .. show_form(data.forms[param])
-- elseif param == "past_part" and y_abbrev == 1 then
-- return "(to) " .. show_form(data.forms["past_part"])
else
return show_form(data.forms[param])
end
end
if conj_type == "irr" and parent_args.type == "been" then
local wikicode = [=[
<div class="NavFrame" style="width: 42em">
<div class="NavHead">''{{{title}}}'' 的變位({{{conj_type}}})</div>
<div class="NavContent">
{| style="width:100%; margin: 0px;" class="wikitable inflection-table"
|-
! [[不定式]]
| colspan="3" | {{{inf}}}
|-
|
! style="width: 50%; white-space: nowrap;" | [[現在時]]
! style="width: 50%; white-space: nowrap;" | [[過去式]]
|-
! style="white-space: nowrap;" | [[第一人稱]][[單數]]
| {{{pres_ind_1s}}}
| {{{past_ind_1s}}}
|-
! style="white-space: nowrap;" | [[第二人稱]][[單數]]
| {{{pres_ind_2s}}}
| {{{past_ind_2s}}}
|-
! style="white-space: nowrap;" | [[第三人稱]][[單數]]
| {{{pres_ind_3s}}}
| {{{past_ind_1s}}}
|-
! style="white-space: nowrap;" | [[虛擬式]][[單數]]
| rowspan="2" | {{{pres_sub_s}}}
| {{{past_ind_2s}}}
|-
! style="white-space: nowrap;" | [[命令式]][[單數]]
| —
|-
| colspan="3" |
|-
![[複數]]<sup style="color:red; font-weight: normal;">1</sup>
| {{{pres_ind_p}}}
| rowspan="2" | {{{past_ind_p}}}
|-
! [[虛擬式]][[複數]]<sup style="color:red; font-weight: normal;">1</sup>
| {{{pres_sub_p}}}
|-
! [[命令式]][[複數]]
| {{{imp_p}}}
| —
|-
| colspan="3" |
|-
! [[分詞]]
| {{{pres_part}}}
| {{{past_part}}}
|}
<div style="width:100%;text-align:left;background:#f7f8fa">
<div style="display:inline-block;text-align:left;padding-left:1em;padding-right:1em">
<strong style="color:red"><sup>1</sup></strong>有時用作正式第二人稱單數形。
</div></div></div></div>]=]
return (mw.ustring.gsub(wikicode, "{{{([a-z0-9_]+)}}}", repl)) .. m_utils.format_categories(data.categories, lang)
elseif table_find(data.forms.imp_p, "—") then
local wikicode = [=[
<div class="NavFrame" style="width: 42em">
<div class="NavHead">''{{{title}}}'' 的變位({{{conj_type}}})</div>
<div class="NavContent">
{| style="width:100%; margin: 0px;" class="wikitable inflection-table"
|-
! [[不定式]]
| colspan="3" | {{{inf}}}
|-
|
! style="width: 50%; white-space: nowrap;" | [[現在時]]
! style="width: 50%; white-space: nowrap;" | [[過去式]]
|-
! style="white-space: nowrap;" | [[第一人稱]][[單數]]
| {{{pres_ind_1s}}}
| {{{past_ind_1s}}}
|-
! style="white-space: nowrap;" | [[第二人稱]][[單數]]
| {{{pres_ind_2s}}}
| {{{past_ind_2s}}}
|-
! style="white-space: nowrap;" | [[第三人稱]][[單數]]
| {{{pres_ind_3s}}}
| rowspan="2" | {{{past_ind_1s}}}
|-
! style="white-space: nowrap;" | [[虛擬式]][[單數]]
| {{{pres_sub_s}}}
|-
! style="white-space: nowrap;" | [[命令式]][[單數]]
| —
| —
|-
| colspan="3" |
|-
![[複數]]<sup style="color:red; font-weight: normal;">1</sup>
| {{{pres_ind_p}}}
| {{{past_ind_p}}}
|-
! [[命令式]][[複數]]
| {{{imp_p}}}
| —
|-
| colspan="3" |
|-
! [[分詞]]
| {{{pres_part}}}
| {{{past_part}}}
|}
<div style="width:100%;text-align:left;background:#f7f8fa">
<div style="display:inline-block;text-align:left;padding-left:1em;padding-right:1em">
<strong style="color:red"><sup>1</sup></strong>有時用作正式第二人稱單數形。
</div></div></div></div>]=]
return (mw.ustring.gsub(wikicode, "{{{([a-z0-9_]+)}}}", repl)) .. m_utils.format_categories(data.categories, lang)
elseif conj_type == "st" or (parent_args.sc or parent_args.s_class) ~= nil then
local wikicode = [=[
<div class="NavFrame" style="width: 42em">
<div class="NavHead">''{{{title}}}'' 的變位({{{conj_type}}})</div>
<div class="NavContent">
{| style="width:100%; margin: 0px;" class="wikitable inflection-table"
|-
! [[不定式]]
| colspan="3" | {{{inf}}}
|-
|
! style="width: 50%; white-space: nowrap;" | [[現在時]]
! style="width: 50%; white-space: nowrap;" | [[過去式]]
|-
! style="white-space: nowrap;" | [[第一人稱]][[單數]]
| {{{pres_ind_1s}}}
| {{{past_ind_1s}}}
|-
! style="white-space: nowrap;" | [[第二人稱]][[單數]]
| {{{pres_ind_2s}}}
| {{{past_ind_2s}}}
|-
! style="white-space: nowrap;" | [[第三人稱]][[單數]]
| {{{pres_ind_3s}}}
| {{{past_ind_1s}}}
|-
! style="white-space: nowrap;" | [[虛擬式]][[單數]]
| rowspan="2" | {{{pres_sub_s}}}
| {{{past_sub_s}}}
|-
! style="white-space: nowrap;" | [[命令式]][[單數]]
| —
|-
| colspan="3" |
|-
![[複數]]<sup style="color:red; font-weight: normal;">2</sup>
| {{{pres_ind_p}}}
| {{{past_ind_p}}}
|-
! [[命令式]][[複數]]
| {{{imp_p}}}
| —
|-
| colspan="3" |
|-
! [[分詞]]
| {{{pres_part}}}
| {{{past_part}}}
|}
<div style="width:100%;text-align:left;background:#f7f8fa">
<div style="display:inline-block;text-align:left;padding-left:1em;padding-right:1em">
<strong style="color:red"><sup>1</sup></strong>晚期中古英語中,被直陳式代替。<br/><strong style="color:red"><sup>2</sup></strong>有時用作正式第二人稱單數形。
</div></div></div></div>]=]
return (mw.ustring.gsub(wikicode, "{{{([a-z0-9_]+)}}}", repl)) .. m_utils.format_categories(data.categories, lang)
else
local wikicode = [=[
<div class="NavFrame" style="width: 42em">
<div class="NavHead">''{{{title}}}'' 的變位({{{conj_type}}})</div>
<div class="NavContent">
{| style="width:100%; margin: 0px;" class="wikitable inflection-table"
|-
! [[不定式]]
| colspan="3" | {{{inf}}}
|-
|
! style="width: 50%; white-space: nowrap;" | [[現在時]]
! style="width: 50%; white-space: nowrap;" | [[過去式]]
|-
! style="white-space: nowrap;" | [[第一人稱]][[單數]]
| {{{pres_ind_1s}}}
| {{{past_ind_1s}}}
|-
! style="white-space: nowrap;" | [[第二人稱]][[單數]]
| {{{pres_ind_2s}}}
| {{{past_ind_2s}}}
|-
! style="white-space: nowrap;" | [[第三人稱]][[單數]]
| {{{pres_ind_3s}}}
| rowspan="2" | {{{past_ind_1s}}}
|-
! style="white-space: nowrap;" | [[虛擬式]][[單數]]
| rowspan="2" | {{{pres_sub_s}}}
|-
! style="white-space: nowrap;" | [[命令式]][[單數]]
| —
|-
| colspan="3" |
|-
! [[複數]]<sup style="color:red; font-weight: normal;">1</sup>
| {{{pres_ind_p}}}
| {{{past_ind_p}}}
|-
! [[命令式]][[複數]]
| {{{imp_p}}}
| —
|-
| colspan="3" |
|-
! [[分詞]]
| {{{pres_part}}}
| {{{past_part}}}
|}
<div style="width:100%;text-align:left;background:#f7f8fa">
<div style="display:inline-block;text-align:left;padding-left:1em;padding-right:1em">
<strong style="color:red"><sup>1</sup></strong>有時用作正式第二人稱單數形。
</div></div></div></div>]=]
return (mw.ustring.gsub(wikicode, "{{{([a-z0-9_]+)}}}", repl)) .. m_utils.format_categories(data.categories, lang)
end
end
return export