local export = {}
local m_IPA = require("Module:IPA")

local IPA_mapping = {
	["a"] = "a", ["ã"] = "ɜ̃", ["à"] = "ɜ", ["b"] = "b", ["c"] = "k",
	["e"] = "ɛ", ["ê"] = "e", ["ẽ"] = "ẽ", ["g"] = "ŋg", ["h"] = "h",
	["i"] = "i", ["ĩ"] = "ĩ", ["j"] = "j", ["k"] = "kʰ", ["m"] = "m",
	["n"] = "n", ["o"] = "ɔ", ["ô"] = "o", ["õ"] = "õ", ["p"] = "p",
	["qu"] = "k", ["r"] = "ɺ", ["t"] = "t", ["u"] = "u", ["ũ"] = "ũ",
	["w"] = "ʋ", ["x"] = "t͡ɕ", ["y"] = "ɨ", ["ỳ"] = "ɘ", ["ỹ"] = "ɨ"
}

function export.IPA_transcribe(text)
	return "/" .. mw.ustring.gsub(text, '.', IPA_mapping) .. "/"
end

function export.translate(text)
	if type(text) == "table" then
		text = text.args[1]
	end
	local pron = export.IPA_transcribe(text)
	
	lang = require("Module:languages").getByCode("ram")
	local items = {}
	table.insert(items, {pron = pron, note = nil})
	return m_IPA.format_IPA_full { lang = lang, items = items }
end

function export.IPA(frame)
	local args = type(frame) == 'string' and { frame } or frame:getParent().args
	local result = {}
	
	if args['phon'] and args['phon'] ~= '' then
		args = { args['phon'] }
	end
	args = (not args[1]) and { mw.title.getCurrentTitle().text } or args

	for _, text in ipairs(args) do
		text = mw.ustring.lower(text)
	
		-- h before consonants
		text = gsub(text, 'h([khjmntɺʋ])', 'ʔ%1')
		
		-- r before consonants
		text = gsub(text, 'ɺ([khjmntɺʋ%s])', 'ɹ%1')
		
		-- nasalization after consonants
		text = gsub(text,"([mn][aeiouy])",{
		["a"] = "ã",
		["e"] = "ẽ",
		["i"] = "ĩ",
		["o"] = "õ",
		["u"] = "ũ",
		["y"] = "ɨ̃",
		})

		table.insert(result, '[' .. text .. ']')
	end
	
	table.insert(result, 1, "ram")
	if (type(frame) == 'string') then
		return mw.ustring.sub(result[1], 2, mw.ustring.len(result[1]) - 1)
	else
		return frame:expandTemplate{ title = "IPA", args = result}
	end

end

return export