local export = {}

local m_IPA = require("Module:IPA")
local lang = require("Module:languages").getByCode("crk")
local rsub = mw.ustring.gsub
local rlower = mw.ustring.lower
local rlen = mw.ustring.len
local rlast = require("Module:string/replace last").replace_last
local rfind = mw.ustring.find

local V = "[aioâîôê]"
local C = "[ptckwyhsmn^]"

local phon = {
	["p"]="p", ["t"]="t", ["k"]="k", ["c"]="ts",
	["w"]="w", ["y"]="j", ["h"]="h", ["s"]="s",
	["m"]="m", ["n"]="n",
	["a"]="a", ["i"]="i", ["o"]="o",
	["â"]="aː", ["î"]="iː", ["ô"]="oː", ["ê"]="eː"
}

local function phonetic(text)
	text = rlower(text)
	-- stress
	local n 
	n = rsub(text, C, "")
	n = rlen(n)
	local i = 1
	while i <= n do
		if i == 3 then 
			text = rlast(text, "(" .. C .. ")(" .. V .. ")", "%1ˈ%2", 1)
		elseif i % 2 ~= 0 then
			text = rlast(text, "(" .. C .. ")(" .. V .. ")", "%1ˌ%2", 1)
		else
			text = rlast(text, "(" .. C .. ")(" .. V .. ")", "%1.%2", 1)
		end
		if i == n and i % 2 ~= 0 then
			if i ==3 then text = rsub(text, "^(" .. V .. ")", "ˈ%1")
			else text = rsub(text, "^(" .. V .. ")", "ˌ%1") end
		end
		i = i + 1
	end
	if rfind(text, "ˈ") == nil then
		text = rsub(text, "ˌ", "ˈ")
	end
	text = rsub(text, "(" .. C .. ")([ˈˌ])", ".%2%1")
	text = rsub(text, "(" .. C .. ")%.(" .. V .. ")", ".%1%2")
	text = rsub(text, "^%.", "")
	-- stops
	text = rsub(text, "([aio])(%.?[ˈˌ]?)([ptk])([aio])", "%1%3%2%3%4")
	text = rsub(text, "([ptk])%1", "%1ː")
	-- general phonology
	text = rsub(text, ".", phon)
	-- vowels
	text = rsub(text, "i", "ɪ")
	text = rsub(text, "ɪ([wj])", "i%1")
	text = rsub(text, "ɪː", "iː")
	text = rsub(text, "o", "ʊ")
	text = rsub(text, "ʊː", "oː")
	text = rsub(text, "a", "ʌ")
	text = rsub(text, "ʌː", "ɑː")
	-- fricatives
	text = rsub(text, "h$", "")
	-- labialisation and aspiration
	text = rsub(text, "^([ptkm]s?)(%.?[ˈˌ]?)w", "%2%1ʷ")
	text = rsub(text, "([ptkhsmnj]s?)(%.?[ˈˌ]?)w", "%2%1ʷ")
	text = rsub(text, "h([ptk]s?)$", "ʰ%1")
	text = rsub(text, "t%.s", ".ts")
	text = rsub(text, "ts", "t͡s")
	-- stylistic thingies
	text = rsub(text, "%.([ˈˌ])", "%1")
	
	return text
end

function export.IPA(frame)
	local words = {}
	
	for _, word in ipairs(frame:getParent().args) do
		table.insert(words, word)
	end
	
	if #words == 0 then
		words = {mw.title.getCurrentTitle().text}
	end
	
	local IPA_results = {}
	
	for _, word in ipairs(words) do
		table.insert(IPA_results, { pron = "[" .. phonetic(word) .. "]" })
	end
	
	return m_IPA.format_IPA_full { lang = lang, items = IPA_results }
end

return export