Module:User:SarahFatimaK/apc-conj
Appearance
- This module sandbox lacks a documentation subpage. Please create it.
- Useful links: root page • root page’s subpages • links • transclusions • testcases • sandbox
local export = {}
local PAGENAME = mw.title.getCurrentTitle().text
local cons = 'ʾʿʔʕbdḍḏfgḡhḥjkḵlḷmnpqrsṣštṭṯvwyzẓ'
function export.show(frame)
-- get arguments
local args = frame:getParent().args
local form = frame.args[1] or error("Verb form (arg 1) has not been specified.")
local pasttr = frame.args[2] or error("Past transliteration (arg 2) has not been specified.")
local subjtr = frame.args[3] or error("Subjunctive transliteration (arg 3) have not been specified.")
local past = frame.args[4] or PAGENAME
-- prepare arguments
past = mw.ustring.gsub(past, '[ًٌٍَُِّْٰ]', '') -- remove tashkil
pasttr = mw.ustring.gsub(mw.ustring.gsub(pasttr, 'e', 'i'), 'o', 'u') -- change vowels e, o into i, u
subjtr = mw.ustring.gsub(mw.ustring.gsub(subjtr, 'e', 'i'), 'o', 'u') -- change vowels e, o into i, u
subjtr = mw.ustring.gsub(subjtr, '^b?y(.+)$', '%1') -- get subjunctive/present root
-- find out type of root
local tdef = mw.ustring.match(past, '.+([ايى])$') -- defective root (fa3a/fi3i)
local thol = mw.ustring.match(past, '.+(ا).$') -- hollow root (faal)
local tdbl = mw.ustring.match(pasttr, '.+['..cons..']['..cons..']$') -- doubled root (fall)
local treg = false
if form == '2' or form == '5' then
past = mw.ustring.sub(past, 1, -2) .. 'ّ' .. mw.ustring.sub(past, -1, -1) -- add shadda after middle root letter
end
-- define variants of the past root
local past2 = past
local past2tr = pasttr
local past3ftr = mw.ustring.gsub(pasttr, '^(.*['..cons..'][iu]['..cons..'])[iu](['..cons..'])$', '%1%2') -- remove medial vowel i/u
local past3ptr = past3ftr
-- define variants of the subj/pres root
local sjvow = mw.ustring.match(subjtr, '^([aiuāīū])') -- prefix vowel
local subj = mw.ustring.gsub(past, '^[ا]', '')
if form == '4' then
subj = mw.ustring.gsub(subj, '^[أ]', '')
end
if sjvow == 'ā' then -- ʔakal and ʔaḵad
subj = mw.ustring.gsub(subj, '^أ', 'ا')
elseif sjvow and sjvow ~= 'a' then -- change seat of hamza after the vowels i, u
subj = mw.ustring.gsub(subj, '^[أإ]', sjvow == 'i' and 'ئ' or 'ؤ')
end
local subj2 = subj
local subj2tr = subjtr
local bpref = sjvow and 'b' or 'bi' -- b-prefix
-- special treatment by root type
if tdef then -- defective
past2 = mw.ustring.sub(past, 1, -2) .. 'ي'
past2tr = mw.ustring.sub(pasttr, 1, -2) .. (tdef == 'ي' and 'ī' or 'ē')
past3ftr = mw.ustring.sub(pasttr, 1, -2)
past3ptr = mw.ustring.sub(pasttr, 1, -2) .. (tdef == 'ي' and 'y' or '')
subj2 = mw.ustring.gsub(subj, '[ايى]$', '')
subj2tr = mw.ustring.gsub(subjtr, '[ai]$', '')
if tdef == 'ي' and mw.ustring.sub(subjtr, -1, -1) == 'a' then
subj = subj2..'ى'
elseif tdef == 'ى' and mw.ustring.sub(subjtr, -1, -1) == 'i' then
subj = subj2..'ي'
end
elseif thol then -- hollow
local sjhvow = mw.ustring.match(subjtr, '([āīū])')
past2 = mw.ustring.gsub(past, '^(.+)ا(.)$', '%1%2')
past2tr = mw.ustring.gsub(pasttr, '^(.+)ā(.)$', '%1i%2')
subj = mw.ustring.sub(past, -3, -3) .. (sjhvow == 'ā' and 'ا' or (sjhvow == 'ū' and 'و' or 'ي')) .. mw.ustring.sub(past, -1, -1)
elseif tdbl then -- doubled
past = past .. 'ّ'
past2 = past .. 'ي'
past2tr = pasttr .. 'ē'
else -- sound/regular
treg = true
subj2tr = mw.ustring.gsub(subj2tr, '([aiuāīū]['..cons..']?['..cons..'])[iu](['..cons..'])', '%1%2')
end
-- define imperative roots
local imp = mw.ustring.gsub(mw.ustring.gsub(subj, '^ا', ''), '[ؤئ]', 'أ')
local imp2 = mw.ustring.gsub(mw.ustring.gsub(subj2, '^ا', ''), '[ؤئ]', 'أ')
local imptr = mw.ustring.gsub(subjtr, '^[aiuā]', '')
local imp2tr = mw.ustring.gsub(subj2tr, '^[aiuā]', '')
-- special imperative in form I regular/sound and defective
if form == '1' then
if treg then
local sjrvow = mw.ustring.match(subjtr, '([aiu])['..cons..']$')
imp = mw.ustring.sub(imp, 1, -2) .. (sjrvow == 'a' and 'ا' or (sjrvow == 'u' and 'و' or 'ي')) .. mw.ustring.sub(subj, -1, -1)
imptr = mw.ustring.sub(imptr, 1, -3) .. (sjrvow == 'a' and 'ā' or (sjrvow == 'u' and 'ō' or 'ē')) .. mw.ustring.sub(subjtr, -1, -1)
imptr = mw.ustring.gsub(imptr, '^ū', 'w')
imp2tr = mw.ustring.gsub(subjtr, '^[aiu](.+a['..cons..'])$', '%1')
imp2tr = mw.ustring.gsub(imp2tr, '^u(.+)[iu](['..cons..'])$', '%1u%2')
imp2tr = mw.ustring.gsub(imp2tr, '^[aiā](.+)[iu](['..cons..'])$', '%1i%2')
imp2tr = mw.ustring.gsub(imp2tr, '^ū', 'w')
elseif tdef then
imptr = mw.ustring.sub(imptr, 1, -2) .. (tdef == 'ي' and 'ī' or 'ā')
imp2tr = imp2tr .. 'ˉ'
end
end
-- i/u disappears when stress shifts
past2tr = mw.ustring.gsub(past2tr, '(['..cons..'])u(['..cons..'])i(['..cons..']?)$', '%1%2u%3') -- stressed i becomes u in emphatic environment
past2tr = mw.ustring.gsub(past2tr, '(['..cons..'])[iu](['..cons..'][iuēī]['..cons..']?)$', '%1%2')
-- output values in arabic script
local res_ar = {}
res_ar['past3m'] = past
res_ar['past3f'] = mw.ustring.gsub(past, '[ايى]$', '')..'ت'
res_ar['past3p'] = mw.ustring.gsub(past, '[اى]$', '')..'و'
res_ar['past2m'] = past2..'ت'
res_ar['past2f'] = past2..'تي'
res_ar['past2p'] = past2..'تو'
res_ar['past1s'] = past2..'ت'
res_ar['past1p'] = past2..'نا'
res_ar['subj3m'] = 'ي'..subj
res_ar['subj3f'] = 'ت'..subj
res_ar['subj3p'] = 'ي'..subj2..'و'
res_ar['subj2m'] = 'ت'..subj
res_ar['subj2f'] = 'ت'..subj2..'ي'
res_ar['subj2p'] = 'ت'..subj2..'و'
res_ar['subj1s'] = mw.ustring.gsub(((sjvow and (form == '1' or form == '4')) and (sjvow == 'i' and 'إ' or sjvow and 'أ') or '')..subj, 'أا', 'آ')
res_ar['subj1p'] = 'ن'..subj
res_ar['pres3m'] = 'بي'..subj
res_ar['pres3f'] = 'بت'..subj
res_ar['pres3p'] = 'بي'..subj2..'و'
res_ar['pres2m'] = 'بت'..subj
res_ar['pres2f'] = 'بت'..subj2..'ي'
res_ar['pres2p'] = 'بت'..subj2..'و'
res_ar['pres1s'] = 'ب'..subj
res_ar['pres1p'] = 'من'..subj
res_ar['imp2m'] = imp
res_ar['imp2f'] = imp2..'ي'
res_ar['imp2p'] = imp2..'و'
-- output values in transliteration
local res_tr = {}
res_tr['past3m'] = pasttr
res_tr['past3f'] = past3ftr..'it'
res_tr['past3p'] = past3ptr..'u'
res_tr['past2m'] = past2tr..'t'
res_tr['past2f'] = past2tr..'ti'
res_tr['past2p'] = past2tr..'tu'
res_tr['past1s'] = past2tr..'t'
res_tr['past1p'] = past2tr..'na'
res_tr['subj3m'] = 'y'..subjtr
res_tr['subj3f'] = 't'..subjtr
res_tr['subj3p'] = 'y'..subj2tr..'u'
res_tr['subj2m'] = 't'..subjtr
res_tr['subj2f'] = 't'..subj2tr..'i'
res_tr['subj2p'] = 't'..subj2tr..'u'
res_tr['subj1s'] = mw.ustring.gsub(((sjvow and (form == '1' or form == '4')) and 'ʔ' or '')..subjtr, '^i', '')
res_tr['subj1p'] = 'n'..subjtr
res_tr['pres3m'] = bpref..(sjvow and 'y' or '')..subjtr
res_tr['pres3f'] = bpref..'t'..subjtr
res_tr['pres3p'] = bpref..(sjvow and 'y' or '')..subj2tr..'u'
res_tr['pres2m'] = bpref..'t'..subjtr
res_tr['pres2f'] = bpref..'t'..subj2tr..'i'
res_tr['pres2p'] = bpref..'t'..subj2tr..'u'
res_tr['pres1s'] = 'b'..subjtr
res_tr['pres1p'] = mw.ustring.gsub(bpref, 'b', 'm')..'n'..subjtr
res_tr['imp2m'] = imptr
res_tr['imp2f'] = mw.ustring.gsub(imp2tr..'i', 'ˉi', 'ī')
res_tr['imp2p'] = mw.ustring.gsub(imp2tr..'u', 'ˉu', 'ū')
return
'<table class="wikitable vsSwitcher vsToggleCategory-conjugation autocollapsed" style="text-align:center; border: 0.5px solid #CCC;">' ..
'<tr><th class="vsToggleElement" style="text-align:left; width:40em" colspan="9">    Conjugation of <i class="Arab mention" lang="ajp">'..past..'</i></th></tr>' ..
'<tr class="vsHide"><th colspan="2"></th><th colspan="3">singular</th><td rowspan="10"></td><th colspan="3">plural</th></tr>' ..
'<tr class="vsHide"><th colspan="2"></th><th>1<sup>st</sup> person</th><th>2<sup>nd</sup> person</th><th>3<sup>rd</sup> person</th><th>1<sup>st</sup> person</th><th>2<sup>nd</sup> person</th><th>3<sup>rd</sup> person</th></tr>' ..
'<tr class="vsHide">' ..
' <th rowspan="2">past</th><th><span class="gender"><abbr title="masculine gender">m</abbr></span></th>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['past1s']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['past1s']..'</span>)</td>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['past2m']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['past2m']..'</span>)</td>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['past3m']..'</span> (<span lang="ajp-Latn" class="tr Latn">'..res_tr['past3m']..'</span>)</td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['past1p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['past1p']..'</span>)</td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['past2p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['past2p']..'</span>)</td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['past3p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['past3p']..'</span>)</td></tr>' ..
'<tr class="vsHide">' ..
' <th><span class="gender"><abbr title="feminine gender">f</abbr></span></th>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['past2f']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['past2f']..'</span>)</td>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['past3f']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['past3f']..'</span>)</td></tr>' ..
'<tr class="vsHide">' ..
' <th rowspan="2">present</th><th><span class="gender"><abbr title="masculine gender">m</abbr></span></th>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['pres1s']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['pres1s']..'</span>)</td>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['pres2m']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['pres2m']..'</span>)</td>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['pres3m']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['pres3m']..'</span>)</td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['pres1p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['pres1p']..'</span>)</td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['pres2p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['pres2p']..'</span>)</td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['pres3p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['pres3p']..'</span>)</td></tr>' ..
'<tr class="vsHide">' ..
' <th><span class="gender"><abbr title="feminine gender">f</abbr></span></th>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['pres2f']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['pres2f']..'</span>)</td>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['pres3f']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['pres3f']..'</span>)</td></tr>' ..
'<tr class="vsHide">' ..
' <th rowspan="2">subjunctive</th><th><span class="gender"><abbr title="masculine gender">m</abbr></span></th>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['subj1s']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['subj1s']..'</span>)</td>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['subj2m']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['subj2m']..'</span>)</td>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['subj3m']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['subj3m']..'</span>)</td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['subj1p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['subj1p']..'</span>)</td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['subj2p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['subj2p']..'</span>)</td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['subj3p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['subj3p']..'</span>)</td></tr>' ..
'<tr class="vsHide"><th><span class="gender"><abbr title="feminine gender">f</abbr></span></th>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['subj2f']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['subj2f']..'</span>)</td>' ..
' <td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['subj3f']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['subj3f']..'</span>)</td></tr>' ..
'<tr class="vsHide"><th rowspan="2">imperative</th><th><span class="gender"><abbr title="masculine gender">m</abbr></span></th>' ..
' <td rowspan="2"></td><td><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['imp2m']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['imp2m']..'</span>)</td>' ..
' <td rowspan="2"></td><td rowspan="2"></td>' ..
' <td rowspan="2"><span class="Arab form-of lang-apc" lang="ajp">'..res_ar['imp2p']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['imp2p']..'</span>)</td>' ..
' <td rowspan="2"></td></tr>' ..
'<tr class="vsHide">' ..
' <th><span class="gender"><abbr title="feminine gender">f</abbr></span></th>' ..
' <td><span class="Arab form-of lang-apc 2|f|s|imperative-form-of" lang="ajp">'..res_ar['imp2f']..'</span>‎ (<span lang="ajp-Latn" class="tr Latn">'..res_tr['imp2f']..'</span>)</td></tr>' ..
'</table>'
end
return export