پودمان:Lang/data: تفاوت میان نسخه‌ها

از ویکی باریستا
جز ۱ نسخه واردشده
جز ۱ نسخه واردشده
 
(یک نسخهٔ میانی ویرایش شده توسط یک کاربر دیگر نشان داده نشد)
خط ۱: خط ۱:
local lang_obj = mw.language.getContentLanguage();
local this_wiki_lang_tag = lang_obj.code; -- get this wiki's language tag
--[[--------------------------< L A N G _ N A M E _ T A B L E >------------------------------------------------
--[[--------------------------< L A N G _ N A M E _ T A B L E >------------------------------------------------


خط ۱۰: خط ۱۴:
all of these data come from separate modules that are derived from the IANA language-subtag-registry file
all of these data come from separate modules that are derived from the IANA language-subtag-registry file


key_to_lower() avoids the metatable trap and sets all keys in the subtables to lowercase. Many language codes
key_to_lower() avoids the metatable trap and sets all keys in the subtables to lowercase. Many language codes
have multiple associated names; Module:lang is only concerned with the first name so key_to_lower() only fetches
have multiple associated names; Module:lang is only concerned with the first name so key_to_lower() only fetches
the first name.
the first name.
TODO: instead of returning:
["key"] = {"name"}
where each table has only one name, return
["key"] = "name"
requires changes in Module:Lang.


]]
]]
خط ۲۴: خط ۲۲:
local function key_to_lower (module, src_type)
local function key_to_lower (module, src_type)
local out = {};
local out = {};
local source = (('var_sup' == src_type) and require (module)) or mw.loadData (module); -- fetch data from this module; require() avoids metatable trap for variant data
local source_t = (('var_sup' == src_type) and require (module)) or mw.loadData (module); -- fetch data from this module; require() avoids metatable trap for variant data
 
if 'var_sup' == src_type then
if 'var_sup' == src_type then
for k, v in pairs (source) do
for k, v in pairs (source_t) do
out[k:lower()] = v; -- for variant, everything is needed
out[k:lower()] = v; -- for variant and suppressed everything is needed
end
end


elseif 'lang' == src_type and source.active then -- for ~/iana_languages (active)
elseif 'lang' == src_type and source_t.active then -- for ~/iana_languages (active)
for k, v in pairs (source.active) do
for k, v in pairs (source_t.active) do
out[k:lower()] = {v[1]}; -- ignore multiple names; take first name only
out[k:lower()] = v[1]; -- ignore multiple names; take first name only
end
end


elseif 'lang_dep' == src_type and source.deprecated then -- for ~/iana_languages (deprecated)
elseif 'lang_dep' == src_type and source_t.deprecated then -- for ~/iana_languages (deprecated)
for k, v in pairs (source.deprecated) do
for k, v in pairs (source_t.deprecated) do
out[k:lower()] = {v[1]}; -- ignore multiple names; take first name only
out[k:lower()] = v[1]; -- ignore multiple names; take first name only
end
end


else -- here for all other sources
else -- here for all other sources
for k, v in pairs (source) do
for k, v in pairs (source_t) do
out[k:lower()] = {v[1]}; -- ignore multiple names; take first name only
out[k:lower()] = v[1]; -- ignore multiple names; take first name only
end
end
end
end
خط ۴۸: خط ۴۷:
end
end


local lang_name_table = {
local lang_name_table_t = {
lang = key_to_lower ('Module:Language/data/iana languages', 'lang'),
lang = key_to_lower ('Module:Lang/data/iana languages', 'lang'),
lang_dep = key_to_lower ('Module:Language/data/iana languages', 'lang_dep'),
lang_dep = key_to_lower ('Module:Lang/data/iana languages', 'lang_dep'),
script = key_to_lower ('Module:Language/data/iana scripts'), -- script keys are capitalized; set to lower
script = key_to_lower ('Module:Lang/data/iana scripts'), -- script keys are capitalized; set to lower
region = key_to_lower ('Module:Language/data/iana regions'), -- region keys are uppercase; set to lower
region = key_to_lower ('Module:Lang/data/iana regions'), -- region keys are uppercase; set to lower
variant = key_to_lower ('Module:Language/data/iana variants', 'var_sup'),
variant = key_to_lower ('Module:Lang/data/iana variants', 'var_sup'),
suppressed = key_to_lower ('Module:Language/data/iana suppressed scripts', 'var_sup'), -- script keys are capitalized; set to lower
suppressed = key_to_lower ('Module:Lang/data/iana suppressed scripts', 'var_sup'), -- script keys are capitalized; set to lower
}
}
--[[--------------------------< I 1 8 N  M E D I A W I K I  O V E R R I D E >--------------------------------
For internationalization; not used at en.wiki
The language names taken from the IANA language-subtag-registry file are given in English. That may not be ideal.
Translating ~8,000 language names is also not ideal.  MediaWiki maintains (much) shorter lists of language names
in most languages for which there is a Wikipedia edition.  When desired, Module:Lang can use the MediaWiki
language list for the local language.
Caveat lector: the list of MediaWiki language names for your language may not be complete or may not exist at all.
When incomplete, MediaWiki's list will 'fall back' to another language (typically English).  When that happens
add an appropriate entry to the override table below.
Caveat lector: the list of MediaWiki language names for your language may not be correct.  At en.wiki, the
MediaWiki language names do not agree with the IANA language names for these ISO 639-1 tags.  Often it is simply
spelling differences:
bh: IANA: Bihari languages MW: Bhojpuri – the ISO 639-3 tag for Bhojpuri is bho
bn: IANA: Bengali MW: Bangla – Bengali is the exonym, Bangla is the endonym
dv: IANA: Dhivehi MW: Divehi
el: IANA: Modern Greek MW: Greek
ht: IANA: Haitian MW: Haitian Creole
ky: IANA: Kirghiz MW: Kyrgyz
li: IANA: Limburgan MW: Limburgish
or: IANA: Oriya MW: Odia
os: IANA: Ossetian MW: Ossetic
"pa: IANA: Panjabi MW: Punjabi
"ps: IANA: Pushto MW: Pashto
"to: IANA: Tonga MW: Tongan
"ug: IANA: Uighur MW: Uyghur
use the override table to override language names that are incorrect for your project
To see the list of names that MediaWiki has for your language, enter this in the Debug colsole:
=mw.dumpObject (mw.language.fetchLanguageNames ('<tag>', 'all'))
(replacing <tag> with the language tag for your language)
Use of the MediaWiki language names lists is enabled when media_wiki_override_enable is set to boolean true.
]]
local media_wiki_override_enable = false; -- set to true to override IANA names with MediaWiki names; always false at en.wiki
-- caveat lector: the list of MediaWiki language names for your language may not be complete or may not exist at all
if true == media_wiki_override_enable then
local mw_languages_by_tag_t = mw.language.fetchLanguageNames (this_wiki_lang_tag, 'all'); -- get a table of language tag/name pairs known to MediaWiki
for tag, name in pairs (mw_languages_by_tag_t) do -- loop through each tag/name pair in the MediaWiki list
if lang_name_table_t.lang[tag] then -- if the tag is in the main list
lang_name_table_t.lang[tag] = name; -- overwrite exisiting name with the name from MediaWiki
end
end
end




خط ۶۷: خط ۱۱۷:


local override = {
local override = {
------------------------------< I S O   6 3 9 - 1 >------------------------------------------------------------
------------------------------< I S O _ 6 3 9 - 1 >------------------------------------------------------------


["ca-valencia"] = {"والنسیایی"},
["ab"] = "Abkhaz",                                                          -- to match en.wiki article name
["cu"] = {"اسلاوی کلیسایی"},   --2nd IANA name;
["ca-valencia"] = "Valencian",
["de-at"] = {"آلمانی اتریشی"}, -- these code-region and code-variant tags to match en.wiki article names
["cu"] = "Church Slavonic", -- 2nd IANA name;
["de-ch"] = {"آلمانی معیار سوئیس"},
["de-at"] = "Austrian German", -- these code-region and code-variant tags to match en.wiki article names
["en-au"] = {"انگلیسی استرالیایی"},
["de-ch"] = "Swiss Standard German",
["en-ca"] = {"انگلیسی کانادایی"},
["en-au"] = "Australian English",
["en-emodeng"] = {"انگلیسی نو نخستین"},
["en-ca"] = "Canadian English",
["en-gb"] = {"انگلیسی بریتانیایی"},
["en-emodeng"] = "Early Modern English",
["en-ie"] = {"انگلیسی ایرلندی"},
["en-gb"] = "British English",
["en-in"] = {"انگلیسی هندی"},
["en-ie"] = "Irish English",
["en-nz"] = {"New Zealand English"}, -- no article yet
["en-in"] = "Indian English",
["en-us"] = {"انگلیسی آمریکایی"},
["en-nz"] = "New Zealand English",
["en-za"] = {"South African English"}, -- no article yet
["en-us"] = "American English",
["fy"] = {"فریسی غربی"}, -- Western Frisian
["en-za"] = "South African English",
["mo"] = {"مولداویایی"}, -- Moldavian (deprecated code); to match en.wiki article title
["fr-ca"] = "Quebec French",
["oc-provenc"] = {"پرونسی"},
["fr-gallo"] = "Gallo",
["ps"] = {"پشتو"}, -- Pushto
["fy"] = "West Frisian", -- Western Frisian
["tw-asante"] = {"Asante Twi"}, -- no article yet
["mo"] = "Moldovan", -- Moldavian (deprecated code); to match en.wiki article title
["pt-br"] = {"پرتغالی برزیلی"},
["nl-be"] = "Flemish", -- match MediaWiki
["oc-gascon"] = "Gascon",
["oc-provenc"] = "Provençal",
["ps"] = "Pashto", -- Pushto
["pt-br"] = "Brazilian Portuguese", -- match MediaWiki
["ro-md"] = "Moldovan", -- 'not deprecated' form
["ro-cyrl-md"] = "Moldovan", -- 'not deprecated' form
["tw-asante"] = "Asante Twi",
["ug"] = "Uyghur", -- 2nd IANA name; to match en.wiki article name


-- these ISO 639-1 language-name overrides imported from Module:Language/data/wp_languages
-- these ISO 639-1 language-name overrides imported from Module:Language/data/wp_languages (since deleted)
--<begin do-not-edit except to comment out>--
--<begin do-not-edit except to comment out>--
["av"] = {"آواری"}, -- Avaric
["av"] = "Avar", -- Avaric
["bo"] = {"تبتی معیار"}, -- Tibetan
["bo"] = "Standard Tibetan", -- Tibetan
["el"] = {"یونانی"}, -- Modern Greek
["el"] = "Greek", -- Modern Greek
-- ["en-SA"] = {"South African English"}, -- English; no; SA is not South Africa it Saudi Arabia; ZA is South Africa
-- ["en-SA"] = "South African English", -- English; no; SA is not South Africa it Saudi Arabia; ZA is South Africa
["ff"] = {"فولانی"}, -- Fulah
["ff"] = "Fula", -- Fulah
["ht"] = {"کریول آییسینی"}, -- Haitian
["ht"] = "Haitian Creole", -- Haitian
["hz"] = {"هررو"}, -- Herero
["hz"] = "Otjiherero", -- Herero
["ii"] = {"یی"}, -- Sichuan Yi
["ii"] = "Yi", -- Sichuan Yi
["ki"] = {"کیکویو"}, -- Kikuyu
["ki"] = "Gikuyu", -- Kikuyu
["kl"] = {"گرینلندی"}, -- Kalaallisut
["kl"] = "Greenlandic", -- Kalaallisut
["ky"] = {"قرقیزی"}, -- Kirghiz
["ky"] = "Kyrgyz", -- Kirghiz
["lg"] = {"لوگاندا"}, -- Ganda
["lg"] = "Luganda", -- Ganda
["li"] = {"لیمبورخی"}, -- Limburgan
["li"] = "Limburgish", -- Limburgan
["mi"] = {"مائوری"}, -- Maori
["mi"] = "Māori", -- Maori
["na"] = {"نائورویی"}, -- Nauru
["na"] = "Nauruan", -- Nauru
["nb"] = {"بوکمل"}, -- Norwegian Bokmål
["nb"] = "Bokmål", -- Norwegian Bokmål
["nd"] = {"اندبله شمالی"}, -- North Ndebele
["nd"] = "Northern Ndebele", -- North Ndebele
["nn"] = {"نروژی نو"}, -- Norwegian Nynorsk
["nn"] = "Nynorsk", -- Norwegian Nynorsk
["nr"] = {"اندبله جنوبی"}, -- South Ndebele
["nr"] = "Southern Ndebele", -- South Ndebele
["ny"] = {"چوایی"}, -- Nyanja
["ny"] = "Chichewa", -- Nyanja
["oj"] = {"اوجیبوی"}, -- Ojibwa
["oj"] = "Ojibwe", -- Ojibwa
["or"] = {"اوریه"}, -- Oriya
["or"] = "Odia", -- Oriya
["pa"] = {"پنجابی"}, -- Panjabi
["pa"] = "Punjabi", -- Panjabi
["rn"] = {"روندی"}, -- Rundi
["rn"] = "Kirundi", -- Rundi
["sl"] = {"اسلوونیایی"}, -- Slovenian
["sl"] = "Slovene", -- Slovenian
["ss"] = {"سوازی"}, -- Swati
["ss"] = "Swazi", -- Swati
["st"] = {"سوتو"}, -- Southern Sotho
["st"] = "Sotho", -- Southern Sotho
["to"] = {"تونگایی"}, -- Tonga
["to"] = "Tongan", -- Tonga
--<end do-not-edit except to comment out>--
--<end do-not-edit except to comment out>--




------------------------------< I S O   6 3 9 - 2,  - 3,  - 5 >----------------------------------------------
------------------------------< I S O _ 6 3 9 - 2,  - 3,  - 5 >----------------------------------------------


["arc"] = {"آرامی"}, -- Official Aramaic (700-300 BCE), Imperial Aramaic (700-300 BCE);
["alv"] = "Atlantic–Congo languages", -- to match en.wiki article title (endash)
["art"] = {"فراساخته"}, -- to match en.wiki article; lowercase for category name
["arc"] = "Imperial Aramaic (700-300 BCE)", -- Official Aramaic (700-300 BCE), Imperial Aramaic (700-300 BCE); to match en.wiki article title uses ISO639-2 'preferred' name
["bhd"] = {"Bhadarwahi"}, -- Bhadrawahi; to match en.wiki article title
["art"] = "constructed", -- to match en.wiki article; lowercase for category name
["bla"] = {"Blackfoot"}, -- Siksika; to match en.wiki article title
["bea"] = "Dane-zaa", -- Beaver; to match en.wiki article title
["bua"] = {"بوریاتی"}, -- Buriat; this is a macro language; these four use wp preferred transliteration;
["bhd"] = "Bhadarwahi", -- Bhadrawahi; to match en.wiki article title
["bxm"] = {"بوریاتی مغولی"}, -- Mongolia Buriat; these three all redirect to Buryat
["bla"] = "Blackfoot", -- Siksika; to match en.wiki article title
["bxr"] = {"بوریاتی روسی"}, -- Russia Buriat;
["blc"] = "Nuxalk", -- Bella Coola; to match en.wiki article title
["bxu"] = {"بوریاتی چینی"}, -- China Buriat;
["bua"] = "Buryat", -- Buriat; this is a macro language; these four use wp preferred transliteration;
["byr"] = {"Yipma"}, -- Baruya, Yipma
["bxm"] = "Mongolian Buryat", -- Mongolia Buriat; these three all redirect to Buryat
["egy"] = {"مصری باستان"}, -- Egyptian (Ancient); distinguish from contemporary arz: Egyptian Arabic  
["bxr"] = "Russian Buryat", -- Russia Buriat;
["frr"] = {"فریسی شمالی"}, -- Northern Frisian
["bxu"] = "Chinese Buryat", -- China Buriat;
["frs"] = {"East Frisian Low Saxon"}, -- Eastern Frisian
["byr"] = "Yipma", -- Baruya, Yipma
["ilo"] = {"ایلوکانو"}, -- Iloko; to match en.wiki article title
["clm"] = "Klallam", -- Clallam; to match en.wiki article title
["jam"] = {"پتوای جامائیکایی"}, -- Jamaican Creole English
["egy"] = "Ancient Egyptian", -- Egyptian (Ancient); distinguish from contemporary arz: Egyptian Arabic  
["mhr"] = {"ماری مرغزاری"}, -- Eastern Mari
["ems"] = "Alutiiq", -- Pacific Gulf Yupik; to match en.wiki article title
["mid"] = {"مندائی مدرن"}, -- Mandaic
["esx"] = "Eskimo–Aleut languages", -- to match en.wiki article title (endash)
["mla"] = {"Tamambo"}, -- Malo
["frr"] = "North Frisian", -- Northern Frisian
['mte'] = {"Mono-Alu"}, -- Mono (Solomon Islands)
["frs"] = "East Frisian Low Saxon", -- Eastern Frisian
["nan-tw"] = {"هاکین تایوانی"}, -- make room for IANA / 639-3 nan Min Nan Chinese; match en.wiki article title
["gsw-fr"] = "Alsatian", -- match MediaWiki
["nrf"] = {"نورمان"}, -- not quite a collective - IANA name: Jèrriais; categorizes to Norman-language text
["haa"] = "Hän", -- Han; to match en.wiki article title
["nzi"] = {"Nzema"}, -- Nzima; to match en.wiki article title
["hei"] = "Heiltsuk–Oowekyala", -- Heiltsuk; to match en.wiki article title
["orv"] = {"اسلاوی شرقی باستان"}, -- Old Russian
["hmx"] = "Hmong–Mien languages", -- to match en.wiki article title (endash)
["pfl"] = {"آلمانی پالاتن"}, -- Pfaelzisch; to match en.wiki article
["ilo"] = "Ilocano", -- Iloko; to match en.wiki article title
["pms"] = {"پیدمونتی"}, -- Piemontese; to match en.wiki article title
["jam"] = "Jamaican Patois", -- Jamaican Creole English
["pnb"] = {"پنجابی (غربی)"}, -- Western Panjabi; dab added to override import from ~/wp languages and distinguish pnb from pa in reverse look up tag_from_name()
["lij-mc"] = "Monégasque", -- Ligurian as spoken in Monaco; this one for proper tool tip; also in <article_name> table
["stq"] = {"فریسی ساترلند"}, -- Saterfriesisch
["luo"] = "Dholuo", -- IANA (primary) /ISO 639-3: Luo (Kenya and Tanzania); IANA (secondary): Dholuo
["und"] = {"نامشخص"}, -- capitalization to match existing category
["mhr"] = "Meadow Mari", -- Eastern Mari
["wrg"] = {"Warrongo"}, -- Warungu
["mid"] = "Modern Mandaic", -- Mandaic
["xal-ru"] = {"قالمیق"}, -- to match en.wiki article title
['mis'] = "uncoded", -- Uncoded languages; capitalization; special scope, not collective scope;
["xgf"] = {"Tongva"}, -- ISO 639-3 is Gabrielino-Fernandeño
["mkh"] = "Mon–Khmer languages", -- to match en.wiki article title (endash)
["mla"] = "Tamambo", -- Malo
['mte'] = "Mono-Alu", -- Mono (Solomon Islands)
['mul'] = "multiple", -- Multiple languages; capitalization; special scope, not collective scope;
["nan-tw"] = "Taiwanese Hokkien", -- make room for IANA / 639-3 nan Min Nan Chinese; match en.wiki article title
["new"] = "Newar", -- Newari, Nepal Bhasa; to match en,wiki article title
["ngf"] = "Trans–New Guinea languages", -- to match en.wiki article title (endash)
["nic"] = "Niger–Congo languages", -- Niger-Kordofanian languages; to match en,wiki article title
["nrf"] = "Norman", -- not quite a collective - IANA name: Jèrriais + Guernésiais; categorizes to Norman-language text
["nrf-gg"] = "Guernésiais", -- match MediaWiki
["nrf-je"] = "Jèrriais", -- match MediaWiki
["nzi"] = "Nzema", -- Nzima; to match en.wiki article title
["oma"] = "Omaha–Ponca", -- to match en.wiki article title (endash)
["orv"] = "Old East Slavic", -- Old Russian
["pfl"] = "Palatine German", -- Pfaelzisch; to match en.wiki article
["pie"] = "Piro Pueblo", -- Piro; to match en.wiki article
["pms"] = "Piedmontese", -- Piemontese; to match en.wiki article title
["pnb"] = "Punjabi (Western)", -- Western Panjabi; dab added to override import from ~/wp languages and distinguish pnb from pa in reverse look up tag_from_name()
['qwm'] = "Cuman", -- Kuman (Russia); to match en.wiki article name
["rop"] = "Australian Kriol", -- Kriol; en.wiki article is a dab; point to correct en.wiki article
["sco-ulster"] = "Ulster Scots",
["sdo"] = "Bukar–Sadong", -- Bukar-Sadung Bidayuh; to match en.wiki article title
["smp"] = "Samaritan Hebrew", -- to match en.wiki article title
["stq"] = "Saterland Frisian", -- Saterfriesisch
["und"] = "undetermined", -- capitalization to match existing category
["wrg"] = "Warrongo", -- Warungu
["xal-ru"] = "Kalmyk", -- to match en.wiki article title
["xgf"] = "Tongva", -- ISO 639-3 is Gabrielino-Fernandeño
["yuf"] = "Havasupai–Hualapai", -- Havasupai-Walapai-Yavapai; to match en.wiki article title
["zxx"] = "no linguistic content", -- capitalization


-- these ISO 639-2, -3 language-name overrides imported from Module:Language/data/wp_languages
-- these ISO 639-2, -3 language-name overrides imported from Module:Language/data/wp_languages (since deleted)
--<begin do-not-edit except to comment out>--
--<begin do-not-edit except to comment out>--
["ace"] = {"آچه‌ای"}, -- Achinese
["ace"] = "Acehnese", -- Achinese
["aec"] = {"عربی صعیدی"}, -- Saidi Arabic
["aec"] = "Sa'idi Arabic", -- Saidi Arabic
["akl"] = {"آکلانی"}, -- Aklanon
["akl"] = "Aklan", -- Aklanon
["alt"] = {"آلتای"}, -- Southern Altai
["alt"] = "Altay", -- Southern Altai
["apm"] = {"Mescalero-Chiricahua"}, -- Mescalero-Chiricahua Apache
["apm"] = "Mescalero-Chiricahua", -- Mescalero-Chiricahua Apache
["bal"] = {"بلوچی"}, -- Baluchi
["bal"] = "Balochi", -- Baluchi
["bcl"] = {"بیکول مرکزی"}, -- Central Bikol
-- ["bcl"] = "Central Bicolano", -- Central Bikol
["bin"] = {"ادو"}, -- Bini
["bin"] = "Edo", -- Bini
["bpy"] = {"بیشنوپریا مانیپوری"}, -- Bishnupriya
["bpy"] = "Bishnupriya Manipuri", -- Bishnupriya
["chg"] = {"جغتایی"}, -- Chagatai
["chg"] = "Chagatay", -- Chagatai
["ckb"] = {"کردی سورانی"}, -- Central Kurdish
["ckb"] = "Sorani Kurdish", -- Central Kurdish
["cnu"] = {"Shenwa"}, -- Chenoua
["cnu"] = "Shenwa", -- Chenoua
["coc"] = {"Cocopah"}, -- Cocopa
["coc"] = "Cocopah", -- Cocopa
["diq"] = {"زازاکی"}, -- Dimli
["diq"] = "Zazaki", -- Dimli
["fit"] = {"مینکیلی"}, -- Tornedalen Finnish
["fit"] = "Meänkieli", -- Tornedalen Finnish
["fkv"] = {"کون"}, -- Kven Finnish
["fkv"] = "Kven", -- Kven Finnish
["frk"] = {"فرانکی باستان"}, -- Frankish
["frk"] = "Old Frankish", -- Frankish
["gez"] = {"گعز"}, -- Geez
["gez"] = "Ge'ez", -- Geez
["gju"] = {"گوجری"}, -- Gujari
["gju"] = "Gujari", -- Gujari
["gsw"] = {"آلمانیش"}, -- Swiss German
["gsw"] = "Alemannic German", -- Swiss German
["gul"] = {"Gullah"}, -- Sea Island Creole English
["gul"] = "Gullah", -- Sea Island Creole English
["hak"] = {"هاکا"}, -- Hakka Chinese
["hak"] = "Hakka", -- Hakka Chinese
["hbo"] = {"عبری توراتی"}, -- Ancient Hebrew
["hbo"] = "Biblical Hebrew", -- Ancient Hebrew
["hnd"] = {"هندکو"}, -- Southern Hindko
["hnd"] = "Hindko", -- Southern Hindko
-- ["ikt"] = {"Inuvialuk"}, -- Inuinnaqtun
-- ["ikt"] = "Inuvialuk", -- Inuinnaqtun
["kaa"] = {"قره‌قالپاقی"}, -- Kara-Kalpak
["kaa"] = "Karakalpak", -- Kara-Kalpak
["khb"] = {"تای لو"}, -- Lü
["khb"] = "Tai Lü", -- Lü
["kmr"] = {"کردی کرمانجی"}, -- Northern Kurdish
["kmr"] = "Kurmanji Kurdish", -- Northern Kurdish
["kpo"] = {"Kposo"}, -- Ikposo
["kpo"] = "Kposo", -- Ikposo
["krj"] = {"Kinaray-a"}, -- Kinaray-A
["krj"] = "Kinaray-a", -- Kinaray-A
["ktz"] = {"Juǀ'hoan"}, -- Juǀʼhoan
-- ["ktz"] = "Juǀ'hoan", -- Juǀʼhoan
["lez"] = {"لزگی"}, -- Lezghian
["lez"] = "Lezgian", -- Lezghian
["liv"] = {"لیوونیایی"}, -- Liv
["liv"] = "Livonian", -- Liv
["lng"] = {"Lombardic"}, -- Langobardic
["lng"] = "Lombardic", -- Langobardic
["mia"] = {"میامی-ایلینوی"}, -- Miami
["mia"] = "Miami-Illinois", -- Miami
["miq"] = {"Miskito"}, -- Mískito
["miq"] = "Miskito", -- Mískito
["mix"] = {"Mixtec"}, -- Mixtepec Mixtec
["mix"] = "Mixtec", -- Mixtepec Mixtec
["mni"] = {"مانیپوری"}, -- Manipuri
["mni"] = "Meitei", -- Manipuri
["mrj"] = {"ماری تپه‌ای"}, -- Western Mari
["mrj"] = "Hill Mari", -- Western Mari
["mww"] = {"همونگ سفید"}, -- Hmong Daw
["mww"] = "White Hmong", -- Hmong Daw
["nds-nl"] = {"ساکسونی سفلای هلند"}, -- Low German
["nds-nl"] = "Dutch Low Saxon", -- Low German
["new"] = {"نپال بهاسایی"}, -- Newari
-- ["new"] = "Nepal Bhasa", -- Newari
["nso"] = {"سوتوی شمالی"}, -- Pedi
["nso"] = "Northern Sotho", -- Pedi
["nwc"] = {"Classical Nepal Bhasa"}, -- Classical Newari
-- ["nwc"] = "Classical Nepal Bhasa", -- Classical Newari, Classical Nepal Bhasa, Old Newari
["ood"] = {"اوئدام"}, -- Tohono O'odham
["ood"] = "O'odham", -- Tohono O'odham
["otk"] = {"ترکی باستان"}, -- Old Turkish
["otk"] = "Old Turkic", -- Old Turkish
["pal"] = {"پارسی میانه"}, -- Pahlavi
["pal"] = "Middle Persian", -- Pahlavi
["pam"] = {"کاپامپانگان"}, -- Pampanga
["pam"] = "Kapampangan", -- Pampanga
["phr"] = {"پوتواری"}, -- Pahari-Potwari
["phr"] = "Potwari", -- Pahari-Potwari
["pka"] = {"پراکریت"}, -- Ardhamāgadhī Prākrit
["pka"] = "Jain Prakrit", -- Ardhamāgadhī Prākrit
-- ["pnb"] = {"پنجابی"}, -- Western Panjabi
-- ["pnb"] = "Punjabi", -- Western Panjabi
["psu"] = {"Shauraseni"}, -- Sauraseni Prākrit
["psu"] = "Shauraseni", -- Sauraseni Prākrit
["rap"] = {"رپا نویی"}, -- Rapanui
["rap"] = "Rapa Nui", -- Rapanui
["rar"] = {"مائوری جزایر کوک"}, -- Rarotongan
["rar"] = "Cook Islands Māori", -- Rarotongan
["rmu"] = {"Scandoromani"}, -- Tavringer Romani
["rmu"] = "Scandoromani", -- Tavringer Romani
["rom"] = {"رومانی"}, -- Romany
["rom"] = "Romani", -- Romany
["rup"] = {"آرومانی"}, -- Macedo-Romanian
["rup"] = "Aromanian", -- Macedo-Romanian
["ryu"] = {"اوکیناوایی"}, -- Central Okinawan
["ryu"] = "Okinawan", -- Central Okinawan
["sdc"] = {"ساساری"}, -- Sassarese Sardinian
["sdc"] = "Sassarese", -- Sassarese Sardinian
["sdn"] = {"گالوری"}, -- Gallurese Sardinian
["sdn"] = "Gallurese", -- Gallurese Sardinian
["shp"] = {"Shipibo"}, -- Shipibo-Conibo
["shp"] = "Shipibo", -- Shipibo-Conibo
["src"] = {"لوگودوری"}, -- Logudorese Sardinian
["src"] = "Logudorese", -- Logudorese Sardinian
["sro"] = {"کامپیدانی"}, -- Campidanese Sardinian
["sro"] = "Campidanese", -- Campidanese Sardinian
["tkl"] = {"توکلائویی"}, -- Tokelau
["tkl"] = "Tokelauan", -- Tokelau
["tvl"] = {"تووالویی"}, -- Tuvalu
["tvl"] = "Tuvaluan", -- Tuvalu
["tyv"] = {"تووایی"}, -- Tuvinian
["tyv"] = "Tuvan", -- Tuvinian
["vls"] = {"فلاندری غربی"}, -- Vlaams
["vls"] = "West Flemish", -- Vlaams
["wep"] = {"وستفالی"}, -- Westphalien
["wep"] = "Westphalian", -- Westphalien
["xal"] = {"اویرات"}, -- Kalmyk
["xal"] = "Oirat", -- Kalmyk
["xcl"] = {"ارمنی باستان"}, -- Classical Armenian
["xcl"] = "Old Armenian", -- Classical Armenian
["yua"] = {"مایایی یوکاتانی"}, -- Yucateco
["yua"] = "Yucatec Maya", -- Yucateco
--<end do-not-edit except to comment out>--
--<end do-not-edit except to comment out>--




------------------------------< P R I V A T E - U S E   T A G S >----------------------------------------------
------------------------------< P R I V A T E _ U S E _ T A G S >----------------------------------------------


["cel-x-proto"] = {"Proto-Celtic"}, -- cel in IANA is Celtic languages
["akk-x-latbabyl"] = "Late Babylonian Akkadian",
["gem-x-proto"] = {"نیاژرمنی"}, -- gem in IANA is Germanic languages
["akk-x-midassyr"] = "Middle Assyrian Akkadian",
["grc-x-aeolic"] = {"Aeolic Greek"}, -- these grc-x-... codes are preferred alternates to the non-standard catchall code grc-gre
["akk-x-midbabyl"] = "Middle Babylonian Akkadian",
["grc-x-attic"] = {"یونانی آتنی"},
["akk-x-neoassyr"] = "Neo-Assyrian Akkadian",
["grc-x-biblical"] = {"یونانی انجیلی"},
["akk-x-neobabyl"] = "Neo-Babylonian Akkadian",
["grc-x-byzant"] = {"یونانی بیزانسی"},
["akk-x-old"] = "Old Akkadian",
["grc-x-classic"] = {"یونانی کلاسیک"},
["akk-x-oldassyr"] = "Old Assyrian Akkadian",
["grc-x-doric"] = {"Doric Greek"},
["akk-x-oldbabyl"] = "Old Babylonian Akkadian",
["grc-x-hellen"] = {"یونانی هلنی"},
["alg-x-proto"] = "Proto-Algonquian", -- alg in IANA is Algonquian languages
["grc-x-ionic"] = {"Ionic Greek"},
["ca-x-old"] = "Old Catalan",
["grc-x-koine"] = {"یونانی کوینه"},
["cel-x-combrit"] = "Common Brittonic", -- cel in IANA is Celtic languages
["grc-x-medieval"] = {"یونانی میانه"},
["cel-x-proto"] = "Proto-Celtic",
["grc-x-patris"] = {"Patristic Greek"},
["egy-x-demotic"] = "Demotic Egyptian",
["grk-x-proto"] = {"نیایونانی"}, -- grk in IANA is Greek languages
["egy-x-late"] = "Late Egyptian",
["iir-x-proto"] = {"نیاهندوایرانی"}, -- iir in IANA is Indo-Iranian Languages
["egy-x-middle"] = "Middle Egyptian",
["ira-x-proto"] = {"نیاایرانی"}, -- ira in IANA is Iranian languages
["egy-x-old"] = "Old Egyptian",
["itc-x-proto"] = {"نیاایتالی"}, -- itc in IANA is Italic languages
["gem-x-proto"] = "Proto-Germanic", -- gem in IANA is Germanic languages
["ksh-x-colog"] = {"Colognian"}, -- en.wiki article is Colognian; ksh (Kölsch) redirects there
["gmw-x-ecg"] = "East Central German",
["mis-x-ripuar"] = {"ریپواری"}, -- replaces improper use of ksh in wp_languages
["grc-x-aeolic"] = "Aeolic Greek", -- these grc-x-... codes are preferred alternates to the non-standard catchall code grc-gre
["sla-x-proto"] = {"نیااسلاوی"}, -- sla in IANA is Slavic languages
["grc-x-attic"] = "Attic Greek",
["yuf-x-hav"] = {"Havasupai"}, -- IANA name for these three is Havasupai-Walapai-Yavapai
["grc-x-biblical"] = "Biblical Greek",
["yuf-x-wal"] = {"Walapai"},
["grc-x-byzant"] = "Byzantine Greek",
["yuf-x-yav"] = {"Yavapai"},
["grc-x-classic"] = "Classical Greek",
["grc-x-doric"] = "Doric Greek",
["grc-x-hellen"] = "Hellenistic Greek",
["grc-x-ionic"] = "Ionic Greek",
["grc-x-koine"] = "Koinē Greek",
["grc-x-medieval"] = "Medieval Greek",
["grc-x-patris"] = "Patristic Greek",
["grk-x-proto"] = "Proto-Greek", -- grk in IANA is Greek languages
["iir-x-proto"] = "Proto-Indo-Iranian", -- iir in IANA is Indo-Iranian Languages
["inc-x-mitanni"] = "Mitanni-Aryan", -- inc in IANA is Indic languages
["inc-x-proto"] = "Proto-Indo-Aryan",
["ine-x-anatolia"] = "Anatolian languages",
["ine-x-proto"] = "Proto-Indo-European",
["ira-x-proto"] = "Proto-Iranian", -- ira in IANA is Iranian languages
["itc-x-proto"] = "Proto-Italic", -- itc in IANA is Italic languages
["ksh-x-colog"] = "Colognian", -- en.wiki article is Colognian; ksh (Kölsch) redirects there
["la-x-medieval"] = "Medieval Latin",
["la-x-new"] = "New Latin",
["lmo-x-milanese"] = "Milanese", -- lmo in IANA is Lombard; Milanese is a dialect
["mis-x-ripuar"] = "Ripuarian", -- replaces improper use of ksh in wp_languages
["prg-x-old"] = "Old Prussian",
["sem-x-ammonite"] = "Ammonite",
["sem-x-aramaic"] = "Aramaic",
["sem-x-canaan"] = "Canaanite languages",
["sem-x-dumaitic"] = "Dumaitic",
["sem-x-egurage"] = "Eastern Gurage",
["sem-x-hatran"] = "Hatran Aramaic",
["sem-x-oldsoara"] = "Old South Arabian",
["sem-x-palmyren"] = "Palmyrene Aramaic",
["sem-x-proto"] = "Proto-Semitic",
["sem-x-taymanit"] = "Taymanitic",
["sla-x-proto"] = "Proto-Slavic", -- sla in IANA is Slavic languages
["yuf-x-hav"] = "Havasupai", -- IANA name for these three is Havasupai-Walapai-Yavapai
["yuf-x-wal"] = "Walapai",
["yuf-x-yav"] = "Yavapai",
["xsc-x-pontic"] = "Pontic Scythian", -- xsc in IANA is Scythian
["xsc-x-saka"] = "Saka",
["xsc-x-sarmat"] = "Sarmatian",
}
}


خط ۲۶۱: خط ۳۸۵:
--[[--------------------------< A R T I C L E _ L I N K >------------------------------------------------------
--[[--------------------------< A R T I C L E _ L I N K >------------------------------------------------------


for those rare occasions when article titles don't fit with the normal '<language name>-language', this table
for those rare occasions when article titles don't fit with the normal '<language name> language', this table
maps language code to article title. Use of this table should be avoided and the use of redirects preferred as
maps language code to article title. Use of this table should be avoided and the use of redirects preferred as
that is the long-standing method of handling article names that don't fit with the normal pattern
that is the long-standing method of handling article names that don't fit with the normal pattern


خط ۲۶۸: خط ۳۹۲:


local article_name = {
local article_name = {
["lij"] = {"زبان لیگوری (رومی)"}, -- Ligurian; see Template_talk:Lang#Ligurian_dab
['kue'] = "Kuman language (New Guinea)", -- Kuman (Papua New Guinea); to avoid Kuman dab page
['mnh'] = {"Mono language (Congo)"}, -- Mono (Democratic Republic of Congo); see Template_talk:Lang#Mono_languages
["lij-mc"] = "Monégasque dialect", -- Ligurian as spoken in Monaco
['mnr'] = {"Mono language (California)"}, -- Mono (USA)
['mbo'] = "Mbo language (Cameroon)", -- Mbo (Cameroon)
['mru'] = {"Mono language (Cameroon)"}, -- Mono (Cameroon)
['mnh'] = "Mono language (Congo)", -- Mono (Democratic Republic of Congo); see Template_talk:Lang#Mono_languages
["xlg"] = {"Ligurian (ancient language)"}, -- see Template_talk:Lang#Ligurian_dab
['mnr'] = "Mono language (California)", -- Mono (USA)
['mru'] = "Mono language (Cameroon)", -- Mono (Cameroon)
["snq"] = "Sangu language (Gabon)", -- Sangu (Gabon)
["toi"] = "Tonga language (Zambia and Zimbabwe)",                          -- Tonga (Zambia and Zimbabwe); to avoid Tonga language dab page
["vwa"] = "Awa language (China)", -- Awa (China); to avoid Awa dab page
["xlg"] = "Ligurian language (ancient)", -- see Template_talk:Lang#Ligurian_dab
["zmw"] = "Mbo language (Congo)", -- Mbo (Democratic Republic of Congo)
}
}


خط ۲۷۸: خط ۴۰۸:
--[=[-------------------------< R T L _ S C R I P T S >--------------------------------------------------------
--[=[-------------------------< R T L _ S C R I P T S >--------------------------------------------------------


ISO 15924 scripts that are written right-to-left. Data in this table taken from [[ISO 15924#List of codes]]
ISO 15924 scripts that are written right-to-left. Data in this table taken from [[ISO 15924#List of codes]]


last update to this list: 2017-12-24
last update to this list: 2017-12-24
خط ۲۹۲: خط ۴۲۲:




--[[--------------------------< T R A N S L I T   T I T L E S >------------------------------------------------
--[[--------------------------< T R A N S L I T _ T I T L E S >------------------------------------------------


This is a table of tables of transliteration standards and the language codes or language scripts that apply to
This is a table of tables of transliteration standards and the language codes or language scripts that apply to
those standards. This table is used to create the tool-tip text associated with the transliterated text displayed
those standards. This table is used to create the tool-tip text associated with the transliterated text displayed
by some of the {{lang-??}} templates.
by some of the {{lang-??}} templates.


These tables are more-or-less copied directly from {{transl}}. The standard 'NO_STD' is a construct to allow for
These tables are more-or-less copied directly from {{transl}}. The standard 'NO_STD' is a construct to allow for
the cases when no |std= parameter value is provided.
the cases when no |std= parameter value is provided.


خط ۳۰۵: خط ۴۳۵:
local translit_title_table = {
local translit_title_table = {
['ahl'] = {
['ahl'] = {
['default'] = 'آکادمی نویسه‌گردانی زبان عبری',
['default'] = 'Academy of the Hebrew Language transliteration',
},
},


['ala'] = {
['ala'] = {
['default'] = 'انجمن کتابخانه آمریکا نویسه‌گردانی کتابخانه کنگره',
['default'] = 'American Library Association Library of Congress transliteration',
},
},


['ala-lc'] = {
['ala-lc'] = {
['default'] = 'انجمن کتابخانه آمریکا نویسه‌گردانی کتابخانه کنگره',
['default'] = 'American Library Association Library of Congress transliteration',
},
},


['batr'] = {
['batr'] = {
['default'] = 'قوانین نویسه‌گردانی عربی بیکداش',
['default'] = 'Bikdash Arabic Transliteration Rules',
},
},


['bgn/pcgn'] = {
['bgn/pcgn'] = {
['default'] = 'هیئت نام‌های جغرافیایی / کمیته دائمی نویسه‌گردانی نام‌های جغرافیایی',
['default'] = 'Board on Geographic Names / Permanent Committee on Geographical Names transliteration',
},
},


خط ۳۳۸: خط ۴۶۸:


['eae'] = {
['eae'] = {
['default'] = 'نویسه‌گردانی دانشنامه اتیوپیکا',
['default'] = 'Encyclopaedia Aethiopica transliteration',
},
},


['hepburn'] = {
['hepburn'] = {
['default'] = 'نویسه‌گردانی هپبورن',
['default'] = 'Hepburn transliteration',
},
},


['hunterian'] = {
['hunterian'] = {
['default'] = 'نویسه‌گردانی هانتری',
['default'] = 'Hunterian transliteration',
},
},


['iast'] = {
['iast'] = {
['default'] = 'الفبای بین‌المللی نویسه‌گردانی سانسکریت',
['default'] = 'International Alphabet of Sanskrit transliteration',
},
},


خط ۳۹۲: خط ۵۲۲:
['zh'] = 'ISO 7098 Chinese',
['zh'] = 'ISO 7098 Chinese',
['chi'] = 'ISO 7098 Chinese',
['chi'] = 'ISO 7098 Chinese',
['pny'] = 'ISO 7098 Chinese',
['cmn'] = 'ISO 7098 Chinese',
['zho'] = 'ISO 7098 Chinese',
['zho'] = 'ISO 7098 Chinese',
-- ['han'] = 'ISO 7098 Chinese', -- unicode alias of Hani? doesn't belong here? should be Hani?
-- ['han'] = 'ISO 7098 Chinese', -- unicode alias of Hani? doesn't belong here? should be Hani?
خط ۴۱۹: خط ۵۴۹:
['gu'] = 'ISO 15919 Indic',
['gu'] = 'ISO 15919 Indic',
['hi'] = 'ISO 15919 Indic',
['hi'] = 'ISO 15919 Indic',
['hno'] = 'ISO 15919 Indic',
['inc'] = 'ISO 15919 Indic',
['inc'] = 'ISO 15919 Indic',
['kn'] = 'ISO 15919 Indic',
['kn'] = 'ISO 15919 Indic',
خط ۴۳۱: خط ۵۶۲:
['or'] = 'ISO 15919 Indic',
['or'] = 'ISO 15919 Indic',
['pa'] = 'ISO 15919 Indic',
['pa'] = 'ISO 15919 Indic',
['pnb'] = 'ISO 15919 Indic',
['raj'] = 'ISO 15919 Indic',
['raj'] = 'ISO 15919 Indic',
['sa'] = 'ISO 15919 Indic',
['sa'] = 'ISO 15919 Indic',
خط ۴۳۶: خط ۵۶۸:
['sd'] = 'ISO 15919 Indic',
['sd'] = 'ISO 15919 Indic',
['si'] = 'ISO 15919 Indic',
['si'] = 'ISO 15919 Indic',
['skr'] = 'ISO 15919 Indic',
['ta'] = 'ISO 15919 Indic',
['ta'] = 'ISO 15919 Indic',
['tcy'] = 'ISO 15919 Indic',
['tcy'] = 'ISO 15919 Indic',
خط ۴۵۱: خط ۵۸۴:
['telu'] = 'ISO 15919 Indic',
['telu'] = 'ISO 15919 Indic',


['default'] = 'نویسه‌گردانی ایزو',
['default'] = 'ISO transliteration',
},
},


['jyutping'] = {
['jyutping'] = {
['default'] = 'نویسه‌گردانی جیوت‌پینگ',
['default'] = 'Jyutping transliteration',
},
 
['mlcts'] = {
['default'] = 'Myanmar Language Commission Transcription System',
},
},


['mr'] = {
['mr'] = {
['default'] = 'نویسه‌گردانی مک‌کیون–ریشاور',
['default'] = 'McCune–Reischauer transliteration',
},
},


['nihon-shiki'] = {
['nihon-shiki'] = {
['default'] = 'نویسه‌گردانی نیهان-شیکی',
['default'] = 'Nihon-shiki transliteration',
},
},


خط ۴۷۰: خط ۶۰۷:
['sem'] = 'Semitic transliteration',
['sem'] = 'Semitic transliteration',
['phnx'] = 'Semitic transliteration',
['phnx'] = 'Semitic transliteration',
['xsux'] = 'نویسه‌گردانی میخی',
['xsux'] = 'Cuneiform transliteration',
},
},


['pinyin'] = {
['pinyin'] = {
['default'] = 'نویسه‌گردانی پین‌یین',
['default'] = 'Pinyin transliteration',
},
},


['rr'] = {
['rr'] = {
['default'] = 'نویسه‌گردانی لاتین‌نویسی کره‌ای اصلاح‌شده',
['default'] = 'Revised Romanization of Korean transliteration',
},
},


خط ۴۸۷: خط ۶۲۴:
['satts'] = {
['satts'] = {
['default'] = 'Standard Arabic Technical Transliteration System transliteration',
['default'] = 'Standard Arabic Technical Transliteration System transliteration',
},
['scientific'] = {
['default'] = 'scientific transliteration',
},
['ukrainian'] = {
['default'] = 'Ukrainian National system of romanization',
},
},


['ungegn'] = {
['ungegn'] = {
['default'] = 'نویسه‌گردانی گروه نام‌های جغرافیایی در سازمان ملل متحد',
['default'] = 'United Nations Group of Experts on Geographical Names transliteration',
},
},


['wadegile'] = {
['wadegile'] = {
['default'] = 'نویسه‌گردانی وید جایلز',
['default'] = 'Wade–Giles transliteration',
},
},


خط ۵۰۰: خط ۶۴۵:
['default'] = 'Hans Wehr transliteration',
['default'] = 'Hans Wehr transliteration',
},
},
['yaleko'] = {
['default'] = 'Yale romanization of Korean',
}
};
--[[--------------------------< E N G _ V A R >----------------------------------------------------------------
Used at en.wiki so that spelling of 'romanized' (US, default) can be changed to 'romanised' to match the envar
specified by a {{Use xxx English}}.
This is accomplished by setting |engvar=gb; can, should be omitted in articles that use American English; no
need for the clutter.
]]
local engvar_sel_t = { -- select either UK English or US English
['au'] = 'gb_t', -- these match IANA region codes (except in lower case)
['ca'] = 'us_t',
['gb'] = 'gb_t',
['ie'] = 'gb_t',
['in'] = 'gb_t',
['nz'] = 'gb_t',
['us'] = 'us_t', -- default engvar
['za'] = 'gb_t'
};
};


local engvar_t = {
['gb_t'] = {
['romanisz_lc'] = 'romanisation', -- lower case
['romanisz_uc'] = 'Romanisation', -- upper case
['romanisz_pt'] = 'romanised', -- past tense
},
['us_t'] = { -- default engvar
['romanisz_lc'] = 'romanization', -- lower case
['romanisz_uc'] = 'Romanization', -- upper case
['romanisz_pt'] = 'romanized', -- past tense
}
}
--[[--------------------------< E X P O R T S >----------------------------------------------------------------
]]


return
return
{
{
this_wiki_lang_tag = this_wiki_lang_tag,
this_wiki_lang_dir = lang_obj:getDir(), -- wiki's language direction
article_name = article_name,
article_name = article_name,
lang_name_table = lang_name_table,
engvar_t = engvar_t,
engvar_sel_t = engvar_sel_t,
lang_name_table = lang_name_table_t,
override = override,
override = override,
rtl_scripts = rtl_scripts,
rtl_scripts = rtl_scripts,
special_tags_table = special_tags_table,
translit_title_table = translit_title_table,
translit_title_table = translit_title_table,
};
};

نسخهٔ کنونی تا ‏۳۱ اکتبر ۲۰۲۴، ساعت ۰۵:۵۲

توضیحات این پودمان می‌تواند در پودمان:Lang/data/توضیحات قرار گیرد.

local lang_obj = mw.language.getContentLanguage();
local this_wiki_lang_tag = lang_obj.code;										-- get this wiki's language tag


--[[--------------------------< L A N G _ N A M E _ T A B L E >------------------------------------------------

primary table of tables that decode:
	lang -> language tags and names
	script -> ISO 15924 script tags
	region -> ISO 3166 region tags
	variant -> iana registered variant tags
	suppressed -> map of scripts tags and their associated language tags
	
all of these data come from separate modules that are derived from the IANA language-subtag-registry file

key_to_lower() avoids the metatable trap and sets all keys in the subtables to lowercase. Many language codes
have multiple associated names; Module:lang is only concerned with the first name so key_to_lower() only fetches
the first name.

]]

local function key_to_lower (module, src_type)
	local out = {};
	local source_t = (('var_sup' == src_type) and require (module)) or mw.loadData (module);		-- fetch data from this module; require() avoids metatable trap for variant data

	if 'var_sup' == src_type then
		for k, v in pairs (source_t) do
			out[k:lower()] = v;													-- for variant and suppressed everything is needed
		end

	elseif 'lang' == src_type and source_t.active then							-- for ~/iana_languages (active)
		for k, v in pairs (source_t.active) do
			out[k:lower()] = v[1];												-- ignore multiple names; take first name only
		end

	elseif 'lang_dep' == src_type and source_t.deprecated then					-- for ~/iana_languages (deprecated)
		for k, v in pairs (source_t.deprecated) do
			out[k:lower()] = v[1];												-- ignore multiple names; take first name only
		end

	else																		-- here for all other sources
		for k, v in pairs (source_t) do
			out[k:lower()] = v[1];												-- ignore multiple names; take first name only
		end
	end
	return out;
end

local lang_name_table_t = {
	lang = key_to_lower ('Module:Lang/data/iana languages', 'lang'),
	lang_dep = key_to_lower ('Module:Lang/data/iana languages', 'lang_dep'),
	script = key_to_lower ('Module:Lang/data/iana scripts'),					-- script keys are capitalized; set to lower
	region = key_to_lower ('Module:Lang/data/iana regions'),					-- region keys are uppercase; set to lower
	variant = key_to_lower ('Module:Lang/data/iana variants', 'var_sup'),
	suppressed = key_to_lower ('Module:Lang/data/iana suppressed scripts', 'var_sup'),	-- script keys are capitalized; set to lower
	}


--[[--------------------------< I 1 8 N   M E D I A W I K I   O V E R R I D E >--------------------------------

For internationalization; not used at en.wiki

The language names taken from the IANA language-subtag-registry file are given in English. That may not be ideal.
Translating ~8,000 language names is also not ideal.  MediaWiki maintains (much) shorter lists of language names
in most languages for which there is a Wikipedia edition.  When desired, Module:Lang can use the MediaWiki 
language list for the local language.

Caveat lector: the list of MediaWiki language names for your language may not be complete or may not exist at all.
When incomplete, MediaWiki's list will 'fall back' to another language (typically English).  When that happens
add an appropriate entry to the override table below.

Caveat lector: the list of MediaWiki language names for your language may not be correct.  At en.wiki, the
MediaWiki language names do not agree with the IANA language names for these ISO 639-1 tags.  Often it is simply
spelling differences:
	bh: IANA: Bihari languages MW: Bhojpuri – the ISO 639-3 tag for Bhojpuri is bho
	bn: IANA: Bengali MW: Bangla – Bengali is the exonym, Bangla is the endonym
	dv: IANA: Dhivehi MW: Divehi
	el: IANA: Modern Greek MW: Greek
	ht: IANA: Haitian MW: Haitian Creole
	ky: IANA: Kirghiz MW: Kyrgyz
	li: IANA: Limburgan MW: Limburgish
	or: IANA: Oriya MW: Odia
	os: IANA: Ossetian MW: Ossetic
	"pa: IANA: Panjabi MW: Punjabi
	"ps: IANA: Pushto MW: Pashto
	"to: IANA: Tonga MW: Tongan
	"ug: IANA: Uighur MW: Uyghur
use the override table to override language names that are incorrect for your project

To see the list of names that MediaWiki has for your language, enter this in the Debug colsole:
	=mw.dumpObject (mw.language.fetchLanguageNames ('<tag>', 'all'))
(replacing <tag> with the language tag for your language)

Use of the MediaWiki language names lists is enabled when media_wiki_override_enable is set to boolean true.
	
]]

local media_wiki_override_enable = false;										-- set to true to override IANA names with MediaWiki names; always false at en.wiki
																				-- caveat lector: the list of MediaWiki language names for your language may not be complete or may not exist at all
	if true == media_wiki_override_enable then
		local mw_languages_by_tag_t = mw.language.fetchLanguageNames (this_wiki_lang_tag, 'all');	-- get a table of language tag/name pairs known to MediaWiki
		for tag, name in pairs (mw_languages_by_tag_t) do						-- loop through each tag/name pair in the MediaWiki list
			if lang_name_table_t.lang[tag] then									-- if the tag is in the main list
				lang_name_table_t.lang[tag] = name;								-- overwrite exisiting name with the name from MediaWiki
			end
		end
	end


--[[--------------------------< O V E R R I D E >--------------------------------------------------------------

Language codes and names in this table override the BCP47 names in lang_name_table.

indexes in this table shall always be lower case

]]

local override = {
------------------------------< I S O _ 6 3 9 - 1 >------------------------------------------------------------

	["ab"] = "Abkhaz",                                                          -- to match en.wiki article name
	["ca-valencia"] = "Valencian",
	["cu"] = "Church Slavonic",													-- 2nd IANA name;
	["de-at"] = "Austrian German",												-- these code-region and code-variant tags to match en.wiki article names
	["de-ch"] = "Swiss Standard German",
	["en-au"] = "Australian English",
	["en-ca"] = "Canadian English",
	["en-emodeng"] = "Early Modern English",
	["en-gb"] = "British English",
	["en-ie"] = "Irish English",
	["en-in"] = "Indian English",
	["en-nz"] = "New Zealand English",
	["en-us"] = "American English",
	["en-za"] = "South African English",
	["fr-ca"] = "Quebec French",
	["fr-gallo"] = "Gallo",
	["fy"] = "West Frisian",													-- Western Frisian
	["mo"] = "Moldovan",														-- Moldavian (deprecated code); to match en.wiki article title
	["nl-be"] = "Flemish",														-- match MediaWiki
	["oc-gascon"] = "Gascon",
	["oc-provenc"] = "Provençal",
	["ps"] = "Pashto",															-- Pushto
	["pt-br"] = "Brazilian Portuguese",											-- match MediaWiki
	["ro-md"] = "Moldovan",														-- 'not deprecated' form
	["ro-cyrl-md"] = "Moldovan",												-- 'not deprecated' form
	["tw-asante"] = "Asante Twi",
	["ug"] = "Uyghur",															-- 2nd IANA name; to match en.wiki article name

-- these ISO 639-1 language-name overrides imported from Module:Language/data/wp_languages (since deleted)
--<begin do-not-edit except to comment out>--
		["av"] = "Avar",														-- Avaric
		["bo"] = "Standard Tibetan",											-- Tibetan
		["el"] = "Greek",														-- Modern Greek
--		["en-SA"] = "South African English",									-- English; no; SA is not South Africa it Saudi Arabia; ZA is South Africa
		["ff"] = "Fula",														-- Fulah
		["ht"] = "Haitian Creole",												-- Haitian
		["hz"] = "Otjiherero",													-- Herero
		["ii"] = "Yi",															-- Sichuan Yi
		["ki"] = "Gikuyu",														-- Kikuyu
		["kl"] = "Greenlandic",													-- Kalaallisut
		["ky"] = "Kyrgyz",														-- Kirghiz
		["lg"] = "Luganda",														-- Ganda
		["li"] = "Limburgish",													-- Limburgan
		["mi"] = "Māori",														-- Maori
		["na"] = "Nauruan",														-- Nauru
		["nb"] = "Bokmål",														-- Norwegian Bokmål
		["nd"] = "Northern Ndebele",											-- North Ndebele
		["nn"] = "Nynorsk",														-- Norwegian Nynorsk
		["nr"] = "Southern Ndebele",											-- South Ndebele
		["ny"] = "Chichewa",													-- Nyanja
		["oj"] = "Ojibwe",														-- Ojibwa
		["or"] = "Odia",														-- Oriya
		["pa"] = "Punjabi",														-- Panjabi
		["rn"] = "Kirundi",														-- Rundi
		["sl"] = "Slovene",														-- Slovenian
		["ss"] = "Swazi",														-- Swati
		["st"] = "Sotho",														-- Southern Sotho
		["to"] = "Tongan",														-- Tonga
--<end do-not-edit except to comment out>--


------------------------------< I S O _ 6 3 9 - 2,   - 3,   - 5 >----------------------------------------------

	["alv"] = "Atlantic–Congo languages",										-- to match en.wiki article title (endash)
	["arc"] = "Imperial Aramaic (700-300 BCE)",									-- Official Aramaic (700-300 BCE), Imperial Aramaic (700-300 BCE); to match en.wiki article title uses ISO639-2 'preferred' name
	["art"] = "constructed",													-- to match en.wiki article; lowercase for category name
	["bea"] = "Dane-zaa",														-- Beaver; to match en.wiki article title
	["bhd"] = "Bhadarwahi",														-- Bhadrawahi; to match en.wiki article title
	["bla"] = "Blackfoot",														-- Siksika; to match en.wiki article title
	["blc"] = "Nuxalk",															-- Bella Coola; to match en.wiki article title
	["bua"] = "Buryat",															-- Buriat; this is a macro language; these four use wp preferred transliteration;
	["bxm"] = "Mongolian Buryat",												-- Mongolia Buriat; these three all redirect to Buryat
	["bxr"] = "Russian Buryat",													-- Russia Buriat;
	["bxu"] = "Chinese Buryat",													-- China Buriat;
	["byr"] = "Yipma",															-- Baruya, Yipma
	["clm"] = "Klallam",														-- Clallam; to match en.wiki article title
	["egy"] = "Ancient Egyptian",												-- Egyptian (Ancient); distinguish from contemporary arz: Egyptian Arabic 
	["ems"] = "Alutiiq",														-- Pacific Gulf Yupik; to match en.wiki article title
	["esx"] = "Eskimo–Aleut languages",											-- to match en.wiki article title (endash)
	["frr"] = "North Frisian",													-- Northern Frisian
	["frs"] = "East Frisian Low Saxon",											-- Eastern Frisian
	["gsw-fr"] = "Alsatian",													-- match MediaWiki
	["haa"] = "Hän",															-- Han; to match en.wiki article title
	["hei"] = "Heiltsuk–Oowekyala",												-- Heiltsuk; to match en.wiki article title
	["hmx"] = "Hmong–Mien languages",											-- to match en.wiki article title (endash)
	["ilo"] = "Ilocano",														-- Iloko; to match en.wiki article title
	["jam"] = "Jamaican Patois",												-- Jamaican Creole English
	["lij-mc"] = "Monégasque",													-- Ligurian as spoken in Monaco; this one for proper tool tip; also in <article_name> table
	["luo"] = "Dholuo",															-- IANA (primary) /ISO 639-3: Luo (Kenya and Tanzania); IANA (secondary): Dholuo
	["mhr"] = "Meadow Mari",													-- Eastern Mari
	["mid"] = "Modern Mandaic",													-- Mandaic
	['mis'] = "uncoded",														-- Uncoded languages; capitalization; special scope, not collective scope;
	["mkh"] = "Mon–Khmer languages",											-- to match en.wiki article title (endash)
	["mla"] = "Tamambo",														-- Malo
	['mte'] = "Mono-Alu",														-- Mono (Solomon Islands)
	['mul'] = "multiple",														-- Multiple languages; capitalization; special scope, not collective scope;
	["nan-tw"] = "Taiwanese Hokkien",											-- make room for IANA / 639-3 nan Min Nan Chinese; match en.wiki article title
	["new"] = "Newar",															-- Newari, Nepal Bhasa; to match en,wiki article title
	["ngf"] = "Trans–New Guinea languages",										-- to match en.wiki article title (endash)
	["nic"] = "Niger–Congo languages",											-- Niger-Kordofanian languages; to match en,wiki article title
	["nrf"] = "Norman",															-- not quite a collective - IANA name: Jèrriais + Guernésiais; categorizes to Norman-language text
	["nrf-gg"] = "Guernésiais",													-- match MediaWiki
	["nrf-je"] = "Jèrriais",													-- match MediaWiki
	["nzi"] = "Nzema",															-- Nzima; to match en.wiki article title
	["oma"] = "Omaha–Ponca",													-- to match en.wiki article title (endash)
	["orv"] = "Old East Slavic",												-- Old Russian
	["pfl"] = "Palatine German",												-- Pfaelzisch; to match en.wiki article
	["pie"] = "Piro Pueblo",													-- Piro; to match en.wiki article
	["pms"] = "Piedmontese",													-- Piemontese; to match en.wiki article title
	["pnb"] = "Punjabi (Western)",												-- Western Panjabi; dab added to override import from ~/wp languages and distinguish pnb from pa in reverse look up tag_from_name()
	['qwm'] = "Cuman",															-- Kuman (Russia); to match en.wiki article name
	["rop"] = "Australian Kriol",												-- Kriol; en.wiki article is a dab; point to correct en.wiki article
	["sco-ulster"] = "Ulster Scots",
	["sdo"] = "Bukar–Sadong",													-- Bukar-Sadung Bidayuh; to match en.wiki article title
	["smp"] = "Samaritan Hebrew",												-- to match en.wiki article title
	["stq"] = "Saterland Frisian",												-- Saterfriesisch
	["und"] = "undetermined",													-- capitalization to match existing category
	["wrg"] = "Warrongo",														-- Warungu
	["xal-ru"] = "Kalmyk",														-- to match en.wiki article title
	["xgf"] = "Tongva",															-- ISO 639-3 is Gabrielino-Fernandeño
	["yuf"] = "Havasupai–Hualapai",												-- Havasupai-Walapai-Yavapai; to match en.wiki article title
	["zxx"] = "no linguistic content",											-- capitalization

-- these ISO 639-2, -3 language-name overrides imported from Module:Language/data/wp_languages (since deleted)
--<begin do-not-edit except to comment out>--
		["ace"] = "Acehnese",													-- Achinese
		["aec"] = "Sa'idi Arabic",												-- Saidi Arabic
		["akl"] = "Aklan",														-- Aklanon
		["alt"] = "Altay",														-- Southern Altai
		["apm"] = "Mescalero-Chiricahua",										-- Mescalero-Chiricahua Apache
		["bal"] = "Balochi",													-- Baluchi
--		["bcl"] = "Central Bicolano",											-- Central Bikol
		["bin"] = "Edo",														-- Bini
		["bpy"] = "Bishnupriya Manipuri",										-- Bishnupriya
		["chg"] = "Chagatay",													-- Chagatai
		["ckb"] = "Sorani Kurdish",												-- Central Kurdish
		["cnu"] = "Shenwa",														-- Chenoua
		["coc"] = "Cocopah",													-- Cocopa
		["diq"] = "Zazaki",														-- Dimli
		["fit"] = "Meänkieli",													-- Tornedalen Finnish
		["fkv"] = "Kven",														-- Kven Finnish
		["frk"] = "Old Frankish",												-- Frankish
		["gez"] = "Ge'ez",														-- Geez
		["gju"] = "Gujari",														-- Gujari
		["gsw"] = "Alemannic German",											-- Swiss German
		["gul"] = "Gullah",														-- Sea Island Creole English
		["hak"] = "Hakka",														-- Hakka Chinese
		["hbo"] = "Biblical Hebrew",											-- Ancient Hebrew
		["hnd"] = "Hindko",														-- Southern Hindko
--		["ikt"] = "Inuvialuk",													-- Inuinnaqtun
		["kaa"] = "Karakalpak",													-- Kara-Kalpak
		["khb"] = "Tai Lü",														-- Lü
		["kmr"] = "Kurmanji Kurdish",											-- Northern Kurdish
		["kpo"] = "Kposo",														-- Ikposo
		["krj"] = "Kinaray-a",													-- Kinaray-A
--		["ktz"] = "Juǀ'hoan",													-- Juǀʼhoan
		["lez"] = "Lezgian",													-- Lezghian
		["liv"] = "Livonian",													-- Liv
		["lng"] = "Lombardic",													-- Langobardic
		["mia"] = "Miami-Illinois",												-- Miami
		["miq"] = "Miskito",													-- Mískito
		["mix"] = "Mixtec",														-- Mixtepec Mixtec
		["mni"] = "Meitei",														-- Manipuri
		["mrj"] = "Hill Mari",													-- Western Mari
		["mww"] = "White Hmong",												-- Hmong Daw
		["nds-nl"] = "Dutch Low Saxon",											-- Low German
--		["new"] = "Nepal Bhasa",												-- Newari
		["nso"] = "Northern Sotho",												-- Pedi
--		["nwc"] = "Classical Nepal Bhasa",										-- Classical Newari, Classical Nepal Bhasa, Old Newari
		["ood"] = "O'odham",													-- Tohono O'odham
		["otk"] = "Old Turkic",													-- Old Turkish
		["pal"] = "Middle Persian",												-- Pahlavi
		["pam"] = "Kapampangan",												-- Pampanga
		["phr"] = "Potwari",													-- Pahari-Potwari
		["pka"] = "Jain Prakrit",												-- Ardhamāgadhī Prākrit
--		["pnb"] = "Punjabi",													-- Western Panjabi
		["psu"] = "Shauraseni",													-- Sauraseni Prākrit
		["rap"] = "Rapa Nui",													-- Rapanui
		["rar"] = "Cook Islands Māori",											-- Rarotongan
		["rmu"] = "Scandoromani",												-- Tavringer Romani
		["rom"] = "Romani",														-- Romany
		["rup"] = "Aromanian",													-- Macedo-Romanian
		["ryu"] = "Okinawan",													-- Central Okinawan
		["sdc"] = "Sassarese",													-- Sassarese Sardinian
		["sdn"] = "Gallurese",													-- Gallurese Sardinian
		["shp"] = "Shipibo",													-- Shipibo-Conibo
		["src"] = "Logudorese",													-- Logudorese Sardinian
		["sro"] = "Campidanese",												-- Campidanese Sardinian
		["tkl"] = "Tokelauan",													-- Tokelau
		["tvl"] = "Tuvaluan",													-- Tuvalu
		["tyv"] = "Tuvan",														-- Tuvinian
		["vls"] = "West Flemish",												-- Vlaams
		["wep"] = "Westphalian",												-- Westphalien
		["xal"] = "Oirat",														-- Kalmyk
		["xcl"] = "Old Armenian",												-- Classical Armenian
		["yua"] = "Yucatec Maya",												-- Yucateco
--<end do-not-edit except to comment out>--


------------------------------< P R I V A T E _ U S E _ T A G S >----------------------------------------------

	["akk-x-latbabyl"] = "Late Babylonian Akkadian",
	["akk-x-midassyr"] = "Middle Assyrian Akkadian",
	["akk-x-midbabyl"] = "Middle Babylonian Akkadian",
	["akk-x-neoassyr"] = "Neo-Assyrian Akkadian",
	["akk-x-neobabyl"] = "Neo-Babylonian Akkadian",
	["akk-x-old"] = "Old Akkadian",
	["akk-x-oldassyr"] = "Old Assyrian Akkadian",
	["akk-x-oldbabyl"] = "Old Babylonian Akkadian",
	["alg-x-proto"] = "Proto-Algonquian",										-- alg in IANA is Algonquian languages
	["ca-x-old"] = "Old Catalan",
	["cel-x-combrit"] = "Common Brittonic",										-- cel in IANA is Celtic languages
	["cel-x-proto"] = "Proto-Celtic",
	["egy-x-demotic"] = "Demotic Egyptian",
	["egy-x-late"] = "Late Egyptian",
	["egy-x-middle"] = "Middle Egyptian",
	["egy-x-old"] = "Old Egyptian",
	["gem-x-proto"] = "Proto-Germanic",											-- gem in IANA is Germanic languages
	["gmw-x-ecg"] = "East Central German",
	["grc-x-aeolic"] = "Aeolic Greek",											-- these grc-x-... codes are preferred alternates to the non-standard catchall code grc-gre
	["grc-x-attic"] = "Attic Greek",
	["grc-x-biblical"] = "Biblical Greek",
	["grc-x-byzant"] = "Byzantine Greek",
	["grc-x-classic"] = "Classical Greek",
	["grc-x-doric"] = "Doric Greek",
	["grc-x-hellen"] = "Hellenistic Greek",
	["grc-x-ionic"] = "Ionic Greek",
	["grc-x-koine"] = "Koinē Greek",
	["grc-x-medieval"] = "Medieval Greek",
	["grc-x-patris"] = "Patristic Greek",
	["grk-x-proto"] = "Proto-Greek",											-- grk in IANA is Greek languages
	["iir-x-proto"] = "Proto-Indo-Iranian",										-- iir in IANA is Indo-Iranian Languages
	["inc-x-mitanni"] = "Mitanni-Aryan",										-- inc in IANA is Indic languages
	["inc-x-proto"] = "Proto-Indo-Aryan",
	["ine-x-anatolia"] = "Anatolian languages",
	["ine-x-proto"] = "Proto-Indo-European",
	["ira-x-proto"] = "Proto-Iranian",											-- ira in IANA is Iranian languages
	["itc-x-proto"] = "Proto-Italic",											-- itc in IANA is Italic languages
	["ksh-x-colog"] = "Colognian",												-- en.wiki article is Colognian; ksh (Kölsch) redirects there
	["la-x-medieval"] = "Medieval Latin",
	["la-x-new"] = "New Latin",
	["lmo-x-milanese"] = "Milanese",											-- lmo in IANA is Lombard; Milanese is a dialect
	["mis-x-ripuar"] = "Ripuarian",												-- replaces improper use of ksh in wp_languages
	["prg-x-old"] = "Old Prussian",
	["sem-x-ammonite"] = "Ammonite",
	["sem-x-aramaic"] = "Aramaic",
	["sem-x-canaan"] = "Canaanite languages",
	["sem-x-dumaitic"] = "Dumaitic",
	["sem-x-egurage"] = "Eastern Gurage",
	["sem-x-hatran"] = "Hatran Aramaic",
	["sem-x-oldsoara"] = "Old South Arabian",
	["sem-x-palmyren"] = "Palmyrene Aramaic",
	["sem-x-proto"] = "Proto-Semitic",
	["sem-x-taymanit"] = "Taymanitic",
	["sla-x-proto"] = "Proto-Slavic",											-- sla in IANA is Slavic languages
	["yuf-x-hav"] = "Havasupai",												-- IANA name for these three is Havasupai-Walapai-Yavapai
	["yuf-x-wal"] = "Walapai",
	["yuf-x-yav"] = "Yavapai",
	["xsc-x-pontic"] = "Pontic Scythian",										-- xsc in IANA is Scythian
	["xsc-x-saka"] = "Saka",
	["xsc-x-sarmat"] = "Sarmatian",
	}


--[[--------------------------< A R T I C L E _ L I N K >------------------------------------------------------

for those rare occasions when article titles don't fit with the normal '<language name> language', this table
maps language code to article title. Use of this table should be avoided and the use of redirects preferred as
that is the long-standing method of handling article names that don't fit with the normal pattern

]]

local article_name = {
	['kue'] = "Kuman language (New Guinea)",									-- Kuman (Papua New Guinea); to avoid Kuman dab page
	["lij-mc"] = "Monégasque dialect",											-- Ligurian as spoken in Monaco
	['mbo'] = "Mbo language (Cameroon)",										-- Mbo (Cameroon)
	['mnh'] = "Mono language (Congo)",											-- Mono (Democratic Republic of Congo); see Template_talk:Lang#Mono_languages
	['mnr'] = "Mono language (California)",										-- Mono (USA)
	['mru'] = "Mono language (Cameroon)",										-- Mono (Cameroon)
	["snq"] = "Sangu language (Gabon)",											-- Sangu (Gabon)
	["toi"] = "Tonga language (Zambia and Zimbabwe)",                           -- Tonga (Zambia and Zimbabwe); to avoid Tonga language dab page
	["vwa"] = "Awa language (China)",											-- Awa (China); to avoid Awa dab page
	["xlg"] = "Ligurian language (ancient)",									-- see Template_talk:Lang#Ligurian_dab
	["zmw"] = "Mbo language (Congo)",											-- Mbo (Democratic Republic of Congo)
	}


--[=[-------------------------< R T L _ S C R I P T S >--------------------------------------------------------

ISO 15924 scripts that are written right-to-left. Data in this table taken from [[ISO 15924#List of codes]]

last update to this list: 2017-12-24

]=]

local rtl_scripts = {
	'adlm', 'arab', 'aran', 'armi', 'avst', 'cprt', 'egyd', 'egyh', 'hatr', 'hebr',
	'hung', 'inds', 'khar', 'lydi', 'mand', 'mani', 'mend', 'merc', 'mero', 'narb',
	'nbat', 'nkoo', 'orkh', 'palm', 'phli', 'phlp', 'phlv', 'phnx', 'prti', 'rohg',
	'samr', 'sarb', 'sogd', 'sogo', 'syrc', 'syre', 'syrj', 'syrn', 'thaa', 'wole',
	};


--[[--------------------------< T R A N S L I T _ T I T L E S >------------------------------------------------

This is a table of tables of transliteration standards and the language codes or language scripts that apply to
those standards. This table is used to create the tool-tip text associated with the transliterated text displayed
by some of the {{lang-??}} templates.

These tables are more-or-less copied directly from {{transl}}. The standard 'NO_STD' is a construct to allow for
the cases when no |std= parameter value is provided.

]]

local translit_title_table = {
	['ahl'] = {
		['default'] = 'Academy of the Hebrew Language transliteration',
		},

	['ala'] = {
		['default'] = 'American Library Association – Library of Congress transliteration',
		},

	['ala-lc'] = {
		['default'] = 'American Library Association – Library of Congress transliteration',
		},

	['batr'] = {
		['default'] = 'Bikdash Arabic Transliteration Rules',
		},

	['bgn/pcgn'] = {
		['default'] = 'Board on Geographic Names / Permanent Committee on Geographical Names transliteration',
		},

	['din'] = {
		['ar'] = 'DIN 31635 Arabic',
		['fa'] = 'DIN 31635 Arabic',
		['ku'] = 'DIN 31635 Arabic',
		['ps'] = 'DIN 31635 Arabic',
		['tg'] = 'DIN 31635 Arabic',
		['ug'] = 'DIN 31635 Arabic',
		['ur'] = 'DIN 31635 Arabic',
		['arab'] = 'DIN 31635 Arabic',

		['default'] = 'DIN transliteration',
		},

	['eae'] = {
		['default'] = 'Encyclopaedia Aethiopica transliteration',
		},

	['hepburn'] = {
		['default'] = 'Hepburn transliteration',
		},

	['hunterian'] = {
		['default'] = 'Hunterian transliteration',
		},

	['iast'] = {
		['default'] = 'International Alphabet of Sanskrit transliteration',
		},

	['iso'] = {																	-- when a transliteration standard is supplied
		['ab'] = 'ISO 9 Cyrillic',
		['ba'] = 'ISO 9 Cyrillic',
		['be'] = 'ISO 9 Cyrillic',
		['bg'] = 'ISO 9 Cyrillic',
		['kk'] = 'ISO 9 Cyrillic',
		['ky'] = 'ISO 9 Cyrillic',
		['mn'] = 'ISO 9 Cyrillic',
		['ru'] = 'ISO 9 Cyrillic',
		['tg'] = 'ISO 9 Cyrillic',
		['uk'] = 'ISO 9 Cyrillic',
		['bua'] = 'ISO 9 Cyrillic',
		['sah'] = 'ISO 9 Cyrillic',
		['tut'] = 'ISO 9 Cyrillic',
		['xal'] = 'ISO 9 Cyrillic',
		['cyrl'] = 'ISO 9 Cyrillic',

		['ar'] = 'ISO 233 Arabic',
		['ku'] = 'ISO 233 Arabic',
		['ps'] = 'ISO 233 Arabic',
		['ug'] = 'ISO 233 Arabic',
		['ur'] = 'ISO 233 Arabic',
		['arab'] = 'ISO 233 Arabic',

		['he'] = 'ISO 259 Hebrew',
		['yi'] = 'ISO 259 Hebrew',
		['hebr'] = 'ISO 259 Hebrew',

		['el'] = 'ISO 843 Greek',
		['grc'] = 'ISO 843 Greek',

		['ja'] = 'ISO 3602 Japanese',
		['hira'] = 'ISO 3602 Japanese',
		['hrkt'] = 'ISO 3602 Japanese',
		['jpan'] = 'ISO 3602 Japanese',
		['kana'] = 'ISO 3602 Japanese',

		['zh'] = 'ISO 7098 Chinese',
		['chi'] = 'ISO 7098 Chinese',
		['cmn'] = 'ISO 7098 Chinese',
		['zho'] = 'ISO 7098 Chinese',
--		['han'] = 'ISO 7098 Chinese',											-- unicode alias of Hani? doesn't belong here? should be Hani?
		['hans'] = 'ISO 7098 Chinese',
		['hant'] = 'ISO 7098 Chinese',

		['ka'] = 'ISO 9984 Georgian',
		['kat'] = 'ISO 9984 Georgian',

		['arm'] = 'ISO 9985 Armenian',
		['hy'] = 'ISO 9985 Armenian',

		['th'] = 'ISO 11940 Thai',
		['tha'] = 'ISO 11940 Thai',

		['ko'] = 'ISO 11941 Korean',
		['kor'] = 'ISO 11941 Korean',

		['awa'] = 'ISO 15919 Indic',
		['bho'] = 'ISO 15919 Indic',
		['bn'] = 'ISO 15919 Indic',
		['bra'] = 'ISO 15919 Indic',
		['doi'] = 'ISO 15919 Indic',
		['dra'] = 'ISO 15919 Indic',
		['gon'] = 'ISO 15919 Indic',
		['gu'] = 'ISO 15919 Indic',
		['hi'] = 'ISO 15919 Indic',
		['hno'] = 'ISO 15919 Indic',
		['inc'] = 'ISO 15919 Indic',
		['kn'] = 'ISO 15919 Indic',
		['kok'] = 'ISO 15919 Indic',
		['ks'] = 'ISO 15919 Indic',
		['mag'] = 'ISO 15919 Indic',
		['mai'] = 'ISO 15919 Indic',
		['ml'] = 'ISO 15919 Indic',
		['mr'] = 'ISO 15919 Indic',
		['ne'] = 'ISO 15919 Indic',
		['new'] = 'ISO 15919 Indic',
		['or'] = 'ISO 15919 Indic',
		['pa'] = 'ISO 15919 Indic',
		['pnb'] = 'ISO 15919 Indic',
		['raj'] = 'ISO 15919 Indic',
		['sa'] = 'ISO 15919 Indic',
		['sat'] = 'ISO 15919 Indic',
		['sd'] = 'ISO 15919 Indic',
		['si'] = 'ISO 15919 Indic',
		['skr'] = 'ISO 15919 Indic',
		['ta'] = 'ISO 15919 Indic',
		['tcy'] = 'ISO 15919 Indic',
		['te'] = 'ISO 15919 Indic',
		['beng'] = 'ISO 15919 Indic',
		['brah'] = 'ISO 15919 Indic',
		['deva'] = 'ISO 15919 Indic',
		['gujr'] = 'ISO 15919 Indic',
		['guru'] = 'ISO 15919 Indic',
		['knda'] = 'ISO 15919 Indic',
		['mlym'] = 'ISO 15919 Indic',
		['orya'] = 'ISO 15919 Indic',
		['sinh'] = 'ISO 15919 Indic',
		['taml'] = 'ISO 15919 Indic',
		['telu'] = 'ISO 15919 Indic',

		['default'] = 'ISO transliteration',
		},

	['jyutping'] = {
		['default'] = 'Jyutping transliteration',
		},

	['mlcts'] = {
		['default'] = 'Myanmar Language Commission Transcription System',
		},

	['mr'] = {
		['default'] = 'McCune–Reischauer transliteration',
		},

	['nihon-shiki'] = {
		['default'] = 'Nihon-shiki transliteration',
		},

	['no_std'] = {																-- when no transliteration standard is supplied
		['akk'] = 'Semitic transliteration',
		['sem'] = 'Semitic transliteration',
		['phnx'] = 'Semitic transliteration',
		['xsux'] = 'Cuneiform transliteration',
		},

	['pinyin'] = {
		['default'] = 'Pinyin transliteration',
		},

	['rr'] = {
		['default'] = 'Revised Romanization of Korean transliteration',
		},

	['rtgs'] = {
		['default'] = 'Royal Thai General System of Transcription',
		},
	
	['satts'] = {
		['default'] = 'Standard Arabic Technical Transliteration System transliteration',
		},

	['scientific'] = {
		['default'] = 'scientific transliteration',
		},

	['ukrainian'] = {
		['default'] = 'Ukrainian National system of romanization',
		},

	['ungegn'] = {
		['default'] = 'United Nations Group of Experts on Geographical Names transliteration',
		},

	['wadegile'] = {
		['default'] = 'Wade–Giles transliteration',
		},

	['wehr'] = {
		['default'] = 'Hans Wehr transliteration',
		},
	['yaleko'] = {
		['default'] = 'Yale romanization of Korean',
	}
};


--[[--------------------------< E N G _ V A R >----------------------------------------------------------------

Used at en.wiki so that spelling of 'romanized' (US, default) can be changed to 'romanised' to match the envar
specified by a {{Use xxx English}}.

This is accomplished by setting |engvar=gb; can, should be omitted in articles that use American English; no
need for the clutter.

]]

local engvar_sel_t = {															-- select either UK English or US English
	['au'] = 'gb_t',															-- these match IANA region codes (except in lower case)
	['ca'] = 'us_t',
	['gb'] = 'gb_t',
	['ie'] = 'gb_t',
	['in'] = 'gb_t',
	['nz'] = 'gb_t',
	['us'] = 'us_t',															-- default engvar
	['za'] = 'gb_t'
	};

local engvar_t = {
	['gb_t'] = {
		['romanisz_lc'] = 'romanisation',										-- lower case
		['romanisz_uc'] = 'Romanisation',										-- upper case
		['romanisz_pt'] = 'romanised',											-- past tense
		},
	['us_t'] = {																-- default engvar
		['romanisz_lc'] = 'romanization',										-- lower case
		['romanisz_uc'] = 'Romanization',										-- upper case
		['romanisz_pt'] = 'romanized',											-- past tense
		}
	}


--[[--------------------------< E X P O R T S >----------------------------------------------------------------
]]

return
	{
	this_wiki_lang_tag = this_wiki_lang_tag,
	this_wiki_lang_dir = lang_obj:getDir(),										-- wiki's language direction
	
	article_name = article_name,
	engvar_t = engvar_t,
	engvar_sel_t = engvar_sel_t,
	lang_name_table = lang_name_table_t,
	override = override,
	rtl_scripts = rtl_scripts,
	special_tags_table = special_tags_table,
	translit_title_table = translit_title_table,
	};