Diqqət! 4 aprel 2024-cü il tarixdən saytın yeni versiyası sheki.org domenində fəaliyyət göstərir. Bu köhnə versiyadır və yenilənməsi məhdudlaşdırılıb.

Changes

Jump to navigation Jump to search
45.300 bayt çıxarıldı ,  17:00, 15 noyabr 2020
Nəzərə çarpan dəyişiklik yoxdur.
Sətir 1: Sətir 1: −
--[=[
+
local Langue = { }
   −
Lua support for the {{lang}}, {{lang-xx}}, and {{transl}} templates and replacement of various supporting templates.  
+
local dataLangue = mw.loadData 'Module:Dil/Data'
 +
local langErrorMess = '<span class="error">langue non reconnue : %s</span>'
   −
]=]
+
-- premierParametre renvoie le premier paramètre de Frame, que celui-ci ait été passé au module par invoke, directement au modèle,
 
+
-- ou à l'intérieur d'un module sous forme de string dans un tableau ou directement de string.
require('Module:No globals');
+
-- Si aucun de ces arguments ne contient de chaine, la fonction renvoie nil.
 
+
-- Si le deuxième paramètre est true, la chaine est renvoyée trimée et en minuscules.
local getArgs = require ('Module:Arguments').getArgs;
+
local function premierParametre( frame, lowerCase )
local unicode = require ("Module:Unicode data"); -- for is_latin() and is_rtl()
+
local arg
local yesno = require ('Module:Yesno');
+
if type( frame ) == 'table' then
 
+
arg = ( frame.getParent and ( frame.args[1] or frame:getParent().args[1] ) ) or frame[1]
local lang_data =  mw.loadData ('Module:Lang/data'); -- language name override and transliteration tool-tip tables
+
elseif type( frame ) == 'string' then
local lang_name_table = lang_data.lang_name_table; -- language codes, names, regions, scripts, suppressed scripts
+
arg = frame
local lang_table = lang_data.lang_name_table.lang;
  −
local lang_dep_table = lang_data.lang_name_table.lang_dep;
  −
local script_table = lang_data.lang_name_table.script;
  −
local region_table = lang_data.lang_name_table.region;
  −
local variant_table = lang_data.lang_name_table.variant;
  −
local suppressed_table = lang_data.lang_name_table.suppressed;
  −
local override_table = lang_data.override;
  −
 
  −
local synonym_table = mw.loadData ('Module:Lang/ISO 639 synonyms'); -- ISO 639-2/639-2T code translation to 639-1 code
  −
 
  −
local namespace = mw.title.getCurrentTitle().namespace; -- used for categorization
  −
 
  −
local this_wiki_lang = mw.language.getContentLanguage().code; -- get this wiki's language
  −
 
  −
local initial_style_state; -- set by lang_xx_normal() and lang_xx_italic()
  −
 
  −
local maint_cats = {}; -- maintenance categories go here
  −
local maint_msgs = {}; -- and their messages go here
  −
 
  −
 
  −
--[[--------------------------< I S _ S E T >------------------------------------------------------------------
  −
 
  −
Returns true if argument is set; false otherwise. Argument is 'set' when it exists (not nil) or when it is not an empty string.
  −
 
  −
]]
  −
 
  −
local function is_set( var )
  −
return not (var == nil or var == '');
  −
end
  −
 
  −
 
  −
--[[--------------------------< I N V E R T  _ I T A L I C S >-------------------------------------------------
  −
 
  −
This function attempts to invert the italic markup a args.text by adding/removing leading/trailing italic markup
  −
in args.text.  Like |italic=unset, |italic=invert disables automatic italic markup. Individual leading/trailing
  −
apostrophes are converted to their html numeric entity equivalent so that the new italic markup doesn't become
  −
bold markup inadvertently.
  −
 
  −
Leading and trailing wiki markup is extracted from args.text into separate table elements.  Addition, removal,
  −
replacement of wiki markup is handled by a string.gsub() replacement table operating only on these separate elements.
  −
In the string.gsub() matching pattern, '.*' matches empty string as well as the three expected wiki markup patterns.
  −
 
  −
This function expects that markup in args.text is complete and correct; if it is not, oddness may result.
  −
 
  −
]]
  −
 
  −
local function invert_italics (source)
  −
local invert_pattern_table = { -- leading/trailing markup add/remove/replace patterns
  −
[""]="\'\'", -- empty string becomes italic markup
  −
["\'\'"]="", -- italic markup becomes empty string
  −
["\'\'\'"]="\'\'\'\'\'", -- bold becomes bold italic
  −
["\'\'\'\'\'"]="\'\'\'", -- bold italic become bold
  −
};
  −
local seg = {};
  −
 
  −
source = source:gsub ("%f[\']\'%f[^\']", '&#39;'); -- protect single quote marks from being interpreted as bold markup
  −
 
  −
seg[1] = source:match ('^(\'\'+%f[^\']).+') or ''; -- get leading markup, if any; ignore single quote
  −
seg[3] = source:match ('.+(%f[\']\'\'+)$') or ''; -- get trailing markup, if any; ignore single quote
  −
 
  −
if '' ~= seg[1] and '' ~= seg[3] then -- extract the 'text'
  −
seg[2] = source:match ('^\'\'+%f[^\'](.+)%f[\']\'\'+$') -- from between leading and trailing markup
  −
elseif '' ~= seg[1] then
  −
seg[2] = source:match ('^\'\'+%f[^\'](.+)') -- following leading markup
  −
elseif '' ~= seg[3] then
  −
seg[2] = source:match ('(.+)%f[\']\'\'+$') -- preceding trailing markup
  −
else
  −
seg[2] = source -- when there is no markup
   
end
 
end
 
+
if type( arg ) ~= 'string' then
seg[1] = invert_pattern_table[seg[1]] or seg[1]; -- replace leading markup according to pattern table
+
arg = nil
seg[3] = invert_pattern_table[seg[3]] or seg[3]; -- replace leading markup according to pattern table
  −
 
  −
return table.concat (seg); -- put it all back together and done
  −
end
  −
 
  −
 
  −
--[[--------------------------< V A L I D A T E _ I T A L I C >------------------------------------------------
  −
 
  −
validates |italic= or |italics= assigned values.
  −
 
  −
When |italic= is set and has an acceptible assigned value, return the matching css font-style property value or,
  −
for the special case 'default', return nil.
  −
 
  −
When |italic= is not set, or has an unacceptible assigned value, return nil and a nil error message.
  −
 
  −
When both |italic= and |italics= are set, returns nil and a 'conflicting' error message.
  −
 
  −
The return value nil causes the calling lang, lang_xx, or transl function to set args.italic according to the template's
  −
defined default ('inherit' for {{lang}}, 'inherit' or 'italic' for {{lang-xx}} depending on
  −
the individual template's requirements, 'italic' for {{transl}}) or to the value appropriate to |script=, if set ({{lang}}
  −
and {{lang-xx}} only).
  −
 
  −
Accepted values and the values that this function returns are are:
  −
nil - when |italic= absent or not set; returns nil
  −
default - for completeness, should rarely if ever be used; returns nil
  −
yes - force args.text to be rendered in italic font; returns 'italic'
  −
no - force args.text to be rendered in normal font; returns 'normal'
  −
unset - disables font control so that font-style applied to text is dictated by markup inside or outside the template; returns 'inherit'
  −
invert - disables font control so that font-style applied to text is dictated by markup outside or inverted inside the template; returns 'invert'
  −
 
  −
]]
  −
 
  −
local function validate_italic (args)
  −
local properties = {['yes'] = 'italic', ['no'] = 'normal', ['unset'] = 'inherit', ['invert'] = 'invert', ['default'] = nil};
  −
  −
local count = 0
  −
for _, arg in pairs {'italic', 'italics', 'i'} do
  −
if args[arg] then
  −
count = count + 1
  −
end
   
end
 
end
 
+
if arg and lowerCase then
if count > 1 then -- return nil and an error message if more than one is set
+
arg = mw.ustring.lower( mw.text.trim( arg ) )
return nil, 'only one of |italic=, |italics=, or |i= can be specified';
   
end
 
end
+
return arg
return properties[args.italic or args.italics or args.i], nil; -- return an appropriate value and a nil error message
   
end
 
end
   −
 
+
-- determinationCode retourne une table contenant le code de langue principal et la liste des subcode
--[=[--------------------------< V A L I D A T E _ C A T _ A R G S >----------------------------------------------------------
+
-- si le code de langue principal n'est pas reconnu, retourne nil.
 
+
function Langue.determinationCode( langue )
Default behavior of the {{lang}} and {{lang-xx}} templates is to add categorization when the templates are used in mainspace.
+
if type( langue ) == 'string' and langue ~= '' then
This default functionality may be suppressed by setting |nocat=yes or |cat=no.  This function selects one of these two parameters
+
local tabCode = mw.text.split( langue, '-' )
to control categorization.
+
local tabLangue = dataLangue[ mw.ustring.lower( tabCode[1] ) ]
 
+
if tabLangue and tabLangue.code then
Because having two parameters with 'opposite' names and 'opposite' values is confusing, this function accepts only affirmative
+
tabCode[1] = tabLangue.code
values for |nocat= and only negative values for |cat=; in both cases the 'other' sense (and non-sense) is not accepted and the
+
if tabLangue.invalide then
parameter is treated as if it were not set in the template.
+
tabCode.invalide=true
 
+
end
Sets args.nocat to true if categorization is to be turned off; to nil if the default behavior should apply.
+
return tabCode
 
+
end
Accepted values for |nocat= are the text strings:
  −
'yes', 'y', 'true', 't', on, '1' -- [[Module:Yesno]] returns logical true for all of these; false or nil else
  −
for |cat=
  −
'no', 'n', 'false', 'f', 'off', '0' -- [[Module:Yesno]] returns logical false for all of these; true or nil else
  −
 
  −
]=]
  −
 
  −
local function validate_cat_args (args)
  −
if not (args.nocat or args.cat) then -- both are nil, so categorize
  −
return;
  −
end
  −
  −
if false == yesno (args.cat) or true == yesno (args.nocat) then
  −
args.nocat = true; -- set to true when args.nocat is affirmative; nil else (as if the parameter were not set in the template)
  −
else -- args.nocat is the parameter actually used.
  −
args.nocat = nil;
   
end
 
end
 
end
 
end
   −
 
+
-- Voir Modèle:Code langue
--[[--------------------------< I N _ A R R A Y >--------------------------------------------------------------
+
-- Paramètre :
 
+
--     1  : nom de langue.
Whether needle is in haystack
+
function Langue.codeLangue( frame )
 
+
local arg = premierParametre( frame, true )
]]
+
local tabCode = Langue.determinationCode( arg )
 
+
return ( tabCode and table.concat( tabCode, '-' ) ) or arg or ''
local function in_array ( needle, haystack )
  −
if needle == nil then
  −
return false;
  −
end
  −
for n,v in ipairs( haystack ) do
  −
if v == needle then
  −
return n;
  −
end
  −
end
  −
return false;
   
end
 
end
   −
 
+
-- Voir Modèle:Code langue 2
--[[--------------------------< F O R M A T _ I E T F _ T A G >------------------------------------------------
+
-- Paramètre :
 
+
--     1  : nom de langue.
prettify ietf tags to use recommended subtag formats:
+
function Langue.codeLangue2( frame )
code: lower case
+
local arg = premierParametre( frame, true )
script: sentence case
+
local tabCode = Langue.determinationCode( arg )
region: upper case
+
return ( tabCode and table.concat( tabCode, '-' ) ) or ''
variant: lower case
  −
private: lower case prefixed with -x-
  −
  −
]]
  −
 
  −
local function format_ietf_tag (code, script, region, variant, private)
  −
local out = {};
  −
 
  −
if is_set (private) then
  −
return table.concat ({code:lower(), 'x', private:lower()}, '-'); -- if private, all other tags ignored
  −
end
  −
  −
table.insert (out, code:lower());
  −
if is_set (script) then
  −
script = script:lower():gsub ('^%a', string.upper);
  −
table.insert (out, script);
  −
end
  −
 
  −
if is_set (region) then
  −
table.insert (out, region:upper());
  −
end
  −
  −
if is_set (variant) then
  −
table.insert (out, variant:lower());
  −
end
  −
  −
return table.concat (out, '-');
   
end
 
end
      −
--[[--------------------------< G E T _ I E T F _ P A R T S >--------------------------------------------------
+
-- Voir Modèle:Direction langue
 
+
-- Paramètre :
extracts and returns IETF language tag parts:
+
--     1 : nom de langue ou code IETF.
primary language subtag (required) - 2 or 3 character IANA language code
+
function Langue.directionLangue( frame )
script subtag - four character IANA script code
+
local arg = premierParametre( frame, true )
region subtag - two-letter or three digit IANA region code
+
if type( arg ) ~= 'string' or arg == '' then
variant subtag - four digit or 5-8 alnum variant code; only one variant subtag supported
+
return 'ltr'
private subtag - x- followed by 1-8 alnum private code; only supported with the primary language tag
  −
 
  −
in any one of these forms
  −
lang lang-variant
  −
lang-script lang-script-variant
  −
lang-region lang-region-variant
  −
lang-script-region lang-script-region-variant
  −
lang-x-private
  −
  −
each of lang, script, region, variant, and private, when used, must be valid
  −
 
  −
Languages with both two- and three-character code synonyms are promoted to the two-character synonym because
  −
the IANA registry file omits the synonymous three-character code; we cannot depend on browsers understanding
  −
the synonymous three-character codes in the lang= attribute.
  −
 
  −
For {{lang-xx}} templates, the parameters |script=, |region=, and |variant= are supported (not supported in {{lang}}
  −
because those parameters are superfluous to the IETF subtags in |code=)
  −
 
  −
returns six  values; all lower case. Valid parts are returned as themselves; omitted parts are returned as empty strings, invalid
  −
parts are returned as nil; the sixth returned item is an error message (if an error detected) or nil.
  −
 
  −
see http://www.rfc-editor.org/rfc/bcp/bcp47.txt section 2.1
  −
 
  −
]]
  −
 
  −
local function get_ietf_parts (source, args_script, args_region, args_variant)
  −
local code, script, region, variant, private; -- ietf tag parts
  −
 
  −
if not is_set (source) then
  −
return nil, nil, nil, nil, nil, 'missing language tag';
   
end
 
end
 
+
-- séparation du code de langue en code principal et les différents subcode.
local pattern = { -- table of tables holding acceptibe ietf tag patterns and short names of the ietf part captured by the pattern
+
local tabCode = Langue.determinationCode( arg )
{'^(%a%a%a?)%-(%a%a%a%a)%-(%a%a)%-(%d%d%d%d)$', 's', 'r', 'v'}, -- 1 -  ll-Ssss-RR-variant (where variant is 4 digits)
+
if tabCode then
{'^(%a%a%a?)%-(%a%a%a%a)%-(%d%d%d)%-(%d%d%d%d)$', 's', 'r', 'v'}, -- 2 -  ll-Ssss-DDD-variant (where region is 3 digits; variant is 4 digits)
+
-- on essaye de savoir si la direction est de droite à gauche
{'^(%a%a%a?)%-(%a%a%a%a)%-(%a%a)%-(%w%w%w%w%w%w?%w?%w?)$', 's', 'r', 'v'}, -- 3 -  ll-Ssss-RR-variant (where variant is 5-8 alnum characters)
+
local codeScript = tabCode[2]
{'^(%a%a%a?)%-(%a%a%a%a)%-(%d%d%d)%-(%w%w%w%w%w%w?%w?%w?)$', 's', 'r', 'v'}, -- 4 -  ll-Ssss-DDD-variant (where region is 3 digits; variant is 5-8 alnum characters)
+
if codeScript and string.len( codeScript ) == 4 and dataLangue[ 'rtl script' ] then
+
-- il y a un subcode d'écritrure, c'est lui qui est pris en compte
{'^(%a%a%a?)%-(%a%a%a%a)%-(%d%d%d%d)$', 's', 'v'}, -- 5 -  ll-Ssss-variant (where variant is 4 digits)
+
codeScript = string.upper( string.sub( codeScript, 1, 1 ) ) .. string.sub( codeScript, 2 )
{'^(%a%a%a?)%-(%a%a%a%a)%-(%w%w%w%w%w%w?%w?%w?)$', 's', 'v'}, -- 6 -  ll-Ssss-variant (where variant is 5-8 alnum characters)
+
if dataLangue[ 'rtl script' ][ codeScript ] then
+
return 'rtl'
{'^(%a%a%a?)%-(%a%a)%-(%d%d%d%d)$', 'r', 'v'}, -- 7 - ll-RR-variant (where variant is 4 digits)
+
end
{'^(%a%a%a?)%-(%d%d%d)%-(%d%d%d%d)$', 'r', 'v'}, -- 8 -  ll-DDD-variant (where region is 3 digits; variant is 4 digits)
+
else
{'^(%a%a%a?)%-(%a%a)%-(%w%w%w%w%w%w?%w?%w?)$', 'r', 'v'}, -- 9 -  ll-RR-variant (where variant is 5-8 alnum characters)
+
-- il n'y a pas de sub-code d'écriture, on prend en compte le code de langue principal.
{'^(%a%a%a?)%-(%d%d%d)%-(%w%w%w%w%w%w?%w?%w?)$', 'r', 'v'}, -- 10 - ll-DDD-variant (where region is 3 digits; variant is 5-8 alnum characters)
+
local tabLangue = dataLangue[ tabCode[1] ]
+
if tabLangue and tabLangue.rtl then
{'^(%a%a%a?)%-(%d%d%d%d)$', 'v'}, -- 11 - ll-variant (where variant is 4 digits)
+
return 'rtl'
{'^(%a%a%a?)%-(%w%w%w%w%w%w?%w?%w?)$', 'v'}, -- 12 - ll-variant (where variant is 5-8 alnum characters)
  −
  −
{'^(%a%a%a?)%-(%a%a%a%a)%-(%a%a)$', 's', 'r'}, -- 13 - ll-Ssss-RR
  −
{'^(%a%a%a?)%-(%a%a%a%a)%-(%d%d%d)$', 's', 'r'}, -- 14 - ll-Ssss-DDD (region is 3 digits)
  −
  −
{'^(%a%a%a?)%-(%a%a%a%a)$', 's'}, -- 15 - ll-Ssss
  −
  −
{'^(%a%a%a?)%-(%a%a)$', 'r'}, -- 16 - ll-RR
  −
{'^(%a%a%a?)%-(%d%d%d)$', 'r'}, -- 17 - ll-DDD (region is 3 digits)
  −
  −
{'^(%a%a%a?)$'}, -- 18 - ll
  −
  −
{'^(%a%a%a?)%-x%-(%w%w?%w?%w?%w?%w?%w?%w?)$', 'p'}, -- 19 - ll-x-pppppppp (private is 1-8 alnum characters)
  −
}
  −
 
  −
local t = {}; -- table of captures; serves as a translator between captured ietf tag parts and named variables
  −
 
  −
for i, v in ipairs (pattern) do -- spin through the pattern table looking for a match
  −
local c1, c2, c3, c4; -- captures in the 'pattern' from the pattern table go here
  −
  −
c1, c2, c3, c4 = source:match (pattern[i][1]); -- one or more captures set if source matches pattern[i])
  −
if c1 then -- c1 always set on match
  −
code = c1; -- first capture is always code
  −
t = {
  −
[pattern[i][2] or 'x'] = c2, -- fill the table of captures with the rest of the captures
  −
[pattern[i][3] or 'x'] = c3, -- take index names from pattern table and assign sequential captures
  −
[pattern[i][4] or 'x'] = c4, -- index name may be nil in pattern[i] table so "or 'x'" spoofs a name for this index in this table
  −
};
  −
script = t.s or ''; -- translate table contents to named variables;
  −
region = t.r or ''; -- absent table entries are nil so set named ietf parts to empty string for concatenation
  −
variant= t.v or '';
  −
private = t.p or '';
  −
break; -- and done
   
end
 
end
 +
end
 
end
 
end
  −
if not code then
  −
return nil, nil, nil, nil, nil, table.concat ({'unrecognized language tag: ', source}); -- don't know what we got but it is malformed
  −
end
  −
  −
code = code:lower(); -- ensure that we use and return lower case version of this
   
 
if not (override_table[code] or lang_table[code] or synonym_table[code] or lang_dep_table[code]) then
+
-- la langue n'est pas écrite de droite à gauche, donc ltr.
return nil, nil, nil, nil, nil, table.concat ({'unrecognized language code: ', code}); -- invalid language code, don't know about the others (don't care?)
+
return 'ltr'
end
+
end
  −
if synonym_table[code] then -- if 639-2/639-2T code has a 639-1 synonym
  −
table.insert (maint_cats, table.concat ({'Lang and lang-xx code promoted to ISO 639-1|', code}));
  −
table.insert (maint_msgs, table.concat ({'code: ', code, ' promoted to code: ', synonym_table[code]}));
  −
code = synonym_table[code]; -- use the synonym
  −
end
     −
if is_set (script) then
  −
if is_set (args_script) then
  −
return code, nil, nil, nil, nil, 'redundant script tag'; -- both code with script and |script= not allowed
  −
end
  −
else
  −
script = args_script or ''; -- use args.script if provided
  −
end
     −
if is_set (script) then
+
-- Voir Modèle:Nom langue
script = script:lower(); -- ensure that we use and return lower case version of this
+
-- Paramètre :
if not script_table[script] then
+
--    1  : code IETF de langue.
return code, nil, nil, nil, nil, table.concat ({'unrecognized script: ', script, ' for code: ', code}); -- language code ok, invalid script, don't know about the others (don't care?)
+
function Langue.nomLangue( frame )
end
+
local arg = premierParametre( frame, true )
 +
if type( arg ) ~= 'string' or arg == '' then
 +
return '<span class="error">langue non précisée</span>'
 
end
 
end
if suppressed_table[script] then -- ensure that code-script does not use a suppressed script
+
local tabLangue = dataLangue[ arg ]
if in_array (code, suppressed_table[script]) then
+
if tabLangue == nil then
return code, nil, nil, nil, nil, table.concat ({'script: ', script, ' not supported for code: ', code}); -- language code ok, script is suppressed for this code
+
tabLangue = dataLangue[ mw.ustring.match( arg, '^(%a-)%-' ) ]
end
   
end
 
end
 
+
if not tabLangue then
if is_set (region) then
+
return string.format( langErrorMess, arg )
if is_set (args_region) then
  −
return code, nil, nil, nil, nil, 'redundant region tag'; -- both code with region and |region= not allowed
  −
end
  −
else
  −
region = args_region or ''; -- use args.region if provided
  −
end
  −
 
  −
if is_set (region) then
  −
region = region:lower(); -- ensure that we use and return lower case version of this
  −
if not region_table[region] then
  −
return code, script, nil, nil, nil, table.concat ({'unrecognized region: ', region, ' for code: ', code});
  −
end
   
end
 
end
+
if type( tabLangue.page ) == 'string' then
if is_set (variant) then
+
if tabLangue.page ~= '' then
if is_set (args_variant) then
+
return '[[' .. tabLangue.page .. '|' .. tabLangue.nom .. ']]'
return code, nil, nil, nil, nil, 'redundant variant tag'; -- both code with variant and |variant= not allowed
+
else
 +
return tabLangue.nom
 
end
 
end
 
else
 
else
variant = args_variant or ''; -- use args.variant if provided
+
return '[[' .. tabLangue.nom .. ']]'
end
  −
 
  −
if is_set (variant) then
  −
variant = variant:lower(); -- ensure that we use and return lower case version of this
  −
if not variant_table[variant] then -- make sure variant is valid
  −
return code, script, region, nil, nil, table.concat ({'unrecognized variant: ', variant});
  −
end -- does this duplicate/replace tests in lang() and lang_xx()?
  −
if is_set (script) then -- if script set it must be part of the 'prefix'
  −
if not in_array (table.concat ({code, '-', script}), variant_table[variant]['prefixes']) then
  −
return code, script, region, nil, nil, table.concat ({'unrecognized variant: ', variant, ' for code-script pair: ', code, '-', script});
  −
end
  −
elseif is_set (region) then -- if region set, there are some prefixes that require lang code and region (en-CA-newfound)
  −
if not in_array (code, variant_table[variant]['prefixes']) then -- first see if lang code is all that's required (en-oxendict though en-GB-oxendict is preferred)
  −
if not in_array (table.concat ({code, '-', region}), variant_table[variant]['prefixes']) then -- now try for lang code and region (en-CA-newfound)
  −
return code, script, region, nil, nil, table.concat ({'unrecognized variant: ', variant, ' for code-region pair: ', code, '-', region});
  −
end
  −
end
  −
else
  −
if not in_array (code, variant_table[variant]['prefixes']) then
  −
return code, script, region, nil, nil, table.concat ({'unrecognized variant: ', variant, ' for code: ', code});
  −
end
  −
end
   
end
 
end
  −
if is_set (private) then
  −
private = private:lower(); -- ensure that we use and return lower case version of this
  −
if not override_table[table.concat ({code, '-x-', private})] then -- make sure private tag is valid; note that index
  −
return code, script, region, nil, nil, table.concat ({'unrecognized private tag: ', private});
  −
end
  −
end
  −
return code, script, region, variant, private, nil; -- return the good bits; make sure that msg is nil
   
end
 
end
      −
--[[--------------------------< M A K E _ E R R O R _ M S G >--------------------------------------------------
+
-- Voir Modèle:Langue
 
+
-- Paramètres :
assembles an error message from template name, message text, help link, and error category.
+
--   1 : code IETF de langue ;
 
+
--   texte ou 2 : texte dans cette langue ;
]]
+
--   trans : translittération du texte ;
 
+
--   dir : direction de la langue (obsolète : peut être en paramètre 1, avec code en 2 et texte en 3).
local function make_error_msg (msg, args, template)
+
function Langue.langue( frame )
local out = {};
+
local args = ( frame.getParent and frame:getParent().args ) or frame        -- préparation pour appel par modèle ou direct.
local category;
+
local code = mw.ustring.lower( mw.text.trim( args[1] or '' ) )
+
local texte = args.texte or ''
if 'Transl' == template then
+
if texte == '' then
category = 'Transl';
+
texte = args[2] or ''
else
  −
category = 'Lang and lang-xx'
   
end
 
end
 +
local dir = args.dir
 +
local namespaceCategorisation = { [0] = true, [4] = true, [10] = true, [12] = true, [14] = true, [100] = true }
 +
local categorisation = namespaceCategorisation[ mw.title.getCurrentTitle().namespace ] and not args.nocat
 
 
table.insert (out, table.concat ({'[', args.text or 'undefined', '] '})); -- for error messages output args.text if available
+
-- Décalage des paramètres si code contient la direction du texte (obsolète mais toujours possible).
table.insert (out, table.concat ({'<span style=\"font-size: 100%; font-style: normal;\" class=\"error\">Error: {{', template, '}}: '}));
+
if code == 'ltr' or code == 'rtl' then
table.insert (out, msg);
+
dir = code
table.insert (out, table.concat ({' ([[:Category:', category, ' template errors|help]])'}));
+
code = mw.ustring.lower( mw.text.trim( args[2] ) or '' )
table.insert (out, '</span>');
+
texte = args[3] or ''
  −
if (0 == namespace or 10 == namespace) and not args.nocat then -- categorize in article space (and template space to take care of broken usages)
  −
table.insert (out, table.concat ({'[[Category:', category, ' template errors]]'}));
   
end
 
end
 
+
local codeArg = code
return table.concat (out);
  −
end
   
 
 
+
-- sortie immédiate s'il n'y a pas de texte
--[=[-------------------------< M A K E _ W I K I L I N K >----------------------------------------------------
+
if texte == '' then
 
+
if categorisation then
Makes a wikilink; when both link and display text is provided, returns a wikilink in the form [[L|D]]; if only
+
return '<span class="error">erreur du modèle [[modèle:Langue|{{langue}}]] : texte absent</span>[[Catégorie:Page utilisant un modèle avec une syntaxe erronée|Langue]]'
link is provided, returns a wikilink in the form [[L]]; if neither are provided or link is omitted, returns an
  −
empty string.
  −
 
  −
]=]
  −
 
  −
local function make_wikilink (link, display)
  −
if is_set (link) then
  −
if is_set (display) then
  −
return table.concat ({'[[', link, '|', display, ']]'});
   
else
 
else
return table.concat ({'[[', link, ']]'});
+
return ''
 
end
 
end
else
  −
return '';
   
end
 
end
end
+
 
+
-- récursion si texte contient des blocs
 
+
if texte:match('\n *\n') or texte:match('\n[*#:]') then
--[[--------------------------< D I V _ M A R K U P _ A D D >--------------------------------------------------
+
-- les parenthèses permettent d'éliminer la seconde valeur retournée par gsub (nombre de remplacement)
 
+
return ( texte:gsub(  
adds <i> and </i> tags to list-item text or to implied <p>..</p> text.  mixed not supported
+
'(\n?[*#:]?%s*)([^\n]+)',  
 
+
function ( init, ligne )  
]]
+
return init .. Langue.langue{ code, ligne }
 
+
end
local function div_markup_add (text, style)
+
) )
local implied_p = {};
  −
 
  −
if text:find ('^\n[%*:;#]') then -- look for list markup; list markup must begin at start of text
  −
if 'italic' == style then
  −
return mw.ustring.gsub (text, '(\n[%*:;#]+)([^\n]+)', '%1<i>%2</i>'); -- insert italic markup at each list item
  −
else
  −
return text;
  −
end
   
end
 
end
 
+
if text:find ('\n+') then -- look for any number of \n characters in text
+
-- Si la langue est reconnue, la valeur de la table est prise en compte (permet de corriger les noms de langue en toutes lettres).
text = text:gsub ('([^\n])\n([^\n])', '%1 %2'); -- replace single newline characters with a space character which mimics mediawiki
+
local tabCode = Langue.determinationCode( code )
 
+
local tabLangue
if 'italic' == style then
+
if tabCode then
text = text:gsub('[^\n]+', '<p><i>%1</i></p>'); -- insert p and italic markup tags at each impled p (two or more consecutive '\n\n' sequences)
+
code = table.concat( tabCode, '-' )
else
+
tabLangue = dataLangue[ tabCode[1] ]
text = text:gsub ('[^\n]+', '<p>%1</p>'); -- insert p markup at each impled p
+
text = text:gsub ('\n', ''); -- strip newline characters
+
local codeScript = tabCode[2]
 +
-- Si codeScript est bien un style d'écriture (len = 4) on applique sa direction
 +
if codeScript and  string.len( codeScript ) == 4 and dataLangue[ 'rtl script' ] then
 +
-- formatage type Latn correspondant au fromat dans dataLangue[ 'rtl script' ]
 +
codeScript = string.upper( string.sub( codeScript, 1, 1 ) ) .. string.sub(  codeScript, 2 )
 +
tabLangue = { code = tabLangue.code,
 +
rtl = dataLangue[ 'rtl script' ][ codeScript ],
 +
invalide = tabLangue.invalide
 +
}
 
end
 
end
 
end
 
end
 
+
return text;
+
-- Préparation du rendu de direction du texte.
end
+
dir = dir and dir:lower()
 
+
if dir ~= 'ltr' and dir ~= 'rtl' then
 
+
dir = ( tabLangue and tabLangue.rtl and 'rtl' )
--[[--------------------------< M A K E _ T E X T _ H T M L >--------------------------------------------------
  −
 
  −
Add the html markup to text according to the type of content that it is: <span> or <i> tags for inline content or
  −
<div> tags for block content
  −
 
  −
]]
  −
 
  −
local function make_text_html (code, text, tag, rtl, style, size, language)
  −
local html = {};
  −
local style_added = '';
  −
 
  −
if text:match ('^%*') then
  −
table.insert (html, '&#42;'); -- move proto language text prefix outside of italic markup if any; use numeric entity because plain splat confuses MediaWiki
  −
text = text:gsub ('^%*', ''); -- remove the splat from the text
   
end
 
end
   −
if 'span' == tag then -- default html tag for inline content
+
-- Compilation du texte à retourner.
if 'italic' == style then -- but if italic
+
local html = mw.html.create( '' )
tag = 'i'; -- change to <i> tags
+
if code == '' then
 +
html:wikitext( texte )
 +
else
 +
html:tag( 'span' )
 +
:addClass( 'lang-' .. code )
 +
:addClass( args.class )
 +
:attr{ lang = code, dir = dir }
 +
:wikitext( texte )
 +
:done()
 +
 +
-- Translittération.
 +
if ( args.trans or '' ) ~= '' then
 +
local trans = args.trans:gsub( "^''([^'].*[^'])''$", "%1" )
 +
html:wikitext( " (''" )
 +
:tag( 'span' )
 +
:addClass( 'transcription lang-' .. code )
 +
:attr( 'lang', code .. '-Latn' )
 +
:attr( 'dir', 'ltr' )
 +
:wikitext( trans )
 +
:done()
 +
:wikitext( "'')" )
 
end
 
end
else -- must be div so go
  −
text = div_markup_add (text, style); -- handle implied <p>, implied <p> with <i>, and list markup (*;:#) with <i>
  −
end
  −
  −
table.insert (html, table.concat ({'<', tag})); -- open the <i>, <span>, or <div> html tag
  −
table.insert (html, table.concat ({' lang="', code, '\"'})); -- add language attribute
  −
  −
if rtl or unicode.is_rtl(text) then
  −
table.insert (html, ' dir="rtl"'); -- add direction attribute for right to left languages
  −
end
  −
  −
if 'normal' == style then -- when |italic=no
  −
table.insert (html, ' style=\"font-style: normal;'); -- override external markup, if any
  −
style_added = '\"'; -- remember that style attribute added and is not yet closed
  −
end
     −
if is_set (size) then -- when |size=<something>
  −
if is_set (style_added) then
  −
table.insert (html, table.concat ({' font-size: ', size, ';'})); -- add when style attribute already inserted
  −
else
  −
table.insert (html, table.concat ({' style=\"font-size: ', size, ';'})); -- create style attribute
  −
style_added = '\"'; -- remember that style attribute added and is not yet closed
  −
end
   
end
 
end
   −
if is_set (language) then
+
-- Ajout de la catégorie Page avec code de langue invalide si le code langue non reconnu ou invalide.
table.insert (html, table.concat ({style_added, ' title=\"', language})); --start the title text
+
if categorisation and ( type( tabLangue ) ~= 'table' or tabCode.invalide ) then
if language:find ('languages') then
+
local erreur = string.format( langErrorMess, codeArg )
table.insert (html, ' collective text'); -- for collective languages
+
if codeArg == '' then
else
+
erreur = '<span class="error">langue non précisée</span>'
table.insert (html, ' language text'); -- for individual languages
   
end
 
end
table.insert (html, '\">'); -- close the opening html tag
+
html:wikitext( '[[Catégorie:Page avec code de langue invalide|Langue]] ' .. erreur )
else
  −
table.insert (html, table.concat ({style_added, '>'})); -- close the style attribute and close opening html tag
   
end
 
end
table.insert (html, text); -- insert the text
     −
table.insert (html, table.concat ({'</', tag, '>'})); -- close the <i>, <span>, or <div> html tag
+
return tostring( html )
 
  −
if rtl then -- legacy; shouldn't be necessary because all of the rtl text is wrapped inside an html tag with dir="rtl" attribute
  −
table.insert (html, '&lrm;'); -- make sure the browser knows that we're at the end of the rtl
  −
end
  −
return table.concat (html); -- put it all together and done
   
end
 
end
    +
-- Alias nom de fonction
 +
Langue.lang = Langue.langue
   −
--[=[-------------------------< M A K E _ C A T E G O R Y >----------------------------------------------------
     −
For individual language, <language>, returns:
+
-- Voir Modèle:Indication de langue
[[Category:Articles containing <language>-language text]]
+
-- Paramètres :
 
+
--    1 : nom de langue ;
for English:
+
--    2 : code IETF ;
[[Category:Articles containing explicitly cited English-language text]]
+
--    texte : texte dans cette langue ;
+
--    dir : direction de la langue.
for ISO 639-2 collective languages (and for 639-1 bh):
+
function Langue.indicationDeLangue( frame )
[[Category:Articles with text in <language> languages]]
+
local args = ( frame.getParent and frame:getParent().args ) or frame
 
+
local nomLangue = mw.text.trim( args[1] or '' )
]=]
+
local code = mw.text.trim( args[2] or '' )
 
+
local texte = args.texte
local function make_category (code, language_name, nocat, name_get)
+
local dir = args.dir
local cat = {};
+
local wikiText = ''
local retval;
+
-- Cas où le premier et/ou le deuxième paramètre est vide.
 
+
if code == '' and nomLangue == '' then
if ((0 ~= namespace) or nocat) and not name_get then -- only categorize in article space
+
return texte
return ''; -- return empty string for concatenation
+
elseif nomLangue == '' then
 +
nomLangue = dataLangue[ mw.ustring.lower( code ) ]
 +
nomLangue = (nomLangue and nomLangue.nom or '???')
 +
elseif code == '' then
 +
code = dataLangue[ nomLangue ]
 +
code = ( code and code.code or '' )
 +
if code == '' then
 +
return texte
 +
end
 
end
 
end
 
+
-- Gestion du texte.
if language_name:find ('languages') then
+
if texte and texte ~= '' then
return table.concat ({'[[Category:Articles with text in ', language_name, ']]'});
+
texte = '\194\160' .. Langue.lang{ code, dir = dir, texte = texte }
end
  −
  −
table.insert (cat, '[[Category:Articles containing ');
  −
 
  −
if 'en' == code then
  −
table.insert (cat, 'explicitly cited ' .. language_name); -- falls back to English if regional name not available
   
else
 
else
table.insert (cat, language_name);
+
texte = ''
 
end
 
end
 +
-- Compilation de l'indicateur de langue et du texte.
 +
local html = mw.html.create()
 +
html:tag( 'abbr' )
 +
:addClass( 'abbr' )
 +
:addClass( 'indicateur-langue' )
 +
:attr( 'title', 'Langue : ' .. nomLangue )
 +
:wikitext( '(' .. code .. ')' )
 +
:done()
 +
:wikitext( texte )
 
 
table.insert (cat, '-language text]]');
+
return tostring( html )
 
  −
return table.concat (cat);
   
end
 
end
   −
 
+
-- Voir Modèle:Mul
--[[--------------------------< M A K E _ T R A N S L I T >----------------------------------------------------
+
-- Paramètres : codes IETF ou noms de langue, en nombre indéfini (string ou nil uniquement).
 
+
function Langue.indicationMultilingue( frame )
return translit <i lang=xx-Latn>...</i> where xx is the language code; else return empty string
+
local args = (frame.getParent and frame:getParent().args) or frame
 
+
local listeNom = { }
The value |script= is not used in {{transl}} for this purpose; instead it uses |code.  Because language scripts
+
local listeCode = { }
are listed in the {{transl}} switches they are included in the data tables. The script parameter is introduced
+
local tabLangue
at {{Language with name and transliteration}}.  If |script= is set, this function uses it in preference to code.
+
-- Valeur par défaut du premier paramètre = 'mul'.
 
+
local code = mw.text.trim( args[1] or '' )
To avoid confusion, in this module and the templates that use it, the transliteration script parameter is renamed
+
if code == '' then
to be |translit-script= (in this function, tscript)
+
code = 'mul'
 
+
end
This function is used by both lang_xx() and transl()
  −
lang_xx() always provides code, language_name, and translit; may provide tscript; never provides style
  −
transl() always provides language_name, translit, and one of code or tscript, never both; always provides style
  −
 
  −
For {{transl}}, style only applies when a language code is provided
  −
]]
  −
 
  −
local function make_translit (code, language_name, translit, std, tscript, style)
  −
local title;
  −
local tout = {};
  −
local title_table = lang_data.translit_title_table; -- table of transliteration standards and the language codes and scripts that apply to those standards
   
 
if is_set (code) then -- when a language code is provided (always with {{lang-xx}} templates, not always with {{transl}})
+
if not args[2] and not dataLangue[ mw.ustring.lower( code ) ] then
if not style then -- nil for the default italic style
+
local split = mw.text.split( code, '[+,;:/ .]+' )
table.insert (tout, "<i lang=\""); -- so use <i> tag
+
if #split > 1 then
else
+
return Langue.indicationMultilingue( split )
table.insert (tout, table.concat ({'<span style=\"font-style: ', style, '\" lang=\"'})); -- non-standard style, construct a span tag for it
   
end
 
end
table.insert (tout, code);
  −
table.insert (tout, "-Latn\" title=\""); -- transliterations are always Latin script
  −
else
  −
table.insert (tout, "<span title=\""); -- when no language code: no lang= attribute, not italic ({{transl}} only)
   
end
 
end
+
-- Ajout des noms et codes de langue de chaque paramètre dans listeNom et ListeCode.
std = std and std:lower(); -- lower case for table indexing
+
local i = 1
+
repeat
if not is_set (std) and not is_set (tscript) then -- when neither standard nor script specified
+
code = mw.ustring.lower( code )
table.insert (tout, language_name); -- write a generic tool tip
+
local tabLangue = dataLangue[ code ]
if not language_name:find ('languages') then -- collective language names (plural 'languages' is part of the name)
+
if not tabLangue then
table.insert (tout, '-language') -- skip this text (individual and macro languages only)
+
code = mw.text.split( code, '-' )[1]
 +
tabLangue = dataLangue[ code ]
 
end
 
end
table.insert (tout, ' romanization'); -- finish the tool tip; use romanization when neither script nor standard supplied
+
if type( tabLangue ) == 'table' then
elseif is_set (std) and is_set (tscript) then -- when both are specified
+
table.insert( listeNom, tabLangue.nom )
if title_table[std] then -- and if standard is legitimate
+
table.insert( listeCode, tabLangue.code )
if title_table[std][tscript] then -- and if script for that standard is legitimate
  −
table.insert (tout, table.concat ({title_table[std][tscript:lower()], ' (', script_table[tscript][1], ' script) transliteration'})); -- add the appropriate text to the tool tip
  −
else
  −
table.insert (tout, title_table[std]['default']); -- use the default if script not in std table; TODO: maint cat? error message because script not found for this standard?
  −
end
   
else
 
else
return ''; -- invalid standard, setup for error message
+
table.insert( listeNom, '???' )
end
+
local erreur = string.format( langErrorMess, code )
 
+
table.insert( listeCode, erreur )
elseif is_set (std) then -- translit-script not set, use language code
  −
if not title_table[std] then return ''; end -- invalid standard, setup for error message
  −
  −
if title_table[std][code] then -- if language code is in the table (transl may not provide a language code)
  −
-- table.insert (tout, table.concat ({title_table[std][code:lower()], ' (', lang_table[code][1], ' language) transliteration'})); -- add the appropriate text to the tool tip
  −
table.insert (tout, table.concat ({title_table[std][code:lower()], ' (', language_name, ' language) transliteration'})); -- add the appropriate text to the tool tip
  −
else -- code doesn't match
  −
table.insert (tout, title_table[std]['default']); -- so use the standard's default
  −
end
  −
else -- here if translit-script set but translit-std not set
  −
if title_table['no_std'][tscript] then
  −
table.insert (tout, title_table['no_std'][tscript]); -- use translit-script if set
  −
elseif title_table['no_std'][code] then
  −
table.insert (tout, title_table['no_std'][code]); -- use language code
  −
else
  −
if is_set (tscript) then
  −
table.insert (tout, table.concat ({language_name, '-script transliteration'})); -- write a script tool tip
  −
elseif is_set (code) then
  −
if not language_name:find ('languages') then -- collective language names (plural 'languages' is part of the name)
  −
table.insert (tout, '-language') -- skip this text (individual and macro languages only)
  −
end
  −
table.insert (tout, ' transliteration'); -- finish the tool tip
  −
else
  −
table.insert (tout, ' transliteration'); -- generic tool tip (can we ever get here?)
  −
end
  −
end
  −
end
  −
 
  −
table.insert (tout, '">');
  −
table.insert (tout, translit);
  −
if is_set (code) and not style then -- when a language code is provided (always with {{lang-xx}} templates, not always with {{transl}})
  −
table.insert (tout, "</i>"); -- close the italic tag
  −
else
  −
table.insert (tout, "</span>"); -- no language code so close the span tag
  −
end
  −
return table.concat (tout);
  −
end
  −
 
  −
 
  −
--[[--------------------------< V A L I D A T E _ T E X T >----------------------------------------------------
  −
 
  −
This function checks the content of args.text and returns empty string if nothing is amiss else it returns an
  −
error message.  The tests are for empty or missing text and for improper or disallowed use of apostrophe markup.
  −
 
  −
Italic rendering is controlled by the |italic= template parameter so italic markup should never appear in args.text
  −
either as ''itself'' or as '''''bold italic''''' unless |italic=unset or |italic=invert.
  −
 
  −
]]
  −
 
  −
local function validate_text (template, args)
  −
if not is_set (args.text) then
  −
return make_error_msg ('no text', args, template);
  −
end
  −
 
  −
if args.text:find ("%f[\']\'\'\'\'%f[^\']") or args.text:find ("\'\'\'\'\'[\']+") then -- because we're looking, look for 4 appostrophes or 6+ appostrophes
  −
return make_error_msg ('text has malformed markup', args, template);
  −
end
  −
 
  −
local style = args.italic;
  −
 
  −
if ('unset' ~= style) and ('invert' ~=style) then
  −
if args.text:find ("%f[\']\'\'%f[^\']") or args.text:find ("%f[\']\'\'\'\'\'%f[^\']") then -- italic but not bold, or bold italic
  −
return make_error_msg ('text has italic markup', args, template);
   
end
 
end
end
+
i = i + 1
end
+
code = mw.text.trim( args[i] or '' )
 
+
until code == ''
 
  −
--[[--------------------------< R E N D E R _ M A I N T >------------------------------------------------------
  −
 
  −
render mainenance messages and categories
  −
 
  −
]]
  −
 
  −
local function render_maint(nocat)
  −
local maint = {};
   
 
if 0 < #maint_msgs then -- when there are maintenance messages
+
-- Préparation et renvoi du texte.
table.insert (maint, table.concat ({'<span class="lang-comment" style="font-style: normal; display: none; color: #33aa33; margin-left: 0.3em;">'})); -- opening <span> tag
+
local n = #listeCode
for _, msg in ipairs (maint_msgs) do
+
if n == 0 then
table.insert (maint, table.concat ({msg, ' '})); -- add message strings
+
return ''
end
  −
table.insert (maint, '</span>'); -- close the span
   
end
 
end
 +
local plusieurs = ( n > 1 )
 
 
if (0 < #maint_cats) and (0 == namespace) and not nocat then -- when there are maintenance categories; article namespace only
+
local html = mw.html.create( 'abbr' )
for _, cat in ipairs (maint_cats) do
+
:addClass( 'abbr' )
table.insert (maint, table.concat ({'[[Category:', cat, ']]'})); -- format and add the categories
+
:addClass( 'indicateur-langue' )
end
+
:attr( 'title', 'Langue' .. ( plusieurs and 's' or '' ) .. ' : ' .. mw.text.listToText( listeNom ) )
end
+
:wikitext( '(' .. table.concat( listeCode, '\194\160+\194\160' ) .. ')' )
 
 
return table.concat (maint);
+
return tostring( html )
 
end
 
end
      −
--[[--------------------------< P R O T O _ P R E F I X >------------------------------------------------------
+
-- Voir Modèle:Langue avec nom
 +
-- Paramètres :
 +
--   1 : code IETF de langue ;
 +
--   texte ou 2 : texte dans cette langue ;
 +
--   trans : translittération du texte ;
 +
--   dir : direction de la langue.
 +
function Langue.langueAvecNom( frame )
 +
local args = ( frame.getParent and frame:getParent().args ) or frame
 +
local code = mw.ustring.lower( mw.text.trim( args [1] or '') )
 +
local texte = args.texte or args[2] or ''
 +
local trans = args.trans
 +
local dir = args.dir
 +
local wikiText = ''
   −
for proto languages, text is prefixed with a splat. We do that here as a flag for make_text_html() so that a splat
+
-- Détection de la direction du texte.
will be rendered outside of italic markup (if used).  If the first character in text here is already a splat, we
+
if code == 'ltr' or code == 'rtl' then
do nothing
+
dir = code
 +
code = mw.ustring.lower( mw.text.trim( args[2] ) )
 +
texte = args[3] or ''
 +
end
   −
proto_param is boolean or nil; true adds splat prefix regardless of language name; false removes and / or inhibits
+
-- Définition du nom de la langue en français.
regardless of language name; nil does nothing; presumes that the value in text is correct but removes extra splac
+
local nom = Langue.nomLangue{ code }
   −
]]
+
if texte ~= '' then
 
+
texte = '\194\160' .. Langue.lang{ code, dir = dir, texte = texte, trans = trans }
local function proto_prefix (text, language_name, proto_param)
  −
if false == proto_param then -- when forced by |proto=no
  −
return text:gsub ('^%**', ''); -- return text without splat prefix regardless of language name or existing splat prefix in text
  −
elseif (language_name:find ('^Proto%-') or (true == proto_param)) then -- language is a proto or forced by |proto=yes
  −
return text:gsub ('^%**', '*'); -- prefix proto-language text with a splat; also removes duplicate prefixing splats
   
end
 
end
  −
return text:gsub ('^%*+', '*'); -- return text unmolested except multiple splats reduced to one splat
  −
end
  −
  −
  −
--[[--------------------------< H A S _ P O E M _ T A G >------------------------------------------------------
  −
  −
looks for a poem strip marker in text; returns true when found; false else
  −
  −
auto-italic detection disabled when text has poem stripmarker because it is not possible for this code to know
  −
the content that will replace the stripmarker.
     −
]]
+
wikiText = nom .. ' :' .. texte
   −
local function has_poem_tag (text)
+
return wikiText
return text:find ('\127[^\127]*UNIQ%-%-poem%-[%a%d]+%-QINU[^\127]*\127') and true or false;
   
end
 
end
   −
 
+
---
--[[--------------------------< H T M L _ T A G _ S E L E C T >------------------------------------------------
+
-- latinOnly détermine si la chaine fournie contient uniquement des caractères latin (étendu, unicode < 880)
 
+
function Langue.nonLatin( frame )
Inspects content of and selectively trims text.  Returns text and the name of an appropriate html tag for text.
+
local texte = premierParametre( frame )
 
+
for codepoint in mw.ustring.gcodepoint( texte ) do
If text contains:
+
if codepoint > 879 and not (                 -- > 036F
\n\n text has implied <p>..</p> tags - trim leading and trailing whitespace and return
+
codepoint > 7423 and codepoint < 7936 or  -- suppléments phonétique, diacritiques et latin  (1D00 à 1EFF)
If text begins with list markup:
+
codepoint > 8191 and codepoint < 11392 or -- espace, indices, monaies et symboles divers (2000 à 2C7F)
\n* unordered
+
codepoint > 42783 and codepoint < 43008  -- latin étendu D  (A720 à A7FF)
\n; definition
+
) then
\n: definition
+
return true
\n# ordered
+
end
trim all leading whitespace except  \n and trim all trailing whitespace
  −
 
  −
If text contains <poem>...</poem> stripmarker, return text unmodified and choose <div>..</div> tags because
  −
the stripmarker is replaced with text wrapped in <div>..</div> tags.
  −
 
  −
]]
  −
 
  −
local function html_tag_select (text)
  −
local tag;
  −
  −
if has_poem_tag (text) then -- contains poem stripmarker (we can't know the content of that)
  −
tag = 'div'; -- poem replacement is in div tags so lang must use div tags
  −
elseif mw.text.trim (text):find ('\n\n+') then -- contains implied p tags
  −
text = mw.text.trim (text); -- trim leading and trailing whitespace characters
  −
tag = 'div'; -- must be div because span may not contain p tags (added later by MediaWiki); poem replacement is in div tags
  −
elseif text:find ('\n[%*:;%#]') then -- if text has list markup
  −
text = text:gsub ('^[\t\r\f ]*', ''):gsub ('%s*$', ''); -- trim all whitespace except leading newline character '\n'
  −
tag = 'div'; -- must be div because span may not contain ul, dd, dl, ol tags (added later by MediaWiki)
  −
else
  −
text = mw.text.trim (text); -- plain text
  −
tag = 'span'; -- so span is fine
   
end
 
end
+
return false
return text, tag;
   
end
 
end
    +
-- erreurModuleData affiche un message d'erreur si le Module:Langue/Data n'a pas été chargé correctement,
 +
-- pour la page de discussion de la base de données et ceux qui veulent surveiller cette page.
 +
function Langue.erreurModuleData()
 +
if type( dataLangue ) ~= 'table'  then
 +
local message = [[<strong class="error">Le chargement du module Langue/Data génère une erreur : </strong> <br>%s <br>
   −
--[[--------------------------< V A L I D A T E _ P R O T O >--------------------------------------------------
+
<span class="error">Cette erreur doit être corrigée au plus vite car des milliers de pages ne s'affichent pas correctement.</span>
 
  −
validates value assigned to |proto=; permitted values are yes and no; yes returns as true, no returns as false,
  −
empty string (or parameter omitted) returns as nil; any other value returns as nil with a second return value of
  −
true indicating that some other value has been assigned to |proto=
  −
 
   
]]
 
]]
 
+
return string.format( message, resultat )
local function validate_proto (proto_param)
  −
if 'yes' == proto_param then
  −
return true;
  −
elseif 'no' == proto_param then
  −
return false;
  −
elseif is_set (proto_param) then
  −
return nil, true; -- |proto= something other than 'yes' or 'no'
  −
else
  −
return nil; -- missing or empty
   
end
 
end
 
end
 
end
    +
-- tableauLangues génère un tableau triable de la liste des langues disponible dans Module:langue/Data.
 +
function Langue.tableauLangues()
 +
local tableau = { }
 +
local entete = [[{| class="wikitable alternance sortable"
 +
|-
 +
!scope=col|Alias
 +
!scope=col|Code IETF
 +
!scope=col|Nom principal
 +
!scope=col|Page (si différente du nom)
 +
!scope=col|RTL
 +
!scope=col|Invalide]]
   −
--[[--------------------------< L A N G U A G E _ N A M E _ G E T >--------------------------------------------
+
local ligneTab, ligneSrt
 
+
for i, v in pairs( dataLangue ) do
common function to return language name from the data set according to IETF tag
+
if v.code then
 
+
ligneTab = {
returns language name if found in data tables; nil else
+
i,
 
+
v.code,
]]
+
v.nom,
 
+
v.page or '',
local function language_name_get (ietf, code, cat)
+
v.rtl and '[[Image:Yes check.svg|15px|oui|lien=]]' or '',
ietf = ietf:lower(); -- ietf:lower() because format_ietf_tag() returns mixed case
+
v.invalide and '[[Image:Yes check.svg|15px|oui|lien=]]' or '',
+
}
local name; -- remains nil if not found
+
ligneSrt = table.concat( ligneTab, '\n|' )
+
table.insert( tableau, ligneSrt )
if override_table[ietf] then -- look for whole IETF tag in override table
  −
name = override_table[ietf][1];
  −
elseif override_table[code] then -- not there so try basic language code
  −
name = override_table[code][1];
  −
elseif lang_table[code] then -- shift to iana code/name table
  −
name = lang_table[code][1]; -- table entries sometimes have multiple names, always take the first one
  −
elseif lang_dep_table[code] then
  −
-- if cat then
  −
-- table.insert (maint_cats, table.concat ({'Lang and lang-xx using deprecated ISO 639 codes|', code}));
  −
-- table.insert (maint_msgs, table.concat ({'code: ', code, ' is deprecated'}));
  −
-- end
  −
name = lang_dep_table[code][1]; -- table entries sometimes have multiple names, always take the first one
  −
end
  −
 
  −
if lang_dep_table[code] and cat then -- because deprecated code may have been overridden to en.wiki preferred name
  −
table.insert (maint_cats, table.concat ({'Lang and lang-xx using deprecated ISO 639 codes|', code}));
  −
table.insert (maint_msgs, table.concat ({'code: ', code, ' is deprecated'}));
  −
end
  −
 
  −
return name; -- name from data tables or nil
  −
end
  −
 
  −
 
  −
--[[--------------------------< _ L A N G >--------------------------------------------------------------------
  −
 
  −
entry point for {{lang}}
  −
 
  −
there should be no reason to set parameters in the {{lang}} {{#invoke:}}
  −
<includeonly>{{#invoke:lang|lang}}</includeonly>
  −
 
  −
parameters are received from the template's frame (parent frame)
  −
 
  −
]]
  −
 
  −
local function _lang (args)
  −
local out = {};
  −
local language_name; -- used to make category names
  −
local category_name; -- same as language_name except that it retains any parenthetical disambiguators (if any) from the data set
  −
local subtags = {}; -- IETF subtags script, region, variant, and private
  −
local code; -- the language code
  −
local msg; -- for error messages
  −
local tag = 'span'; -- initial value for make_text_html()
  −
local template = args.template or 'Lang';
  −
 
  −
validate_cat_args (args); -- determine if categorization should be suppressed
  −
 
  −
if args[1] and args.code then
  −
return make_error_msg ('conflicting: {{{1}}} and |code=', args, template);
  −
else
  −
args.code = args[1] or args.code; -- prefer args.code
  −
end
  −
 
  −
if args[2] and args.text then
  −
return make_error_msg ('conflicting: {{{2}}} and |text=', args, template);
  −
else
  −
args.text = args[2] or args.text; -- prefer args.text
  −
end
  −
  −
msg = validate_text (template, args); -- ensure that |text= is set
  −
if is_set (msg) then -- msg is an already-formatted error message
  −
return msg;
  −
end
  −
  −
args.text, tag = html_tag_select (args.text); -- inspects text; returns appropriate html tag with text trimmed accordingly
  −
 
  −
args.rtl = args.rtl == 'yes'; -- convert to boolean: 'yes' -> true, other values -> false
  −
 
  −
args.proto, msg = validate_proto (args.proto); -- return boolean, or nil, or nil and error message flag
  −
if msg then
  −
return make_error_msg (table.concat ({'invalid |proto=: ', args.proto}), args, template);
  −
end
  −
 
  −
code, subtags.script, subtags.region, subtags.variant, subtags.private, msg = get_ietf_parts (args.code); -- |script=, |region=, |variant= not supported because they should be part of args.code ({{{1}}} in {{lang}})
  −
 
  −
if msg then
  −
return make_error_msg ( msg, args, template);
  −
end
  −
 
  −
args.italic, msg = validate_italic (args);
  −
if msg then
  −
return make_error_msg (msg, args, template);
  −
end
  −
 
  −
if nil == args.italic then -- nil when |italic= absent or not set or |italic=default; args.italic controls
  −
if ('latn' == subtags.script) or -- script is latn
  −
(this_wiki_lang ~= code and not is_set (subtags.script) and not has_poem_tag (args.text) and unicode.is_Latin (args.text)) then -- text not this wiki's language, no script specified and not in poem markup but is wholly latn script (auto-italics)
  −
args.italic = 'italic'; -- DEFAULT for {{lang}} templates is upright; but if latn script set for font-style:italic
  −
else
  −
args.italic = 'inherit'; -- italic not set; script not latn; inherit current style
   
end
 
end
 
end
 
end
 +
table.sort( tableau )
 +
table.insert( tableau, 1, entete )
 +
table.insert( tableau, '}' )
 
 
if is_set (subtags.script) then -- if script set, override rtl setting
+
return table.concat( tableau, '\n|-\n|' )
if in_array (subtags.script, lang_data.rtl_scripts) then
  −
args.rtl = true; -- script is an rtl script
  −
else
  −
args.rtl = false; -- script is not an rtl script
  −
end
  −
end
  −
 
  −
args.code = format_ietf_tag (code, subtags.script, subtags.region, subtags.variant, subtags.private); -- format to recommended subtag styles
  −
language_name = language_name_get (args.code, code, true); -- get language name; try ietf tag first, then code w/o variant then code w/ variant
  −
 
  −
if 'invert' == args.italic and 'span' == tag then -- invert only supported for in-line content
  −
args.text = invert_italics (args.text)
  −
end
  −
 
  −
args.text = proto_prefix (args.text, language_name, args.proto); -- prefix proto-language text with a splat
  −
 
  −
table.insert (out, make_text_html (args.code, args.text, tag, args.rtl, args.italic, args.size, language_name));
  −
table.insert (out, make_category (code, language_name, args.nocat));
  −
table.insert (out, render_maint(args.nocat)); -- maintenance messages and categories
  −
 
  −
return table.concat (out); -- put it all together and done
   
end
 
end
   −
 
+
-- listeCodeAlias génère une liste ; les langues sont de la forme : * code : alias1, alias2
--[[--------------------------< L A N G >----------------------------------------------------------------------
+
function Langue.listeCodeAlias()
 
+
local languesTab, listeCodesAlias = { }, { }
entry point for {{lang}}
+
local code, alias, codeAlias
 
+
for i, v in pairs( dataLangue ) do
there should be no reason to set parameters in the {{lang}} {{#invoke:}}
+
-- on construit un table avec pour indices les codes de langue, et pour valeurs une table avec la liste des alias
<includeonly>{{#invoke:lang|lang}}</includeonly>
+
code = v.code
 
+
if code and not v.invalide then
parameters are received from the template's frame (parent frame)
+
languesTab[code] = languesTab[code] or { }
 
+
if i ~= mw.ustring.lower( code ) then
]]
+
table.insert( languesTab[code], i )
 
  −
local function lang (frame)
  −
local args = getArgs (frame, { -- this code so that we can detect and handle wiki list markup in text
  −
valueFunc = function (key, value)
  −
if 2 == key or 'text' == key then -- the 'text' parameter; do not trim wite space
  −
return value; -- return untrimmed 'text'
  −
elseif value then -- all other values: if the value is not nil
  −
value = mw.text.trim (value); -- trim whitespace
  −
if '' ~= value then -- empty string when value was only whitespace
  −
return value;
  −
end
   
end
 
end
return nil; -- value was empty or contained only whitespace
  −
end -- end of valueFunc
  −
});
  −
  −
return _lang (args);
  −
end
  −
  −
  −
--[[--------------------------< L A N G _ X X >----------------------------------------------------------------
  −
  −
For the {{lang-xx}} templates, the only parameter required to be set in the template is the language code.  All
  −
other parameters can, usually should, be written in the template call.  For {{lang-xx}} templates for languages
  −
that can have multiple writing systems, it may be appropriate to set |script= as well.
  −
  −
For each {{lang-xx}} template choose the appropriate entry-point function so that this function knows the default
  −
styling that should be applied to text.
  −
  −
For normal, upright style:
  −
<includeonly>{{#invoke:lang|lang_xx_inherit|code=xx}}</includeonly>
  −
For italic style:
  −
<includeonly>{{#invoke:lang|lang_xx_italic|code=xx}}</includeonly>
  −
  −
All other parameters should be received from the template's frame (parent frame)
  −
  −
Supported parameters are:
  −
|code = (required) the IANA language code
  −
|script = IANA script code; especially for use with languages that use multiple writing systems
  −
|region = IANA region code
  −
|variant = IANA variant code
  −
|text = (required) the displayed text in language specified by code
  −
|link = boolean false ('no') does not link code-spcified language name to associated language article
  −
|rtl = boolean true ('yes') identifies the language specified by code as a right-to-left language
  −
|nocat = boolean true ('yes') inhibits normal categorization; error categories are not affected
  −
|cat = boolian false ('no') opposite form of |nocat=
  −
|italic = boolean true ('yes') renders displayed text in italic font; boolean false ('no') renders displayed text in normal font; not set renders according to initial_style_state
  −
|lit = text that is a literal translation of text
  −
|label = 'none' to suppress all labeling (language name, 'translit.', 'lit.')
  −
any other text replaces language-name label - automatic wikilinking disabled
  −
  −
for those {{lang-xx}} templates that support transliteration (those templates where |text= is not entirely latn script):
  −
|translit = text that is a transliteration of text
  −
|translit-std = the standard that applies to the transliteration
  −
|translit-script = ISO 15924 script name; falls back to code
  −
  −
For {{lang-xx}}, the positional parameters are:
  −
{{{1}}} text
  −
{{{2}}} transliterated text
  −
{{{3}}} literal translation text
  −
no other positional parameters are allowed
  −
  −
]]
  −
  −
local function _lang_xx (args)
  −
local out = {};
  −
local language_name; -- used to make display text, article links
  −
local category_name; -- same as language_name except that it retains any parenthetical disambiguators (if any) from the data set
  −
local subtags = {}; -- IETF subtags script, region, and variant
  −
local code; -- the language code
  −
  −
local translit_script_name; -- name associated with IANA (ISO 15924) script code
  −
local translit;
  −
local translit_title;
  −
local msg; -- for error messages
  −
local tag = 'span'; -- initial value for make_text_html()
  −
local template = args.template or 'Lang-xx';
  −
  −
if args[1] and args.text then
  −
return make_error_msg ('conflicting: {{{1}}} and |text=', args, template);
  −
else
  −
args.text = args[1] or args.text; -- prefer args.text
  −
end
  −
  −
msg = validate_text (template, args); -- ensure that |text= is set, does not contain italic markup and is protected from improper bolding
  −
if is_set (msg) then
  −
return msg;
  −
end
  −
  −
args.text, tag = html_tag_select (args.text); -- inspects text; returns appropriate html tag with text trimmed accordingly
  −
  −
if args[2] and args.translit then
  −
return make_error_msg ('conflicting: {{{2}}} and |translit=', args, template);
  −
else
  −
args.translit = args[2] or args.translit -- prefer args.translit
  −
end
  −
  −
if args[3] and (args.translation or args.lit) then
  −
return make_error_msg ('conflicting: {{{3}}} and |lit= or |translation=', args, template);
  −
elseif args.translation and args.lit then
  −
return make_error_msg ('conflicting: |lit= and |translation=', args, template);
  −
else
  −
args.translation = args[3] or args.translation or args.lit; -- prefer args.translation
  −
end
  −
  −
if args.links and args.link then
  −
return make_error_msg ('conflicting: |links= and |link=', args, template);
  −
else
  −
args.link = args.link or args.links; -- prefer args.link
  −
end
  −
  −
validate_cat_args (args); -- determine if categorization should be suppressed
  −
  −
args.rtl = args.rtl == 'yes'; -- convert to boolean: 'yes' -> true, other values -> false
  −
  −
code, subtags.script, subtags.region, subtags.variant, subtags.private, msg = get_ietf_parts (args.code, args.script, args.region, args.variant); -- private omitted because private
  −
  −
if msg then -- if an error detected then there is an error message
  −
return make_error_msg (msg, args, template);
  −
end
  −
  −
args.italic, msg = validate_italic (args);
  −
if msg then
  −
return make_error_msg (msg, args, template);
  −
end
  −
  −
if nil == args.italic then -- args.italic controls
  −
if is_set (subtags.script) then
  −
if 'latn' == subtags.script then
  −
args.italic = 'italic'; -- |script=Latn; set for font-style:italic
  −
else
  −
args.italic = initial_style_state; -- italic not set; script is not latn; set for font-style:<initial_style_state>
  −
end
  −
else
  −
args.italic = initial_style_state; -- here when |italic= and |script= not set; set for font-style:<initial_style_state>
   
end
 
end
 
end
 
end
+
for i, v in pairs( languesTab ) do
if is_set (subtags.script) then -- if script set override rtl setting
+
-- transformation en un table séquence, avec pour valeur une chaine correspondant à une ligne de la liste
if in_array (subtags.script, lang_data.rtl_scripts) then
+
alias = table.concat( v, ', ' )
args.rtl = true; -- script is an rtl script
+
if alias == '' then
else
+
codeAlias = '* <code>' .. i .. '</code>'
args.rtl = false; -- script is not an rtl script
  −
end
  −
end
  −
 
  −
args.proto, msg = validate_proto (args.proto); -- return boolean, or nil, or nil and error message flag
  −
if msg then
  −
return make_error_msg (table.concat ({'invalid |proto=: ', args.proto}), args, template);
  −
end
  −
 
  −
args.code = format_ietf_tag (code, subtags.script, subtags.region, subtags.variant, subtags.private); -- format to recommended subtag styles
  −
language_name = language_name_get (args.code, code, true); -- get language name; try ietf tag first, then code w/o variant then code w/ variant
  −
 
  −
category_name = language_name; -- category names retain IANA parenthetical diambiguators (if any)
  −
language_name = language_name:gsub ('%s+%b()', ''); -- remove IANA parenthetical disambiguators or qualifiers from names that have them
  −
 
  −
if args.label then
  −
if 'none' ~= args.label then
  −
table.insert (out, table.concat ({args.label, ': '})); -- custom label
  −
end
  −
else
  −
if 'no' == args.link then
  −
table.insert (out, language_name); -- language name without wikilink
   
else
 
else
if language_name:find ('languages') then
+
codeAlias = '* <code>' .. i .. '</code> : ' .. alias
table.insert (out, make_wikilink (language_name)); -- collective language name uses simple wikilink
  −
elseif lang_data.article_name[code] then
  −
table.insert (out, make_wikilink (lang_data.article_name[code][1], language_name)); -- language name with wikilink from override data
  −
else
  −
table.insert (out, make_wikilink (language_name .. ' language', language_name)); -- language name with wikilink
  −
end
   
end
 
end
table.insert (out, ': '); -- separator
+
table.insert( listeCodesAlias, codeAlias )
end
  −
 
  −
if 'invert' == args.italic then
  −
args.text = invert_italics (args.text)
   
end
 
end
 +
table.sort( listeCodesAlias )
 
 
args.text = proto_prefix (args.text, language_name, args.proto); -- prefix proto-language text with a splat
+
return table.concat( listeCodesAlias, '\n' )
 
+
end
table.insert (out, make_text_html (args.code, args.text, tag, args.rtl, args.italic, args.size, nil))
     −
if is_set (args.translit) and not unicode.is_Latin (args.text) then -- transliteration (not supported in {{lang}}); not supported when args.text is wholly latn text (this is an imperfect test)
+
-- listeAliasCode génère une liste ; les langues sont de la forme :  * alias : code
table.insert (out, ', '); -- comma to separate text from translit
+
function Langue.listeAliasCode()
if 'none' ~= args.label then
+
local languesTab = { }
table.insert (out, '<small>');
+
local code
if script_table[args['translit-script']] then -- when |translit-script= is set, try to use the script's name
+
for i, v in pairs( dataLangue ) do
translit_script_name = script_table[args['translit-script'][1]];
+
-- on construit un table avec pour indices les codes de langue, et pour valeurs une table avec la liste des alias
else
+
code = v.code
translit_script_name = language_name; -- fall back on language name
+
if code and i ~= code and not v.invalide then
end
+
table.insert( languesTab, '* ' .. i .. ' = ' .. code )
translit_title = mw.title.makeTitle (0, table.concat ({'Romanization of ', translit_script_name})); -- make a title object
  −
if translit_title.exists and ('no' ~= args.link) then
  −
table.insert (out, make_wikilink ('Romanization of ' .. translit_script_name or language_name, 'romanized') .. ':'); -- make a wikilink if there is an article to link to
  −
else
  −
table.insert (out, 'romanized:'); -- else plain text
  −
end
  −
table.insert (out, '&nbsp;</small>'); -- close the small tag
  −
end
  −
  −
translit = make_translit (args.code, language_name, args.translit, args['translit-std'], args['translit-script'])
  −
if is_set (translit) then
  −
table.insert (out, translit);
  −
else
  −
return make_error_msg (table.concat ({'invalid translit-std: \'', args['translit-std'] or '[missing]'}), args, template);
   
end
 
end
 
end
 
end
 +
table.sort( languesTab )
 
 
if is_set (args.translation) then -- translation (not supported in {{lang}})
+
return table.concat( languesTab, '\n' )
table.insert (out, ', ');
  −
if 'none' ~= args.label then
  −
table.insert (out, '<small>');
  −
if 'no' == args.link then
  −
table.insert (out, '<abbr title="literal translation">lit.</abbr>');
  −
else
  −
table.insert (out, make_wikilink ('Literal translation', 'lit.'));
  −
end
  −
table.insert (out, "&nbsp;</small>");
  −
end
  −
table.insert (out, table.concat ({'&#39;', args.translation, '&#39;'})); -- use html entities to avoid wiki markup confusion
  −
end
  −
  −
table.insert (out, make_category (code, category_name, args.nocat));
  −
table.insert (out, render_maint(args.nocat)); -- maintenance messages and categories
  −
 
  −
return table.concat (out); -- put it all together and done
  −
end
  −
 
  −
 
  −
--[[--------------------------< L A N G _ X X _ A R G S _ G E T >----------------------------------------------
  −
 
  −
common function to get args table from {{lang-??}} templates
  −
 
  −
returns table of args
  −
 
  −
]]
  −
 
  −
local function lang_xx_args_get (frame)
  −
local args = getArgs(frame,
  −
{
  −
parentFirst= true, -- parameters in the template override parameters set in the {{#invoke:}}
  −
valueFunc = function (key, value)
  −
if 1 == key then -- the 'text' parameter; do not trim wite space
  −
return value; -- return untrimmed 'text'
  −
elseif value then -- all other values: if the value is not nil
  −
value = mw.text.trim (value); -- trim whitespace
  −
if '' ~= value then -- empty string when value was only whitespace
  −
return value;
  −
end
  −
end
  −
return nil; -- value was empty or contained only whitespace
  −
end -- end of valueFunc
  −
});
  −
 
  −
return args;
  −
end
  −
 
  −
 
  −
--[[--------------------------< L A N G _ X X _ I T A L I C >--------------------------------------------------
  −
 
  −
Entry point for those {{lang-xx}} templates that call lang_xx_italic().  Sets the initial style state to italic.
  −
 
  −
]]
  −
 
  −
local function lang_xx_italic (frame)
  −
local args = lang_xx_args_get (frame);
  −
  −
initial_style_state = 'italic';
  −
return _lang_xx (args);
  −
end
  −
 
  −
 
  −
--[[--------------------------< _ L A N G _ X X _ I T A L I C >------------------------------------------------
  −
 
  −
Entry point ffrom another module.  Sets the initial style state to italic.
  −
 
  −
]]
  −
 
  −
local function _lang_xx_italic (args)
  −
initial_style_state = 'italic';
  −
return _lang_xx (args);
  −
end
  −
 
  −
 
  −
--[[--------------------------< L A N G _ X X _ I N H E R I T >------------------------------------------------
  −
 
  −
Entry point for those {{lang-xx}} templates that call lang_xx_inherit().  Sets the initial style state to inherit.
  −
 
  −
]]
  −
 
  −
local function lang_xx_inherit (frame)
  −
local args = lang_xx_args_get (frame);
  −
 
  −
initial_style_state = 'inherit';
  −
return _lang_xx (args);
  −
end
  −
 
  −
 
  −
--[[--------------------------< _ L A N G _ X X _ I N H E R I T >----------------------------------------------
  −
 
  −
Entry point from another module.  Sets the initial style state to inherit.
  −
 
  −
]]
  −
 
  −
local function _lang_xx_inherit (args)
  −
initial_style_state = 'inherit';
  −
return _lang_xx (args);
  −
end
  −
 
  −
 
  −
--[[--------------------------< _ I S _ I E T F _ T A G >------------------------------------------------------
  −
 
  −
Returns true when a language name associated with IETF language tag exists; nil else.  IETF language tag must be valid.
  −
 
  −
All code combinations supported by {{lang}} and the {{lang-xx}} templates are supported by this function.
  −
 
  −
Module entry point from another module
  −
 
  −
]]
  −
 
  −
local function _is_ietf_tag (tag) -- entry point when this module is require()d into another
  −
local c, s, r, v, p, err; -- code, script, region, variant, private, error message
  −
c, s, r, v, p, err = get_ietf_parts (tag); -- disassemble tag into constituent part and validate
  −
 
  −
return ((c and not err) and true) or nil; -- return true when code portion has a value without error message; nil else
   
end
 
end
   −
 
+
return Langue
--[[--------------------------< I S _ I E T F _ T A G >--------------------------------------------------------
  −
 
  −
Module entry point from an {{#invoke:}}
  −
 
  −
]]
  −
 
  −
local function is_ietf_tag (frame)
  −
return _is_ietf_tag (getArgs(frame)[1]); -- args[1] is the ietf language tag to be tested; getArgs() so we also get parent frame
  −
end
  −
 
  −
 
  −
--[[--------------------------< _ N A M E _ F R O M _ T A G >--------------------------------------------------
  −
 
  −
Returns language name associated with IETF language tag if valid; error message else.
  −
 
  −
All code combinations supported by {{lang}} and the {{lang-xx}} templates are supported by this function.
  −
 
  −
Set invoke's |link= parameter to yes to get wikilinked version of the language name.
  −
 
  −
Module entry point from another module
  −
 
  −
]]
  −
 
  −
local function _name_from_tag (args)
  −
local subtags = {}; -- IETF subtags script, region, variant, and private
  −
local raw_code = args[1]; -- save a copy of the input IETF subtag
  −
local link = 'yes' == args['link']; -- make a boolean
  −
local label = args.label;
  −
local code; -- the language code
  −
local msg; -- gets an error message if IETF language tag is malformed or invalid
  −
local language_name = '';
  −
  −
code, subtags.script, subtags.region, subtags.variant, subtags.private, msg = get_ietf_parts (raw_code);
  −
if msg then
  −
local template = (args['template'] and table.concat ({'{{', args['template'], '}}: '})) or ''; -- make template name (if provided by the template)
  −
return table.concat ({'<span style=\"font-size: 100%; font-style: normal;\" class=\"error\">Error: ', template, msg, '</span>'});
  −
end
  −
 
  −
raw_code = format_ietf_tag (code, subtags.script, subtags.region, subtags.variant, subtags.private); -- format to recommended subtag styles; private omitted because private
  −
language_name = language_name_get (raw_code, code); -- get language name; try ietf tag first, then code w/o variant then code w/ variant
  −
 
  −
language_name = language_name:gsub ('%s+%b()', ''); -- remove IANA parenthetical disambiguators or qualifiers from names that have them
  −
 
  −
if link then -- when |link=yes, wikilink the language name
  −
if language_name:find ('languages') then
  −
language_name = make_wikilink (language_name, label); -- collective language name uses simple wikilink
  −
elseif lang_data.article_name[code] then
  −
language_name = make_wikilink (lang_data.article_name[code][1], label or language_name); -- language name with wikilink from override data
  −
else
  −
language_name = make_wikilink (language_name .. ' language', label or language_name); -- language name with wikilink
  −
end
  −
end
  −
 
  −
return language_name;
  −
end
 

Naviqasiya menyusu