Module:IPA symbol/overview
This module uses TemplateStyles: |
Generates the collapsed "Data overview" box on Module:IPA symbol/doc and Module:IPA symbol/data/doc
local data = mw.loadData('Module:IPA symbol/data')
local univPatterns, keyPatterns = data.data.univPatterns, data.data.keyPatterns
data = data.rawData
local p = {}
function p.main(frame)
local ret = { frame:extensionTag{
name = 'templatestyles',
args = { src = 'Module:IPA symbol/overview/styles.css' }
} }
local count, sCount = {}, {}
-- Error detection
do
local symbols, dupes, invChars = {}, {}, {}
local function checkSubs(t, s, name)
for _, v in ipairs(t) do
local matched = mw.ustring.match(s, v.pat)
if matched then
table.insert(invChars, { name, matched, v.rep })
end
end
end
local function check(s, checkKeyPats)
sCount[s] = 0
for i, v in ipairs(data[s]) do
for _, symbol in ipairs(v.symbols) do
if symbols[symbol] then
table.insert(dupes, symbol)
else
symbols[symbol] = true
end
checkSubs(univPatterns, symbol, v.name)
if checkKeyPats then
checkSubs(keyPatterns, symbol, v.name)
end
sCount[s] = sCount[s] + 1
end
count[s] = i
end
end
check('sounds', true)
check('diacritics')
if dupes[1] or invChars[1] then
for _, v in ipairs(dupes) do
table.insert(ret, string.format(
'*Error: "<span class="IPA">%s</span>" is defined more than once.\n',
mw.text.nowiki(v)))
end
for _, v in ipairs(invChars) do
table.insert(ret, string.format(
'*Error: A symbol for "%s" uses "<span class="IPA">%s</span>", which will be replaced by "<span class="IPA">%s</span>".\n',
v[1], mw.text.nowiki(v[2]), mw.text.nowiki(v[3])))
end
else
table.insert(ret, 'No errors were found. ')
end
end
table.insert(ret, string.format(
'%s entries (%s in "sounds", %s in "diacritics"), %s symbols (%s in "sounds", %s in "diacritics").\n\n',
count.sounds + count.diacritics, count.sounds, count.diacritics,
sCount.sounds + sCount.diacritics, sCount.sounds, sCount.diacritics))
table.insert(ret,
'Parentheses denote a link automatically inherited from the name field. In italics are redirects.\n')
-- Table
table.insert(ret,
'{| class="wikitable sortable IPA-symbol-overview"\n!Name!!Symbols!!Article!!Audio!!Group\n')
local function renderRows(s)
for _, v in ipairs(data[s]) do
local parenL = v.article and '' or '('
local parenR = v.article and '' or ')'
local article = v.article or v.name
local symbols = {}
for j, w in ipairs(v.symbols) do
symbols[j] = mw.text.nowiki(w)
end
local audio = ''
if v.audio then
if frame.args.check_wikidata == 'yes' then
local rt = mw.title.new(article).redirectTarget
rt = rt and rt.text or article
local qId = mw.wikibase.getEntityIdForTitle(rt)
local wdAudio = qId and mw.wikibase.getEntity(qId).claims
wdAudio = wdAudio and wdAudio['P51']
if wdAudio then
wdAudio = wdAudio[1].mainsnak.datavalue.value
audio = wdAudio and wdAudio ~= v.audio
and ' (≠ [[wikidata:' .. qId .. '#P51|Wikidata]])'
or ''
elseif qId then
audio = ' (not on [[wikidata:' .. qId .. '|Wikidata]])'
end
end
audio = frame:expandTemplate({
title = 'Template:Audio',
args = { v.audio, help = 'no' }
}) .. audio
end
table.insert(ret, string.format(
'|-\n|%s||class="IPA"|%s||%s[[:%s]]%s||%s||%s\n',
v.name, table.concat(symbols, ' , '), parenL, article,
parenR, audio, s))
end
end
renderRows('sounds')
renderRows('diacritics')
table.insert(ret, '|}')
return table.concat(ret)
end
return p