Module:Languages
CodeDiscussionEditHistoryLinksLink count Subpages:DocumentationTestsResultsSandboxLive code All modules
Supported languages (mappings in "MediaWiki:Lang/code" for {{int:lang}}
, and their current native names)
- (hak-hant) 客家語(繁體)
- (als) Alemannisch
- (id) Bahasa Indonesia
- (bdr) Bajau Sama
- (ase) American sign language
- (sma) åarjelsaemien
- (smn) anarâškielâ
- (gn) Avañe'ẽ
- (frp) arpetan
- (nr) isiNdebele seSewula
- (knc) Yerwa Kanuri
- (nan-latn-pehoeji) Bân-lâm-gú (Pe̍h-ōe-jī)
- (isv-cyrl) меджусловјанскы
- (hak-latn) Hak-kâ-ngî (Pha̍k-fa-sṳ)
- (bjn) Banjar
- (ast) asturianu
- (zh-min-nan) 閩南語 / Bân-lâm-gú
- (lua) ciluba
- (ang) Ænglisc
- (ms) Bahasa Melayu
- (en-us) American English
- (abs) bahasa ambon
- (kge) Kumoring
- (bas) Basaa
- (hak-hans) 客家语(简体)
- (az) azərbaycanca
- (gor) Bahasa Hulontalo
- (af) Afrikaans
- (ace) Acèh
- (bkh) Bakoko
- (agq) Aghem
- (atj) Atikamekw
- (bkc) Baka
- (ay) Aymar aru
- (bfd) Bafut
- (mui) Baso Palembang
- (isv-latn) medžuslovjansky
- (map-bms) Basa Banyumasan
- (tig) ትግሬ
- (ccp) 𑄌𑄋𑄴𑄟𑄳𑄦
- (bax) Bamum
- (gsw) Alemannisch
- (acf) Kwéyòl Sent Lisi
- (nan-latn-tailo) Bân-lâm-gú (Tâi-lô)
- (ak) Akan
- (bgc) हरियाणवी
- (iba) Jaku Iban
- (⧼lang/hke⧽) kihunde
- (rup) armãneashti
- (bm) bamanankan
- (roa-rup) armãneashti
- (aae) Arbërisht
- (ban) Basa Bali
- (ksf) Bafia
- (bug) Basa Ugi
- (nup) Nupe
- (an) aragonés
- (btm) Batak Mandailing
- (ibb) ibibio
- (en-gb) British English
- (jbo) la .lojban.
- (ny) Chi-Chewa
- (se-no) davvisámegiella (Norgga bealde)
- (br) brezhoneg
- (pcm) Naijá
- (mi) Māori
- (isu) Isu
- (min) Minangkabau
- (etu) Ejagham
- (bbc) Batak Toba
- (aln) Gegë
- (ilo) Ilokano
- (eu) euskara
- (lv) latviešu
- (rmf) kaalengo tšimb
- (kai) Karai-karai
- (bew) Betawi
- (pam) Kapampangan
- (fat) mfantse
- (nys) Nyunga
- (lld) Ladin
- (guw) gungbe
- (hil) Ilonggo
- (gom-latn) Gõychi Konknni
- (gv) Gaelg
- (lad) Ladino
- (bbc-latn) Batak Toba
- (cnh) Hakha Chin
- (gcf) kréyòl Gwadloup
- (bkm) Kom
- (nah) Nāhuatl
- (ku-latn) kurdî (latînî)
- (ik) Iñupiatun
- (eml) emiliàn e rumagnòl
- (lij) Ligure
- (kw) kernowek
- (dga) Dagaare
- (eto) Eton
- (rw) Ikinyarwanda
- (bcl) Bikol Central
- (co) corsu
- (mad) Madhurâ
- (ku) kurdî
- (se) davvisámegiella
- (se-fi) davvisámegiella (Suoma bealde)
- (bar) Boarisch
- (mnc-latn) manju gisun
- (ext) estremeñu
- (sei) Cmique Itom
- (gaa) Ga
- (hrx) Hunsrik
- (byv) Medumba
- (ewo) Ewondo
- (ha) Hausa
- (kj) Kwanyama
- (ia) interlingua
- (krj) Kinaray-a
- (kea) kabuverdianu
- (nap) Napulitano
- (niu) Niuē
- (lmo) lombard
- (pdc) Deitsch
- (mcp) Maka
- (gag) Gagauz
- (mua) Mundang
- (kri) Krio
- (fmp) Fe'fe'
- (avk) Kotava
- (sje) bidumsámegiella
- (dua) Duala
- (li) Limburgs
- (ki) Gĩkũyũ
- (frr) Nordfriisk
- (dtp) Kadazandusun
- (arn) mapudungun
- (ch) Chamoru
- (nla) Ngombala
- (nmz) nawdm
- (wls) Fakaʻuvea
- (ceb) Cebuano
- (lem) Nomaande
- (sms) nuõrttsääʹmǩiõll
- (lfn) Lingua Franca Nova
- (de-formal) Deutsch (Sie-Form)
- (tum) chiTumbuka
- (mh) Ebon
- (it) italiano
- (srq) mbia cheë
- (mt) Malti
- (fj) Na Vosa Vakaviti
- (olo) livvinkarjala
- (ht) Kreyòl ayisyen
- (pih) Norfuk / Pitkern
- (fy) Frysk
- (haw) Hawaiʻi
- (lg) Luganda
- (kg) Kongo
- (cy) Cymraeg
- (mg) Malagasy
- (sw) Kiswahili
- (ig) Igbo
- (lzz) Lazuri
- (ann) Obolo
- (nv) Diné bizaad
- (et) eesti
- (cak) Kaqchikel
- (gcr) kriyòl gwiyannen
- (dag) dagbanli
- (ff) Fulfulde
- (la) Latina
- (lns) Lamnso'
- (na) Dorerin Naoero
- (kbp) Kabɩyɛ
- (hif) Fiji Hindi
- (lus) Mizo ţawng
- (mus) Mvskoke
- (mrh) Mara
- (jut) jysk
- (zu) isiZulu
- (cho) Chahta anumpa
- (vmw) emakhuwa
- (liv) Līvõ kēļ
- (nnz) Nda'nda'
- (ee) eʋegbe
- (de) Deutsch
- (cbk-zam) Chavacano de Zamboanga
- (uz-latn) oʻzbekcha
- (nds-nl) Nedersaksies
- (nia) Li Niha
- (vmf) Mainfränkisch
- (bbj) Ghomála'
- (ie) Interlingue
- (bi) Bislama
- (uz) oʻzbekcha / ўзбекча
- (mos) moore
- (mwl) Mirandés
- (chn) chinuk wawa
- (es-419) español de América Latina
- (csb) kaszëbsczi
- (nl-informal) Nederlands (informeel)
- (xh) isiXhosa
- (yas) Nugunu
- (es) español
- (hif-latn) Fiji Hindi
- (kus) Kʋsaal
- (da) dansk
- (gd) Gàidhlig
- (bqz) Mka'a
- (nge) Ngémba
- (efi) Efịk
- (egl) emiliàn e rumagnòl
- (igl) Igala
- (yrl) Nhẽẽgatú
- (is) íslenska
- (dsb) dolnoserbski
- (ga) Gaeilge
- (ca) català
- (gl) galego
- (kl) kalaallisut
- (nl) Nederlands
- (lt) lietuvių
- (ltg) latgaļu
- (se-se) davvisámegiella (Ruoŧa bealde)
- (gpe) Ghanaian Pidgin
- (nov) Novial
- (nb) norsk bokmål
- (lb) Lëtzebuergesch
- (cs) čeština
- (bs) bosanski
- (fr) français
- (hr) hrvatski
- (kr) kanuri
- (frc) français cadien
- (kiu) Kırmancki
- (nrm) Nouormand
- (sm) Gagana Samoa
- (cps) Capiceño
- (gur) farefare
- (en) English
- (ln) lingála
- (brh) Bráhuí
- (jv) Jawa
- (nmg) Kwasio
- (hu-formal) magyar (formal)
- (cr) Nēhiyawēwin / ᓀᐦᐃᔭᐍᐏᐣ
- (ike-latn) inuktitut
- (nn) norsk nynorsk
- (nnh) Ngiemboon
- (sn) chiShona
- (rn) ikirundi
- (fit) meänkieli
- (hsb) hornjoserbsce
- (en-ca) Canadian English
- (ho) Hiri Motu
- (eo) Esperanto
- (fo) føroyskt
- (io) Ido
- (fon) fɔ̀ngbè
- (bto) Iriga Bicolano
- (ses) Koyraboro Senni
- (ker) Kera
- (nb) norsk
- (to) lea faka-Tonga
- (gya) Gbaya
- (krl) karjal
- (fkv) kvääni
- (es-formal) español (formal)
- (fur) furlan
- (hu) magyar
- (smj) julevsámegiella
- (oc) occitan
- (tok) toki pona
- (nso) Sesotho sa Leboa
- (kk-cn) قازاقشا (جۇنگو)
- (bo) བོད་ཡིག
- (roa-tara) tarandíne
- (pnt) Ποντιακά
- (rmc) romaňi čhib
- (so) Soomaaliga
- (ts) Xitsonga
- (mo) молдовеняскэ
- (tpi) Tok Pisin
- (vep) vepsän kel’
- (be-tarask) беларуская (тарашкевіца)
- (lo) ລາວ
- (ko) 한국어
- (luz) لئری دوٙمینی
- (wes) Pidgin (Cameroon)
- (ary) الدارجة
- (alt) алтай тил
- (krc) къарачай-малкъар
- (anp) अंगिका
- (lrc) لۊری شومالی
- (yi) ייִדיש
- (shy-latn) tacawit
- (arz) مصرى
- (inh) гӀалгӀай
- (crh-latn) qırımtatarca (Latin)
- (sq) shqip
- (tn) Setswana
- (mn) монгол
- (nds) Plattdüütsch
- (ar) العربية
- (kn) ಕನ್ನಡ
- (crh) qırımtatarca
- (tru) Ṫuroyo
- (sr) српски / srpski
- (nqo) ߒߞߏ
- (kk-tr) qazaqşa (Türkïya)
- (am) አማርኛ
- (mhr) олык марий
- (got) 𐌲𐌿𐍄𐌹𐍃𐌺
- (gom-deva) गोंयची कोंकणी
- (qug) Runa shimi
- (kk-latn) qazaqşa (latın)
- (rm) rumantsch
- (or) ଓଡ଼ିଆ
- (om) Oromoo
- (nod) ᨣᩤᩴᨾᩮᩬᩥᨦ
- (km) ភាសាខ្មែរ
- (arc) ܐܪܡܝܐ
- (mr) मराठी
- (mni) ꯃꯤꯇꯩ ꯂꯣꯟ
- (mnc) manju gisun
- (hsn) 湘語
- (apc) شامي
- (crh-ro) tatarşa
- (ur) اردو
- (yo) Yorùbá
- (vo) Volapük
- (ty) reo tahiti
- (pnb) پنجابی
- (new) नेपाल भाषा
- (sl) slovenščina
- (tl) Tagalog
- (zh-tw) 中文(臺灣)
- (chr) ᏣᎳᎩ
- (zh-sg) 中文(新加坡)
- (pl) polski
- (ml) മലയാളം
- (sty) себертатар
- (ss) SiSwati
- (vot) Vaďďa
- (zh-my) 中文(马来西亚)
- (zh-mo) 中文(澳門)
- (ps) پښتو
- (os) ирон
- (el) Ελληνικά
- (ku-arab) کوردی (عەرەبی)
- (ks) कॉशुर / کٲشُر
- (kjp) ဖၠုံလိက်
- (zh-hans) 中文(简体)
- (dty) डोटेली
- (war) Winaray
- (zgh) ⵜⴰⵎⴰⵣⵉⵖⵜ ⵜⴰⵏⴰⵡⴰⵢⵜ
- (shn) ၽႃႇသႃႇတႆး
- (sh-cyrl) српскохрватски (ћирилица)
- (bgn) روچ کپتین بلوچی
- (zea) Zeêuws
- (yue-hans) 粵语(简体)
- (sd) سنڌي
- (tt-latn) tatarça
- (skr-arab) سرائیکی
- (ybb) Yemba
- (yue-hant) 粵語(繁體)
- (xsy) saisiyat
- (xmf) მარგალური
- (nan-hani) 閩南語
- (tzm) ⵜⴰⵎⴰⵣⵉⵖⵜ
- (wuu-hant) 吳語(正體)
- (wuu) 吴语
- (tg-cyrl) тоҷикӣ
- (wo) Wolof
- (ru) русский
- (zh-cn) 中文(中国大陆)
- (te) తెలుగు
- (ryu) 沖縄口
- (wuu-hans) 吴语(简体)
- (ne) नेपाली
- (ota) لسان عثمانى
- (ady) адыгабзэ
- (bho) भोजपुरी
- (vi) Tiếng Việt
- (vec) vèneto
- (ve) Tshivenda
- (be) беларуская
- (ce) нохчийн
- (uz-cyrl) ўзбекча
- (uk) українська
- (ug-latn) Uyghurche
- (ug-arab) ئۇيغۇرچە
- (dz) ཇོང་ཁ
- (udm) удмурт
- (tyv) тыва дыл
- (nyo) Orunyoro
- (hz) Otsiherero
- (cpx-latn) Pó-sing-gṳ̂ (Báⁿ-uā-ci̍)
- (mnw) ဘာသာမန်
- (tw) Twi
- (tvu) Tunen
- (ttj) Orutooro
- (tt-cyrl) татарча
- (ckb) کوردی
- (trv) Seediq
- (rut) мыхаӀбишды
- (pt-br) português do Brasil
- (vut) Vute
- (loz) Silozi
- (tr) Türkçe
- (shi) Taclḥit
- (th) ไทย
- (sdc) Sassaresu
- (tcy) ತುಳು
- (my) မြန်မာဘာသာ
- (yue) 粵語
- (za) Vahcuengh
- (mai) मैथिली
- (ug) ئۇيغۇرچە / Uyghurche
- (hak) 客家語 / Hak-kâ-ngî
- (sg) Sängö
- (tg) тоҷикӣ
- (ojb) Ojibwemowin
- (de-ch) Schweizer Hochdeutsch
- (ng) Oshiwambo
- (bg) български
- (sv) svenska
- (hy) հայերեն
- (su) Sunda
- (bpy) বিষ্ণুপ্রিয়া মণিপুরী
- (ady-cyrl) адыгабзэ
- (ksh) Ripoarisch
- (tet) tetun
- (awa) अवधी
- (ko-kp) 조선말
- (sh-latn) srpskohrvatski (latinica)
- (sro) sardu campidanesu
- (szy) Sakizaya
- (tly) tolışi
- (srn) Sranantongo
- (arq) جازايرية
- (sr-el) srpski (latinica)
- (as) অসমীয়া
- (sh) srpskohrvatski / српскохрватски
- (pwn) pinayuanan
- (sdh) کوردی خوارگ
- (sr-ec) српски (ћирилица)
- (bat-smg) žemaitėška
- (vls) West-Vlams
- (kum) къумукъ
- (shi-tfng) ⵜⴰⵛⵍⵃⵉⵜ
- (hno) ہندکو
- (bh) भोजपुरी
- (tg-latn) tojikī
- (skr) سرائیکی
- (gom) गोंयची कोंकणी / Gõychi Konknni
- (hyw) Արեւմտահայերէն
- (pfl) Pälzisch
- (fi) suomi
- (simple) Simple English
- (mnc-mong) ᠮᠠᠨᠵᡠ ᡤᡳᠰᡠᠨ
- (shy) tacawit
- (hi) हिन्दी
- (si) සිංහල
- (ks-deva) कॉशुर
- (ti) ትግርኛ
- (zh) 中文
- (zh-classical) 文言
- (ka) ქართული
- (koi) перем коми
- (lzh) 文言
- (be-x-old) беларуская (тарашкевіца)
- (rue) русиньскый
- (gan-hant) 贛語(繁體)
- (pa) ਪੰਜਾਬੀ
- (myv) эрзянь
- (ami) Pangcah
- (sgs) žemaitėška
- (gan-hans) 赣语(简体)
- (syl) ꠍꠤꠟꠐꠤ
- (mk) македонски
- (kk) қазақша
- (mdf) мокшень
- (rsk) руски
- (tk) Türkmençe
- (pms) Piemontèis
- (ksw) စှီၤ
- (ban-bali) ᬩᬲᬩᬮᬶ
- (sk) slovenčina
- (ro) română
- (kcg) Tyap
- (fiu-vro) võro
- (szl) ślůnski
- (bn) বাংলা
- (kk-kz) қазақша (Қазақстан)
- (zh-hk) 中文(香港)
- (ruq-latn) Vlăheşte
- (ruq-cyrl) Влахесте
- (sah) саха тыла
- (rgn) Rumagnôl
- (kab) Taqbaylit
- (rmy) romani čhib
- (zh-hant) 中文(繁體)
- (pi) पालि
- (kbd) адыгэбзэ
- (lez) лезги
- (rif) Tarifit
- (diq) Zazaki
- (quc) Qatzijob\ʼal
- (lbe) лакку
- (zgh-latn) tamaziɣt tanawayt
- (aeb-latn) Tûnsî
- (prg) prūsiskan
- (kaa) Qaraqalpaqsha
- (cv) чӑвашла
- (dv) ދިވެހިބަސް
- (ks-arab) کٲشُر
- (sat) ᱥᱟᱱᱛᱟᱲᱤ
- (jam) Patois
- (grc) Ἀρχαία ἑλληνικὴ
- (kk-cyrl) қазақша (кирил)
- (shi-latn) Taclḥit
- (kv) коми
- (gan) 贛語
- (nan) 閩南語 / Bân-lâm-gú
- (sco) Scots
- (ike-cans) ᐃᓄᒃᑎᑐᑦ
- (din) Thuɔŋjäŋ
- (bqi) بختیاری
- (pdt) Plautdietsch
- (khw) کھوار
- (kjh) хакас
- (pap-aw) Papiamento
- (pap) Papiamentu
- (kk-arab) قازاقشا (تٴوتە)
- (cdo) 閩東語 / Mìng-dĕ̤ng-ngṳ̄
- (av) авар
- (chy) Tsetsêhestâhese
- (aeb-arab) تونسي
- (acm) عراقي
- (nyn) runyankore
- (kbd-cyrl) адыгэбзэ
- (bxr) буряад
- (iu) ᐃᓄᒃᑎᑐᑦ / inuktitut
- (tdd) ᥖᥭᥰ ᥖᥬᥲ ᥑᥨᥒᥰ
- (gu) ગુજરાતી
- (pcd) Picard
- (aeb) تونسي / Tûnsî
- (crh-cyrl) къырымтатарджа (Кирилл)
- (lki) لەکی
- (azb) تۆرکجه
- (qu) Runa Simi
- (wya) Wyandot
- (bcc) جهلسری بلوچی
- (rki) ရခိုင်
- (stq) Seeltersk
- (mag) मगही
- (pag) Pangasinan
- (guc) wayuunaiki
- (nit) కొలామి
- (de-at) Österreichisches Deutsch
- (mcn) vùn màsànà
- (mzn) مازِرونی
- (zh-yue) 粵語
- (st) Sesotho
- (tt) татарча / tatarça
- (nan-hant) 閩南語(傳統漢字)
- (tly-cyrl) толыши
- (tay) Tayal
- (he) עברית
- (scn) sicilianu
- (ky) кыргызча
- (sjd) кӣллт са̄мь кӣлл
- (cpx-hans) 莆仙语(简体)
- (osa-latn) Wažáže íe
- (ta) தமிழ்
- (wa) walon
- (ruq) Vlăheşte
- (sa) संस्कृतम्
- (ms-arab) بهاس ملايو
- (mrj) кырык мары
- (cpx) 莆仙語 / Pó-sing-gṳ̂
- (ja) 日本語
- (ii) ꆇꉙ
- (fa) فارسی
- (pt) português
- (aa) Qafár af
- (ba) башҡортса
- (bag) Tuki
- (wal) wolaytta
- (xal) хальмг
- (yav) Yangben
- (gld) на̄ни
- (bci) wawle
- (sli) Schläsch
- (glk) گیلکی
- (ab) аԥсшәа
- (blk) ပအိုဝ်ႏဘာႏသာႏ
- (rwr) मारवाड़ी
- (cu) словѣньскъ / ⰔⰎⰑⰂⰡⰐⰠⰔⰍⰟ
- (cpx-hant) 莆仙語(繁體)
- (yat) Yambeta
- (sju) ubmejesámiengiälla
- (sc) sardu
- (nog) ногайша
- (vro) võro
The previous list was generated by:
{{#invoke:Languages|forEachLanguage|preprocess=yes|pattern=<nowiki /> * <span style="font-size:smaller;">([[MediaWiki:Lang/$lc|<span style="font-family:monospace,monospace;" title="{{((}}#language:$lc{{!}}en{{))}}">{{((}}int{{!}}lang/$lc{{))}}</span>]])</span> <bdi lang="$lc" class="autonym lang-$lc">{{((}}#language:$lc{{))}}</bdi> }}
Note that as of 2020-10-18, there's a new bug in Scribunto, which causes the standard "table.sort()" function to no longer accept a standard comparison function. Now when "table.sort()" fails, the error is correctly catched (instead of producing a visible error), but the list may not be sorted correctly (temporarily) in some cases. The bug is tracked and corrected in Mediawiki but waiting to be deployed with the fix. Nothing will need to be changed (using "perror()" will then no longer have any effect, it is just needed for now and the bug was not a bug of this module which was properly tested and sudddently failed unexpectedly). Thanks.
Note:
- The list is retrieved using Module:Languages/List and sorted in native language name (LTR languages before RTL languages, then each one sorted by native script and then a locale-neutral sort order within each script) using Module:Multilingual description/sort (which is the consistant sort order used for multilingual navigation navigation boxes, or for showing lists of translations in multilingual descriptions, in a user-friendly way). For seeing the complete list of languages, tested with their directionality, look at the tests results table on Module talk:Multilingual description/sort/testcases.
Code
--[=[
Not globally exposed. Internal function only.
language_subpages( frame, transform, options )
Parameters
frame: The frame that was passed to the method invoked. The first argument or the page argument will be respected.
transform: A transform function. Example: function( basepagename, subpagename, code, langname ) end
options: An object with options. Example: { abort= { on=function() end, time=0.8 } }
Following options are available:
abort: Aborts iterating over the subpages if one of the conditions is met. If the process is aborted, nil is returned!
on: Function to be called if an abort-condition was met.
cycles: The maximum number of subpages to run over.
time: Maximum time to spend running over the subpages.
]=]
local function language_subpages( frame, transform, options )
local args, pargs, options = frame.args, ( frame:getParent() or {} ).args or {}, options or {};
local title = args.page or args[1] or pargs.page or pargs[1] or "";
local abort = options.abort or {};
local at, clock = type( abort.on ), os.clock();
local ac = function()
if at == 'function' or ( at == 'table' and getmetatable(abort.on).__call ) then
abort.on();
end
end
local tt = type( transform );
local page = require( 'Module:Page' );
title = page.clean(title);
if tt == 'function' or ( tt == 'table' and getmetatable(transform).__call ) then
local fetch, pages, langcode, langname = mw.language.fetchLanguageName, {};
--[==[
/ \
/ | \
/ · \
¯¯¯¯¯¯¯
Page.subpages() no longer works because it attempted to parse the HTML content generated by
calling the parser function "Special:Prefixindex:" which is no longer expanded in Lua but
converted to a "stripped tag" (containing a unique identifier surrounded by ASCII DEL characters)
representing the tag name and its parameters.
The actual expansion of stripped tags can no longer be performed in Lua.
Now unstripping these tags just kills ALL these tags (except "wiki" tags) instead of performing
their expansion by running the extension code. Only MediaWiki can unstrip these tags in texts after
they have been returned by Lua.
For this reason, page.subpages() is now completely empty (Module:Page no longer works).
This cannot be bypassed, except by using a Scribunto extension library if lifting the limits set by mw.unstrip.
Note that "Special:Prefixindex:" is also costly, even if it just requires a single database query to
get all subpages, instead of one costly #ifexist or one costly mw.title() property reading per
tested subpage to know if it exists.
For now there's still no reliable way to get a list of subpages, or performing queries similar to
the [[Special:Prefixindex]] page or list members of a category like when viewing a category page.
Ideally, there should exist a method for such queries on Title objects returned by the mw.title library;
but for now there's none.
In Lua now, the only expansion possible with an immediate effect is the expansion of standard templates,
all special tags or special pages, or parser function extensions do not work (Only the #expr parser
function is supported by using an external Scribunto library).
--]==]
for pg in page.subpages( title, { ignoreNS=true } ) do
if abort.cycles then
abort.cycles = abort.cycles - 1
if 0 == abort.cycles then return ac() end
end
if abort.time then
if (os.clock() - clock) > abort.time then return ac() end
end
if mw.ustring.len( pg ) <= 12 then
langcode = string.lower( pg );
langname = fetch( langcode );
if langname ~= '' then
table.insert( pages, transform( title, pg, langcode, langname ) );
end
end
end
return pages;
end
return {};
end
local function cloneArgs(frame)
local args, pargs = {}, {}
for k,v in pairs( frame.args ) do args[k] = v end
if frame:getParent() then
for k,v in pairs( frame:getParent().args ) do pargs[k] = v end
end
return args, pargs
end
local p = {};
--[=[
Usage:
{{#invoke:languages|internal|Template:Adjective}}
]=]
function p.internal(frame)
return table.concat(
language_subpages( frame,
function( title, page, code, name )
return mw.ustring.format(
'<bdi class="language lang-%s" lang="%s">[[%s/%s|%s]]</bdi>',
code, code,
title, page,
name
);
end
),
' <b>·</b> '
);
end
--[=[
Usage:
{{#invoke:languages|external|Template:Adjective}}
]=]
function p.external(frame)
return table.concat(
language_subpages( frame,
function( title, page, code, name )
return mw.ustring.format(
'<bdi class="language lang-%s" lang="%s">[%s/%s %s]</bdi>',
code, code,
tostring( mw.uri.fullUrl( title ) ), page:gsub( ' ', '_' ),
name
);
end
),
' <b>·</b> '
);
end
--[=[
forEachLanguage
This function iterates over all language codes known to MediaWiki based on a maintained list
replacing patterns in a pattern-string for each language
Usage
{{#invoke:Languages|forEachLanguage
|pattern=patternstring
|before=string to insert before iteration
|after=string added after iteration
|sep=separator string between iterations
|inLang=langcode used for $lnTrP and $lnTrUC1
}}
Parameters
pattern: A pattern string which is processed for each language and which is concatenated at the end and returned as one string
before: A string that is inserted before the concatenated result
after: A string that is inserted after the concatenated result
sep: A string that is inserted between each line created from the pattern while iterating (like ProcessedPattern_sep_ProcessedPattern_sep_ProcessedPattern)
inLang: Langcode to use for $lnTrP and $lnTrUC1
preprocess: if set to a non-empty value, the output will be preprocessed before being returned.
Warning
The output is still not prepreprocessed by default: so parser functions and magic keywords generated by the pattern are still not executed and replaced,
and template transclusions are still not expanded (see examples in other functions in this module).
When using this function directly from a MediaWiki page or template, this means it is only possible to use patterns generating basic MediaWiki formatting
or HTML tags. It you want the output to be preprocessed (in the given frame), set the preprocess parameter to a non-empty string.
Patterns
$lc - language code such as en or de
$lnP - language name in own language (autonym)
$lnUC1 - language name in own language (autonym), first letter upper case
$lnTrP - language name translated to the language requested by language code passed to inLang
$lnTrUC1 - language name translated to the language requested by language code passed to inLang, first letter upper case
Example
{{#invoke:Languages|forEachLanguage|pattern=<span lang="$lc" xml:lang="$lc" class="language lang-$lc">[[Page/$lc|$lnP]]</span>}}
]=]
-- =p.forEachLanguage({ args= { pattern = "$lc - $lnTrP\n", inLang = "en" } })
function p.forEachLanguage(frame)
local l = require("Module:Languages/List")
local ret = {}
local lang = mw.language
local line
local pattern = frame.args.pattern or frame.args[1] or ""
local prefix = frame.args.before or frame.args[2] or ""
local postfix = frame.args.after or frame.args[3] or ""
local sep = frame.args.sep or frame.args.separator or frame.args[4] or ""
local inLang = frame.args.inLang or frame.args[5] or nil
local preprocess = frame.args.preprocess or frame.args[6] or ""
local langNameUCFirstReq = not not pattern:find( "$lnUC1", 1, true )
local langNameReq = not not pattern:find( "$lnP", 1, true ) or langNameUCFirstReq
local langNameTranslatedUCFirstReq = not not pattern:find( "$lnTrUC1", 1, true )
local langNameTranslatedReq = not not pattern:find( "$lnTrP", 1, true ) or langNameTranslatedUCFirstReq
local contentLangInstance = mw.language.getContentLanguage()
local inLangLangInstance
local l = mw.language.fetchLanguageNames() -- autonyms
local lTr
local lcIdList = require('Module:Languages/List').getSortedList( l )
if langNameTranslatedReq then
inLangLangInstance = --[==[
mw.getLanguage( inLang ) -- Quota hit in :ucfirst() if using too many langInstances
--]==] contentLangInstance
lTr = mw.language.fetchLanguageNames( inLang ) -- translated names
end
for _, lcId in pairs( lcIdList ) do
local subst = lcId:gsub('%%', '%%%%')
line = pattern:gsub( "%$lc", subst )
local langName, langInstance
-- autonym (name of lcId in locale lcId)
if langNameReq then
langName = l[lcId]
subst = langName:gsub('%%', '%%%%')
line = line:gsub( "%$lnP", subst )
end
if langNameUCFirstReq then
langInstance = --[==[
mw.getLanguage( lcId ) -- Quota hit in :ucfirst() if using too many langInstances
--]==] contentLangInstance
langName = langInstance:ucfirst( langName )
subst = langName:gsub('%%', '%%%%')
line = line:gsub( "%$lnUC1", subst )
end
-- translated name (name of lcId in locale inLang)
if langNameTranslatedReq then
langName = lTr[lcId]
subst = langName:gsub('%%', '%%%%')
line = line:gsub( "%$lnTrP", subst )
end
if langNameTranslatedUCFirstReq then
langName = inLangLangInstance:ucfirst( langName )
subst = langName:gsub('%%', '%%%%')
line = line:gsub( "%$lnTrUC1", subst )
end
table.insert(ret, line)
end
ret = prefix .. table.concat( ret, sep ) .. postfix
if preprocess ~= '' then
ret = frame:preprocess(ret)
end
return ret
end
--[=[
Provide logic for [[Template:Lle]] (Language Links external, to be substituted, language names written exactly as #language would provide them)
Warning: may expands too many costly #ifexist without limitation (if not substituted into a separate "/lang" template)
]=]
function p.lle(frame)
return frame:preprocess(
p.forEachLanguage({
args = {
pattern = '{{subst:#ifexist:{{{1}}}/$lc|[{{subst:fullurl:{{{1}}}/$lc}} <bdi class="language lang-$lc" lang="$lc">$lnP</bdi>] <b>∙</b> <!--\n-->}}'
}
})
)
end
--[=[
Provide logic for [[Template:Ll]] (Language Links internal, to be substituted, language names written exactly as #language would provide them)
Warning: may expands too many costly #ifexist without limitation (if not substituted into a separate "/lang" template)
]=]
function p.ll(frame)
return frame:preprocess(
p.forEachLanguage({
args = {
pattern = '{{subst:#ifexist:{{{1}}}/$lc|[[{{{1}}}/$lc|<bdi class="language lang-$lc" lang="$lc">$lnP</bdi>]] <b>∙</b> <!--\n-->}}'
}
})
)
end
--------------------------------------------------------
--- Different approaches for [[Template:Lang links]] ---
--------------------------------------------------------
--[=[
Provide logic for [[Template:Lang links]]
Using a cute Hybrid-Method:
First check the subpages which is quite fast; if there are too many fall back to checking for each language page individually
]=]
-- =p.langLinksNonExpensive({ args= { page='Commons:Picture of the Year/2010' }, getParent=function() end })
-- =p.langLinksNonExpensive({ args= { page='Main Page' }, getParent=function() end })
-- =p.langLinksNonExpensive({ args= { page='Template:No_source_since' }, getParent=function() end })
-- =p.langLinksNonExpensive({ args= { page='MediaWiki:Gadget-HotCat' }, getParent=function() end })
function p.langLinksNonExpensive(frame)
local args, pargs = frame.args, ( frame:getParent() or {} ).args or {};
local title = args.page or args[1] or pargs.page or pargs[1] or "";
local contentLangInstance = mw.language.getContentLanguage();
local pages2
if frame.preprocess == nil then
frame = mw.getCurrentFrame()
end
--[==[
local options = {
abort = {
time = 3.5,
on = function()
pages2 = p.forEachLanguage({
args = {
pattern = '{{#ifexist:' .. title .. '/$lc|[[' .. title .. '/$lc|<bdi lang="$lc">$lnP</bdi>]] <b>∙</b> }}'
}
})
end
}
}
local pages = language_subpages( frame,
function( title, page, code, langname )
return mw.ustring.format(
'[[%s/%s|<bdi lang="%s">%s</bdi>]]</span> <b>∙</b> ',
title, page, code, langname
)
end, options );
return pages2 and frame:preprocess(pages2) or table.concat(pages, '');
--]==]
return frame:preprocess(
p.forEachLanguage( {
args = {
pattern = '{{#ifexist:' .. title .. '/$lc|[[' .. title .. '/$lc|<bdi lang="$lc">$lnP</bdi>]] <b>∙</b> }}'
}
})
)
end
---------------------------------------------------------
----------------- [[Template:Autolang]] -----------------
---------------------------------------------------------
--[[
Works like {{autotranslate}} just allowing an unlimited number of arguments, even named arguments.
It's doing Magic! No arguments should be passed to {{#invoke:}}
]]
function p.autolang(frame)
local args, pargs = cloneArgs( frame )
if nil == args.useargs then
if not args.base then args = pargs end
elseif 'both' == args.useargs then
for k,v in pairs(args) do pargs[k] = v end
args = pargs
elseif 'parent' == args.useargs then
args = pargs
if pargs.base and not args.base then
args.base = pargs.base
end
end
local base = args.base
local userlang = frame:callParserFunction('int', 'lang')
local tl, tlns = 'Template:', 10
local tlb, fallback1, currenttemplate, currenttemplatepage
local fallback, contentlang = mw.text.split( userlang, '-', true )[1], mw.language.getContentLanguage():getCode()
local function createReturn(title)
local ret
local tlargs = {}
-- When LUA is invoked, templates are already expanded. This must be respected.
return frame:expandTemplate{ title = title, args = args }
end
if not base then
return ("'autolang' in [[Module:Languages]] was called but the 'base' parameter could not be found." ..
"The base parameter specifies the template that's subpages will be sought for a suitable translation.")
end
tlb = tl .. base .. '/'
currenttemplate = tlb .. userlang
currenttemplatepage = mw.title.new( currenttemplate, tlns )
if currenttemplatepage and currenttemplatepage.exists then
return createReturn(currenttemplate)
end
fallback1 = frame:preprocess( '{{Fallback|1=' .. base .. '|2=' .. userlang .. '}}' )
if fallback1 ~= contentlang then
return createReturn(tlb .. fallback1)
end
currenttemplate = tlb .. fallback
currenttemplatepage = mw.title.new( currenttemplate, tlns )
if currenttemplatepage and currenttemplatepage.exists then
return createReturn(currenttemplate)
end
currenttemplate = tlb .. contentlang
currenttemplatepage = mw.title.new( currenttemplate, tlns )
if currenttemplatepage and currenttemplatepage.exists then
return createReturn(currenttemplate)
end
return createReturn(tl .. base)
end
--[=[
Usage:
{{#invoke:languages|isKnownLanguageTag|gsw}} -> 1
{{#invoke:languages|isKnownLanguageTag|doesNotExist}} ->
]=]
function p.isKnownLanguageTag(frame)
return mw.language.isKnownLanguageTag( frame.args[1] or frame.args.tag or frame.args.code or '' ) and '1' or ''
end
function p.file_languages(frame)
local M_link = require( 'Module:Link' )
local contentLangInstance = mw.language.getContentLanguage()
local pattern = frame.args.pattern or '%s (%s)'
local original = frame.args.original or mw.title.getCurrentTitle().text
local ext_start, _ = string.find( original, '\.%w+$' )
local file_ext = string.sub( original, ext_start )
original = string.sub( original, 0, ext_start - 1 )
return frame:preprocess(
'<gallery>\n' ..
(table.concat(
M_link.forEachLink(
p.forEachLanguage({
args = { pattern = '[[$lc]]' }
}),
function( linkInfo )
local filename = mw.ustring.format( pattern, original, linkInfo.text ) .. file_ext
local filepage = mw.title.new( filename, 6 )
if filepage and filepage.exists then
return mw.ustring.format( '%s|%s',
filename,
mw.language.fetchLanguageName( linkInfo.text )
)
else
return nil
end
end
), '\n'
)) ..
'\n</gallery>'
)
end
function p.runTests()
return p.langLinksNonExpensive({
args = {
page = 'Module:Languages/testcases/test'
},
getParent = function() end
}) ==
'[[Module:Languages/testcases/test/de|<bdi lang="de">Deutsch</bdi>]] <b>∙</b> ' ..
'[[Module:Languages/testcases/test/en|<bdi lang="en">English</bdi>]] <b>∙</b> '
end
return p;