Module:pl-adj

Hello, you have come here looking for the meaning of the word Module:pl-adj. In DICTIOUS you will not only get to know all the dictionary meanings for the word Module:pl-adj, but we will also tell you about its etymology, its characteristics and you will know how to say Module:pl-adj in singular and plural. Everything you need to know about the word Module:pl-adj you have here. The definition of the word Module:pl-adj will help you to be more precise and correct when speaking or writing your texts. Knowing the definition ofModule:pl-adj, as well as those of other words, enriches your vocabulary and provides you with more and better linguistic resources.

This module implements {{pl-decl-adj}} and {{pl-decl-adj-auto}}.

See also: Module:pl-adj/testcases.


local gender = require('Module:gender and number')
local m_links = require('Module:links')

local lang = require("Module:languages").getByCode("pl")

local export = {}

-- automatic declension

local inflectors = {}

inflectors))e?$"] = function (pargs, stem, substem, extra)
	local ending = {  = "cy";  = "dzy"; }
	return {
		stem .. "i",
		stem .. "a",
		stem .. "ie",
		substem .. ending,
		stem .. "ie",
		stem .. "iego",
		stem .. "iej",
		stem .. "ich",
		stem .. "iemu",
		stem .. "im",
		stem .. "ą",
		stem .. "im",
		stem .. "imi",
		(pargs.olddat and (stem .. "u") or nil)
	}
end

inflectorsi)?$"] = function (pargs, stem, substem)
	return {
		stem,
		stem .. "a",
		stem .. "e",
		stem,
		stem .. "e",
		stem .. "ego",
		stem .. "ej",
		stem .. "ch",
		stem .. "emu",
		stem .. "m",
		stem .. "ą",
		stem .. "m",
		stem .. "mi"
	}
end

inflectors$"] = function (pargs, stem, substem)
	return {
		stem .. "i",
		stem .. "a",
		stem .. "e",
		stem .. "i",
		stem .. "e",
		stem .. "ego",
		stem .. "ej",
		stem .. "ich",
		stem .. "emu",
		stem .. "im",
		stem .. "ą",
		stem .. "im",
		stem .. "imi"
	}
end

inflectors?$"] = function (pargs, stem, substem)
	return {
		stem .. "i",
		stem .. "ia",
		stem .. "ie",
		stem .. "i",
		stem .. "ie",
		stem .. "iego",
		stem .. "iej",
		stem .. "ich",
		stem .. "iemu",
		stem .. "im",
		stem .. "ią",
		stem .. "im",
		stem .. "imi"
	}
end

inflectors)n)$"] = function (pargs, stem, substem, extra)
	local mpl_suffix

	if stem:match("zielon$") or stem:match("czerwon$") or stem:match("słon$") then
		-- probably the only exceptions
		mpl_suffix = "oni"
	else
		mpl_suffix = ({  = "eni",  = "śni",  = "źni" })
	end

	return {
		stem .. "y",
		stem .. "a",
		stem .. "e",
		substem .. mpl_suffix,
		stem .. "e",
		stem .. "ego",
		stem .. "ej",
		stem .. "ych",
		stem .. "emu",
		stem .. "ym",
		stem .. "ą",
		stem .. "ym",
		stem .. "ymi",
	}
end
inflectors)(z)n)$"] = inflectors)n)$"]

-- .* instead of .+ due to ] (why are we using .+ in general anyway?)
inflectorsn)$"] = function (pargs, stem, substem, extra)
	return {
		stem .. "y",
		stem .. "a",
		stem .. "e",
		stem .. "i",
		stem .. "e",
		stem .. "ego",
		stem .. "ej",
		stem .. "ych",
		stem .. "emu",
		stem .. "ym",
		stem .. "ą",
		stem .. "ym",
		stem .. "ymi"
	}
end
inflectorszn)$"] = inflectorsn)$"]

inflectors)$"] = function (pargs, stem, substem)
	return {
		stem .. "y",
		stem .. "a",
		stem .. "e",
		stem .. "i",
		stem .. "e",
		stem .. "ego",
		stem .. "ej",
		stem .. "ych",
		stem .. "emu",
		stem .. "ym",
		stem .. "ą",
		stem .. "ym",
		stem .. "ymi"
	}
end

inflectors$"] = function (pargs, stem, substem)
	return {
		stem .. "y",
		stem .. "a",
		stem .. "e",
		substem .. "i",
		stem .. "e",
		stem .. "ego",
		stem .. "ej",
		stem .. "ych",
		stem .. "emu",
		stem .. "ym",
		stem .. "ą",
		stem .. "ym",
		stem .. "ymi"
	}
end

inflectors)$"] = function (pargs, stem, substem)
	return {
		stem .. "y",
		stem .. "a",
		stem .. "e",
		stem .. "y",
		stem .. "e",
		stem .. "ego",
		stem .. "ej",
		stem .. "ych",
		stem .. "emu",
		stem .. "ym",
		stem .. "ą",
		stem .. "ym",
		stem .. "ymi"
	}
end
inflectorsz)$"] = inflectors)$"]

inflectors))$"] = function (pargs, stem, substem, extra)
	local soft_mpl_cons = {  = "si",  = "si",  = "źli",  = "śli",  = "li",  = "rzy",  = "ci",  = "ści",  = "dzi" }
	
	return {
		stem .. "y",
		stem .. "a",
		stem .. "e",
		substem .. soft_mpl_cons,
		stem .. "e",
		stem .. "ego",
		stem .. "ej",
		stem .. "ych",
		stem .. "emu",
		stem .. "ym",
		stem .. "ą",
		stem .. "ym",
		stem .. "ymi",
		(pargs.olddat and (stem .. "u") or nil)
	}
end
inflectors$"] = inflectors))$"]
inflectors)(zł))$"] = inflectors))$"]
inflectors$"] = inflectors))$"]
inflectors)(ł))$"] = inflectors))$"]
inflectors$"] = inflectors))$"]
inflectors$"] = inflectors))$"]
inflectors)(t))$"] = inflectors))$"]

-- archaic forms
inflectors)en$"] = function (pargs, stem, substem, extra)
	return {
		stem .. "en",
		stem .. "na",
		stem .. "ne",
		stem .. "ni",
		stem .. "ne",
		stem .. "nego",
		stem .. "nej",
		stem .. "nych",
		stem .. "nemu",
		stem .. "nym",
		stem .. "ną",
		stem .. "nym",
		stem .. "nymi"
	}
end

inflectors = function (pargs, stem, substem, extra)
	return {
		stem .. "on",
		stem .. "ona",
		stem .. "one",
		stem .. "eni",
		stem .. "one",
		stem .. "onego",
		stem .. "onej",
		stem .. "onych",
		stem .. "onemu",
		stem .. "onym",
		stem .. "oną",
		stem .. "onym",
		stem .. "onymi"
	}
end

-- jakikolwiek, którykolwiek
inflectors = function (pargs, stem)
	local result = export.autoinflect(stem, pargs)
	if result then
		for i, item in ipairs(result) do
			result = item .. "kolwiek"	
		end
		return result	
	end
end

function export.autoinflect(lemma, pargs)
	pargs = pargs or {}
	for pat, inflector in pairs(inflectors) do
		local st, en, stem, substem, extra = mw.ustring.find(lemma, pat)
		if st then
			return inflector(pargs, stem, substem, extra)
		end
	end
end

-- automatic comparatives

local comparators = {}

local function bardziej(pargs, stem)
	return "] " .. stem, "] " .. stem	
end

comparators)$"]           = bardziej
comparatorse?)$"]           = bardziej
comparators                = bardziej
comparatorsi?)$"] = bardziej
comparatorsl?)$"]    = bardziej

-- -ały, -ała, -ałe (singular)
comparators)$"] = function (pargs, stem, vowl, suf)
	local shift = {  = "ie",  = "a" }
	return stem .. shift .. "lsz" .. suf, "naj" .. stem .. shift .. "lsz" .. suf
end

-- -ali (virile plural)
comparators = function (pargs, stem, vowl, suf)
	local shift = {  = "ie",  = "a" }
	return stem .. shift .. "lsi", "naj" .. stem .. shift .. "lsi"
end

function export.autocompare(lemma, pargs)
	for pat, comparator in pairs(comparators) do
		local st, en, stem, substem, suf = mw.ustring.find(lemma, pat)
		if st then
			return comparator(pargs, stem, substem, suf)
		end
	end
end

-- template functions

local function make_table(items, title, curtitle, width)
	local itemlinks = {}
	
	local forms = {
		"m|nom//voc|s|;|m|ina|acc|s",
		"f|nom//voc|s",
		"n|nom//voc//acc|s",
		"vr|nom//voc|p",
		"nv|nom//voc//acc|p",
		"m//n|gen|s|;|m|pers//an|acc|s",
		"f|gen//dat//loc|s",
		"gen//loc|p|;|vr|acc|p",
		"m//n|dat|s",
		"dat|p",
		"f|acc//ins|s",
		"m//n|ins//loc|s",
		"ins|p",
		"dat|arch",
	}
	local maxl = 0
	for i, item in ipairs(items) do
		table.insert(itemlinks, item and m_links.full_link({lang = lang, term = item, accel = {form = forms}}))
		if not width then -- speed
			local l = mw.ustring.len(m_links.remove_links(item))
			if maxl < l then
				maxl = l
			end
		end
	end

	if not width then
		width = math.floor(maxl * 0.78) -- number obtained by anecdotal evidence
		width = (width < 10) and 10 or width
		width = 11 + (width * 5)
	end
 
	return ([=[<div class="NavFrame" style="display: block; width: %uem;">
<div class="NavHead" style="background:#eff7ff">%s</div>
<div class="NavContent">
{| class="inflection-table" border="1" style="background:#F9F9F9; text-align:center; width: %uem; margin: 0; border-collapse: collapse; border-color: #a2a9b1;"
 ! rowspan="2" style="width: 11em;" title="przypadek"style="background:#d9ebff;" | case
 ! colspan="4" scope="colgroup" title="liczba pojedyncza" style="background:#d9ebff;" | singular
 ! colspan="3" scope="colgroup" title="liczba mnoga"style="background:#d9ebff;" | plural
 |-
 ! style="background:#d9ebff; min-width: 8em;" scope="col" title="rodzaj męskoosobowy/męskozwierzęcy" | masculine personal/animate
 ! style="background:#d9ebff; min-width: 8em;" scope="col" title="rodzaj męskorzeczowy" | masculine inanimate
 ! style="background:#d9ebff; min-width: 8em;" scope="col" title="rodzaj nijaki" | neuter
 ! style="background:#d9ebff; min-width: 8em;" scope="col" title="rodzaj żeński" | feminine
 ! style="background:#d9ebff; min-width: 8em;" scope="col" title="rodzaj męskoosobowy" | virile
 ! style="background:#d9ebff; min-width: 8em;" scope="col" title="rodzaj niemęskoosobowy" | nonvirile
 |-
 ! style="background:#eff7ff;" title="mianownik (jaki? jaka? jakie?), wołacz (o!)" scope="row" | nominative, vocative
 | colspan="2" | %s
 | %s
 | %s
 | %s
 | %s
 |-
 ! style="background:#eff7ff;" title="dopełniacz (jakiego? jakiej?)" scope="row" | genitive
 | colspan="3" | %s
 | rowspan="2" | %s
 | colspan="2" | %s
 |-
 ! style="background:#eff7ff;" title="celownik (jakiemu? jakiej?)" scope="row" | dative
 | colspan="3" | %s
 | colspan="2" | %s
 |-
 ! style="background:#eff7ff;" title="biernik (jakiego? jaki? jaką? jakie?)" scope="row" | accusative
 | %s
 | %s
 | %s
 | rowspan="2" | %s
 | %s
 | %s
 |-
 ! style="background:#eff7ff;" title="narzędnik (jakim? jaką?)" scope="row" | instrumental
 | colspan="3" rowspan="2" | %s
 | colspan="2" | %s
 |-
 ! style="background:#eff7ff;" title="miejscownik (jakim? jakiej?)" scope="row" | locative
 | %s
 | colspan="2" | %s%s
 |}
</div>
</div>]=]):format(
		width, title, width,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks, 
		itemlinks, 
		itemlinks, 
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks,
		itemlinks and ([=[

 |-
 ! style="background-color:#eff7ff;" title="stary celownik (po jakiemu?)" scope="row" | old dative
 | lang="pl" xml:lang="pl" | %s
]=]):format(itemlinks) or ""
	)
end

function export.template_decl(frame)
	local title = mw.title.getCurrentTitle()
	local pargs = frame:getParent().args

	return make_table({
		pargs or "{{{1}}}",
		pargs or "{{{2}}}",
		pargs or "{{{3}}}",
		pargs or "{{{4}}}",
		pargs or "{{{5}}}",
		pargs or "{{{6}}}",
		pargs or "{{{7}}}",
		pargs or "{{{8}}}",
		pargs or "{{{9}}}",
		pargs or "{{{10}}}",
		pargs or "{{{11}}}",
		pargs or "{{{12}}}",
		pargs or "{{{13}}}",
		pargs or ((title.fullText == frame:getParent():getTitle()) and "{{{14}}}"),
	}, pargs.title or ('Declension of <i class="Latn mention" lang="pl" xml:lang="pl">%s</i>'):format(pargs.head or ((title.namespace == 0) and title.text or (pargs or "{{{1}}}"))), title.fullText)
end

function export.template_decl_y(frame)
	local title = mw.title.getCurrentTitle()
	local pargs = frame:getParent().args
	local lemma = pargs and (pargs .. 'y') or ((title.namespace == 0) and title.text or 'darmowy')
	if pargs then
		if declinfo ~= pargs then
			cat = ']'
		end
		declinfo = pargs
	end

	if mw.isSubsting() then
		return ("{{pl-decl-adj}}"):format(
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo and (("|%s"):format(declinfo)) or ""
		)
	else
		local table_title = pargs.title or (lemma and ('Declension of <i class="Latn mention" lang="pl" xml:lang="pl">%s</i>'):format(lemma)) or "declension table"
		return make_table(declinfo, table_title, title.fullText) .. cat
	end
end

function export.template_decl_auto(frame)
	local title = mw.title.getCurrentTitle()
	local pargs = frame:getParent().args
	local lemma = frame.args or pargs; if lemma == "" then lemma = nil end
	local nom_m_sg = pargs; if nom_m_sg == "" then nom_m_sg = nil end
	local nom_vr_pl = pargs; if nom_vr_pl == "" then nom_vr_pl = nil end
	lemma = lemma or (title.namespace == 0 and title.text) or (title.nsText == "Template" and "-ni")
	
	local declinfo
	
	if title.fullText == frame:getParent():getTitle() then
		declinfo = {
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]",
			"], ]"
		}
	else
		declinfo = export.autoinflect(lemma, pargs) or error(("No declension pattern matches '%s'"):format(lemma))
		
		if not (pargs.olddat and pargs.olddat ~= "") then
			declinfo = nil
		end
		if nom_m_sg then
			-- support short adjectives
			declinfo = nom_m_sg
		end
		if nom_vr_pl then
			-- support ]
			declinfo = nom_vr_pl
		end
	end

	if mw.isSubsting() then
		return ("{{pl-decl-adj}}"):format(
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo,
			declinfo and (("|%s"):format(declinfo)) or ""
		)
	else
		lemma = nom_m_sg or lemma
		local table_title = pargs.title or (lemma and ('Declension of <i class="Latn mention" lang="pl" xml:lang="pl">%s</i>'):format(lemma)) or "declension table"
		return make_table(declinfo, table_title, title.fullText)
	end
end

return export