Module:sv-nouns

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

This module needs documentation.
Please document this module by describing its purpose and usage on the documentation page.

local m_utilities = require("Module:utilities")
local m_links = require("Module:links")

local export = {}

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

-- Functions that do the actual inflecting by creating the forms of a basic term.
local inflections = {}

-- The main entry point.
-- This is the only function that can be invoked from a template.
function export.show(frame)
	local infl_type = frame.args or error("Inflection type has not been specified. Please pass parameter 1 to the module invocation")
	local args = frame:getParent().args
	
	if args then
		require("Module:debug").track("sv-nouns/base")
	end
	
	if args then
		require("Module:debug").track("sv-nouns/betydelser")
	end
	
	if args then
		require("Module:debug").track("sv-nouns/definitions")
	end
	
	if args then
		require("Module:debug").track("sv-nouns/gender")
	end
	
	if args then
		require("Module:debug").track("sv-nouns/genitive")
	end
	
	if not inflections then
		error("Unknown inflection type '" .. infl_type .. "'")
	end
	
	local data = {forms = {}, title = nil, categories = {}}
	
	-- Generate the forms
	inflections(args, data)
	
	-- Postprocess
	postprocess(args, data)
	
	return make_table(data) .. m_utilities.format_categories(data.categories, lang)
end

--[=[
	Inflection functions
]=]--

inflections = function(args, data)
	local par1 = args; if par1 == "" then par1 = nil end
	local par2 = args; if par2 == "" then par2 = nil end
	local fv = args or ""
	
	par1 = par1 or mw.title.getCurrentTitle().text
	par2 = (par2 or par1) .. fv
	
	local s = "s"
	
	if par1:find(":?$") then
		s = ""
	end
	
	data.forms = {par1}
	data.forms = {par1 .. s}
	data.forms = {par2 .. "en"}
	data.forms = {par2 .. "ens"}
	
	data.forms = {par2 .. "ar"}
	data.forms = {par2 .. "ars"}
	data.forms = {par2 .. "arna"}
	data.forms = {par2 .. "arnas"}
end

inflections = function(args, data)
	local par1 = args; if par1 == "" then par1 = nil end
	local par2 = args; if par2 == "" then par2 = nil end
	local fv = args or ""
	local ien = (args or "") ~= ""
	
	local sg_nom_def = args; if sg_nom_def == "" then sg_nom_def = nil end
	local sg_gen_def = args; if sg_gen_def == "" then sg_gen_def = nil end
	
	if args or args then
		require("Module:debug").track("sv-nouns/manual")
	end
	
	par1 = par1 or mw.title.getCurrentTitle().text
	par2 = (par2 or par1) .. fv
	
	local s = "s"
	
	if par1:find(":?$") then
		s = ""
	end
	
	data.forms = {par1}
	data.forms = {par1 .. s}
	data.forms = {sg_nom_def or par2 .. "en"}
	data.forms = {sg_gen_def or par2 .. "ens"}
	
	data.forms = {par2 .. "er"}
	data.forms = {par2 .. "ers"}
	data.forms = {par2 .. "erna"}
	data.forms = {par2 .. "ernas"}
	
	if ien then
		table.insert(data.forms, 1, sg_nom_def or par2 .. "n")
		table.insert(data.forms, 1, sg_gen_def or par2 .. "ns")
	end
end

inflections = function(args, data)
	local par1 = args; if par1 == "" then par1 = nil end
	
	if not par1 and mw.title.getCurrentTitle().nsText == "Template" then
		par1 = "{{{1}}}"
	elseif not par1 and mw.ustring.find(mw.title.getCurrentTitle().text, "a$") then
		par1 = mw.title.getCurrentTitle().text:sub(1, -2)
	end
	
	data.forms = {par1 .. "a"}
	data.forms = {par1 .. "as"}
	data.forms = {par1 .. "an"}
	data.forms = {par1 .. "ans"}
	
	data.forms = {par1 .. "or"}
	data.forms = {par1 .. "ors"}
	data.forms = {par1 .. "orna"}
	data.forms = {par1 .. "ornas"}
end

inflections = function(args, data)
	local par1 = args; if par1 == "" then par1 = nil end
	local par2 = args; if par2 == "" then par2 = nil end
	local par3 = args; if par3 == "" then par3 = nil end
	
	par1 = par1 or mw.title.getCurrentTitle().text
	par2 = par2 or par1
	par3 = par3 or par2 or par1
	
	local s = "s"
	
	if par1:find(":?$") then
		s = ""
	end
	
	data.forms = {par1}
	data.forms = {par1 .. s}
	data.forms = {par2 .. "n"}
	data.forms = {par2 .. "ns"}
	
	data.forms = {par3 .. "r"}
	data.forms = {par3 .. "rs"}
	data.forms = {par3 .. "rna"}
	data.forms = {par3 .. "rnas"}
end

inflections = function(args, data)
	local par1 = args; if par1 == "" then par1 = nil end
	local par2 = args; if par2 == "" then par2 = nil end
	local par3 = args; if par3 == "" then par3 = nil end
	
	par1 = par1 or mw.title.getCurrentTitle().text
	par2 = par2 or par1
	par3 = par3 or par2 or par1
	
	if not par1 and mw.title.getCurrentTitle().nsText == "Template" then
		par1 = "{{{1}}}"
	end
	
	local s = "s"
	
	if par1:find(":?$") then
		s = ""
	end
	
	data.forms = {par1}
	data.forms = {par1 .. s}
	data.forms = {par2 .. "n"}
	data.forms = {par2 .. "ns"}
	
	data.forms = {par1}
	data.forms = {par1 .. s}
	data.forms = {par3 .. "na"}
	data.forms = {par3 .. "nas"}
end

inflections = function(args, data)
	if not mw.ustring.find(mw.title.getCurrentTitle().text, "are$") then
		error("The noun must end in -are.")
	end
	
	data.forms = {mw.title.getCurrentTitle().text}
	data.forms = {mw.title.getCurrentTitle().text .. "s"}
	data.forms = {mw.title.getCurrentTitle().text .. "n"}
	data.forms = {mw.title.getCurrentTitle().text .. "ns"}
	
	data.forms = {mw.title.getCurrentTitle().text}
	data.forms = {mw.title.getCurrentTitle().text .. "s"}
	data.forms = {mw.ustring.sub(mw.title.getCurrentTitle().text, 1, -2) .. "na"}
	data.forms = {mw.ustring.sub(mw.title.getCurrentTitle().text, 1, -2) .. "nas"}
end

inflections = function(args, data)
	if not mw.ustring.find(mw.title.getCurrentTitle().text, "nde$") then
		error("The noun must end in -nde.")
	end
	
	data.forms = {mw.title.getCurrentTitle().text}
	data.forms = {mw.title.getCurrentTitle().text .. "s"}
	data.forms = {mw.title.getCurrentTitle().text .. "n"}
	data.forms = {mw.title.getCurrentTitle().text .. "ns"}
	
	data.forms = {mw.title.getCurrentTitle().text}
	data.forms = {mw.title.getCurrentTitle().text .. "s"}
	data.forms = {mw.title.getCurrentTitle().text .. "na"}
	data.forms = {mw.title.getCurrentTitle().text .. "nas"}
end

inflections = function(args, data)
	local par1 = args; if par1 == "" then par1 = nil end
	local par2 = args; if par2 == "" then par2 = nil end
	local par3 = args; if par3 == "" then par3 = nil end
	
	par1 = par1 or mw.title.getCurrentTitle().text
	par2 = par2 or par1
	par3 = par3 or par2 or par1
	
	local s = "s"
	
	if par1:find(":?$") then
		s = ""
	end
	
	data.forms = {par1}
	data.forms = {par1 .. s}
	data.forms = {par2 .. "t"}
	data.forms = {par2 .. "ts"}
	
	data.forms = {par3 .. "n"}
	data.forms = {par3 .. "ns"}
	data.forms = {par3 .. "na"}
	data.forms = {par3 .. "nas"}
end

inflections = function(args, data)
	local par1 = args; if par1 == "" then par1 = nil end
	local par2 = args; if par2 == "" then par2 = nil end
	
	par1 = par1 or mw.title.getCurrentTitle().text
	par2 = par2 or par1
	
	local s = "s"
	
	if par1:find(":?$") then
		s = ""
	end
	
	data.forms = {par1}
	data.forms = {par1 .. s}
	data.forms = {par2 .. "t"}
	data.forms = {par2 .. "ts"}
	
	data.forms = {par2 .. "r"}
	data.forms = {par2 .. "rs"}
	data.forms = {par2 .. "rna"}
	data.forms = {par2 .. "rnas"}
end

inflections = function(args, data)
	local par1 = args; if par1 == "" then par1 = nil end
	local par2 = args or args; if par2 == "" then par2 = nil end
	local par3 = args; if par3 == "" then par3 = nil end
	
	par1 = par1 or mw.title.getCurrentTitle().text
	par2 = par2 or par1
	par3 = par3 or par2 or par1
	
	if not par1 and mw.title.getCurrentTitle().nsText == "Template" then
		par1 = "{{{1}}}"
	end
	
	local s = "s"
	
	if par1:find(":?$") then
		s = ""
	end
	
	data.forms = {par1}
	data.forms = {par1 .. s}
	data.forms = {par2 .. "et"}
	data.forms = {par2 .. "ets"}
	
	data.forms = {par1}
	data.forms = {par1 .. s}
	data.forms = {par3 .. "en"}
	data.forms = {par3 .. "ens"}
end

-- Helper functions

function postprocess(args, data)
	local n = args; if n == "" then n = nil end
	
	if n == "pl" then
		table.insert(data.categories, lang:getCanonicalName() .. " pluralia tantum")
	end
	
	if n == "sg" then
		table.insert(data.categories, lang:getCanonicalName() .. " uncountable nouns")
	end
	
	for key, form in pairs(data.forms) do
		-- Do not show singular or plural forms for nominals that don't have them
		if (n == "pl" and key:find("_sg$")) or (n == "sg" and key:find("_pl$")) then
			form = nil
		end
		-- Escape any intemediate colons (for the link template) and remove any final colons.
		if form then
			for k, v in ipairs(form) do
				form = v:gsub("()(:)", function(pos, colon)
					if pos == #v then
						return ""
					else
						return "\\:"
					end
				end)
			end
		end
		data.forms = form
	end
	
	-- Check if the lemma form matches the page name
	if (lang:makeEntryName(data.forms)) ~= mw.title.getCurrentTitle().text then
		table.insert(data.categories, lang:getCanonicalName() .. " entries with inflection not matching pagename")
	end
end


-- Make the table
function make_table(data)
	local function show_form(form)
		if not form then
			return "—"
		elseif type(form) ~= "table" then
			error("a non-table value was given in the list of inflected forms.")
		elseif #form == 0 then
			return "—"
		end
		
		local ret = {}
		
		for key, subform in ipairs(form) do
			table.insert(ret, m_links.full_link({lang = lang, term = subform}))
		end
		
		return table.concat(ret, "<br/>")
	end
	
	return mw.getCurrentFrame():expandTemplate{
		title = 'sv-decl-noun',
		args = {
			show_form(data.forms),
			show_form(data.forms),
			show_form(data.forms),
			show_form(data.forms),
			show_form(data.forms),
			show_form(data.forms),
			show_form(data.forms),
			show_form(data.forms),
			definitions = data.title and "(" .. data.title .. ")" or "",
		}
	}
end

return export