Module:rhymes

Underlies {{rhymes}}.


local export = {}
local getArgs = require("Module:Arguments").getArgs

local m_languages = require("Module:languages")
local m_IPA = require("Module:IPA")

local V = "aeiouyɑæɐəɵɛɜɪɨɔœɒøʊʉʌɯʏɤ"

local from_secondary = {
	["lfv"] = true,
	["rad"] = true,
} -- list of language codes which get rhyme from secondary stress as well as primary

local no_primary_if_secondary = {
	["lfv"] = true
} -- list of language codes which ignore primary stress if secondary stress is present

function de_onset(ipa)
	ipa = mw.ustring.gsub(ipa, "[ˈˌ]", "")
	-- mw.log(ipa)
	while true do
		if mw.ustring.find(ipa, "^[" .. V .. "]̯") then
			ipa = mw.ustring.sub(ipa, 3)
		elseif mw.ustring.find(ipa, "^[" .. V .. "]") or mw.ustring.find(ipa, "^%S̩") then
			break
		elseif #ipa < 2 then error("No syllabic element detected")
		else
			ipa = mw.ustring.sub(ipa, 2)
		end
		-- mw.log(ipa)
	end
	return ipa
end

function export.generate(lang, rhymes, nopre, nocat)
    local language = m_languages.get_by_code(lang)
    local rhymes_show = ""
	
	if nopre ~= true then
		rhymes_show = "Rhyme"
		if #rhymes > 1 then rhymes_show = rhymes_show .. "s" end 
		rhymes_show = rhymes_show .. ": "
	end

    for num, rhyme in ipairs(rhymes) do
    	local rhyme_cat = "Rhymes:" .. language.name .. "/" .. rhyme
        local rhyme_count = mw.site.stats.pagesInCategory(rhyme_cat, "pages")
        if num > 1 then
            rhymes_show = rhymes_show .. ", "
        end
        if rhyme_count < 2 then
        	rhymes_show = rhymes_show ..
        		"<span class=\"IPA\">-" .. rhyme .. "</span>"
    	else
            rhymes_show = rhymes_show ..
                "<span class=\"IPA\">[[:Category:" .. rhyme_cat .. "|-" .. rhyme .. "]]</span>" ..
                "<sup> (" .. rhyme_count .. ")</sup>"
        end
        if nocat ~= true then
        	rhymes_show = rhymes_show .. "[[Category:" .. rhyme_cat .. "]]"
    	end
    end
    
    return rhymes_show
end

function export.show(frame)
	local args = getArgs(frame)
	local language = m_languages.get_by_code(args[1])
	local rhymes = {}
	if args[2] == nil then error("At least one rhyme is required") end
	
	for i, rhyme in ipairs(args) do
		if i > 1 then
			rhyme = m_IPA.get_SAMPAd(rhyme)
			rhyme = mw.ustring.gsub(rhyme, "[%/%[%]]", "")
			local rhyme2
			if from_secondary[language.code] and mw.ustring.find(rhyme, "ˌ") then
				rhyme2 = mw.ustring.match(rhyme, "ˌ([^ˈˌ]*)$")
			end
			rhyme = mw.ustring.match(rhyme, "ˈ(.*)$") or rhyme
			if rhyme2 == nil or no_primary_if_secondary[language.code] ~= true then
				table.insert(rhymes, de_onset(rhyme))
			end
			if rhyme2 then
				table.insert(rhymes, de_onset(rhyme2))
			end
		end
	end
	
	-- mw.logObject(rhymes)

	return export.generate(language.code, rhymes, args["nopre"] ~= nil, args["nocat"] ~= nil)
end

return export
--[[
=p.show(mw.getCurrentFrame():newChild{title="parent", args={"lfv", "/ˈvydɛ/"}}:newChild{title="child"})
]]--