Mô đun:ka-IPA
local export = {}
local gsub = mw.ustring.gsub
local lang = require("Module:languages").getByCode("ka")
local ipa = require("Module:IPA")
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",
-- special character:
["ჶ"] = "f",
}
local narrow = {
["რ"] = "ɾ", ["ღ"] = "ʁ", ["ყ"] = "χʼ", ["ჩ"] = "t͡ʃʰ",
["ც"] = "t͡sʰ", ["ხ"] = "χ"
}
function export.pronunciation(word, is_phonetic)
-- make text lowercase
word = mw.ustring.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, ɡ/ is devoiced
word = gsub(word, "^([ბდ])", "%1" .. mw.ustring.char(0x0325))
word = gsub(word, "^გ", "გ" .. mw.ustring.char(0x030a))
word = gsub(word, " ([ბდ])", " %1" .. mw.ustring.char(0x0325))
word = gsub(word, " გ", " გ" .. mw.ustring.char(0x030a))
-- word-final /b, d, ɡ/ is devoiced and aspirated
word = gsub(word, "ბ$", "ფ")
word = gsub(word, "დ$", "თ")
word = gsub(word, "გ$", "ქ")
word = gsub(word, "ბ ", "ფ ")
word = gsub(word, "დ ", "თ ")
word = gsub(word, "გ ", "ქ ")
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 = "/" .. phonemic .. "/" })
local qual = args["q"..input_index]
if qual then
results[#results].qualifiers = { qual }
end
if phonemic ~= phonetic then table.insert(results, { pron = "[" .. phonetic .. "]" }) 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