local export = {}

local ipa = require("Module:IPA")
local lang = require("Module:languages").getByCode("ka")

local gsub = mw.ustring.gsub
local lower = mw.ustring.lower

local mapping = {
	["ა"] = "a", ["ბ"] = "b", ["გ"] = "ɡ", ["დ"] = "d",
	["ე"] = "e", ["ვ"] = "v", ["ზ"] = "z", ["თ"] = "tʰ",
	["ი"] = "i", ["კ"] = "kʼ", ["ლ"] = "l", ["მ"] = "m",
	["ნ"] = "n", ["ო"] = "o", ["პ"] = "pʼ", ["ჟ"] = "ʒ",
	["რ"] = "r", ["ს"] = "s", ["ტ"] = "tʼ", ["უ"] = "u",
	["ფ"] = "pʰ", ["ქ"] = "kʰ", ["ღ"] = "ɣ", ["ყ"] = "qʼ",
	["შ"] = "ʃ", ["ჩ"] = "t͡ʃ", ["ც"] = "t͡s", ["ძ"] = "d͡z",
	["წ"] = "t͡sʼ", ["ჭ"] = "t͡ʃʼ", ["ხ"] = "x", ["ჯ"] = "d͡ʒ",
	["ჰ"] = "h",
	["ჶ"] = "f" -- special character
}
local narrow = {
	["რ"] = "ɾ", ["ღ"] = "ʁ", ["ყ"] = "χʼ", ["ჩ"] = "t͡ʃʰ",
	["ც"] = "t͡sʰ", ["ხ"] = "χ"
}

function export.pronunciation(word, is_phonetic)
	-- make text lowercase
	word = lower(word)

	require("Module:script utilities").checkScript(word, "Geor")

	if is_phonetic then
		-- /v/ is labialised to the previous consonant
		word = gsub(word, "([ბგდვზთკლმნპჟრსტფქღყშჩცძწჭხჯჰ])ვ", "%1ʷ")

		-- /v/ is devoiced before a devoiced consonant
		word = gsub(word, "ვ([თკპსტფქშჩცწჭხჰ])", "f%1")

		-- /l/ is velarised before a back vowel
		word = gsub(word, "ლ([აოუ])", "ɫ%1")

		-- /n/ is velarised before a velar consonant
		word = gsub(word, "ნ([ქკგ])", "ŋ%1")

		-- word-initial /b, d, ɡ/ are devoiced
		local bdg_initial = { ["ბ"] = "b̥", ["დ"] = "d̥", ["გ"] = "ɡ̊" }
		word = gsub(word, "^([ბდგ])", bdg_initial)
		word = gsub(word, "(%s)([ბდგ])", function(s, c) return s .. bdg_initial[c] end)

		-- word-final /b, d, ɡ/ are devoiced and aspirated
		local bdg_final = { ["ბ"] = "ფ", ["დ"] = "თ", ["გ"] = "ქ" }
		word = gsub(word, "([ბდგ])$", bdg_final)
		word = gsub(word, "([ბდგ])(%s)", function(c, s) return bdg_final[c] .. s end)

		word = gsub(word, ".", narrow)
	end

	word = gsub(word, "%p", "")
	word = gsub(word, ".", mapping)

	return word
end

function export.show(frame)
	local args = frame:getParent().args
	local pagetitle = mw.title.getCurrentTitle().text

	local p, results = {}, {}

	if args[1] then
		for _, v in ipairs(args) do
			if v == "+" then v = pagetitle end
			table.insert(p, (v ~= "") and v or nil)
		end
	else
		if mw.title.getCurrentTitle().nsText == "Template" then
			p = {"ქართული ენა"}
		else p = { pagetitle } end
	end

	local has_f = false

	for input_index, word in ipairs(p) do
		-- check for character ჶ /f/
		if mw.ustring.find(word, "ჶ") then
			has_f = true
		end

		local phonemic = export.pronunciation(word, false)
		local phonetic = export.pronunciation(word, true)

		table.insert(results, { pron = "[" .. phonetic .. "]" })

		local qual = args["q"..input_index]
		if qual then
			results[#results].qualifiers = { qual }
		end

	end

	local ret = ipa.format_IPA_full { lang = lang, items = results }

	if has_f then
		ret = ret .. require("Module:utilities").format_categories({"Georgian terms with /f/"}, lang)
	end

	return ret
end

return export