« Module:Outils » : différence entre les versions
Aller à la navigation
Aller à la recherche
Modèle>Zebulon84 (extractArgs : paramètre spécifique pour ne pas récupérer les paramètres du modèle) |
m (57 revisions imported) |
||
| (37 versions intermédiaires par 7 utilisateurs non affichées) | |||
| Ligne 1 : | Ligne 1 : | ||
local | local Outils = { } | ||
--[[ | --[[ | ||
trim nettoie un paramètre non nommé (supprime les espaces et retours ligne au début et à la fin) | trim nettoie un paramètre non nommé (supprime les espaces et retours ligne au début et à la fin) | ||
retourne | retourne nil si le texte est vide ou n'est pas du texte. Les nombres ne sont PAS considérés | ||
comme du texte. | comme du texte. | ||
]] | ]] | ||
function Outils.trim( texte ) | function Outils.trim( texte ) | ||
if type( texte ) == 'string' then | if type( texte ) == 'string' and texte ~= '' then | ||
texte = | texte = texte:gsub( '^%s*(%S?.-)%s*$', '%1' ) | ||
if texte ~= '' then | if texte ~= '' then | ||
return texte | return texte | ||
end | end | ||
end | end | ||
return nil | |||
end | end | ||
--[[ | --[[ | ||
validTextArg renvoit le premier paramètre chaine non vide | validTextArg renvoit le premier paramètre chaine non vide | ||
Paramètre : | Paramètre : | ||
1 - tableau contenant tous paramètres | 1 - tableau contenant tous paramètres | ||
2, ... - les noms des paramètres qui doivent êtres testés. | 2, ... - les noms des paramètres qui doivent êtres testés. | ||
]] | ]] | ||
function Outils.validTextArg( args, name, ... ) | function Outils.validTextArg( args, name, ... ) | ||
local texte = Outils.trim( args[name] ) | local texte = Outils.trim( args[name] ) | ||
if texte then | if texte then | ||
| Ligne 36 : | Ligne 32 : | ||
return Outils.validTextArg( args, ... ) | return Outils.validTextArg( args, ... ) | ||
end | end | ||
return nil | |||
end | end | ||
--[[ | --[[ | ||
notEmpty renvoie le premier paramètre non vide ou nul. | notEmpty renvoie le premier paramètre non vide ou nul. | ||
Paramètre : | Paramètre : | ||
1, ... - les variables qui doivent êtres testés. | 1, ... - les variables qui doivent êtres testés. | ||
]] | ]] | ||
function Outils.notEmpty( var, ... ) | function Outils.notEmpty( var, ... ) | ||
local texte = Outils.trim( var ) | |||
if texte then | |||
return texte | |||
end | |||
local tvar = type( var ) | local tvar = type( var ) | ||
if | if tvar == 'table' then | ||
local nextFunc = pairs( var ) -- n'utilise pas next car non défini par mw.loadData | local nextFunc = pairs( var ) -- n'utilise pas next car non défini par mw.loadData | ||
if nextFunc( var ) ~= nil then | if nextFunc( var ) ~= nil then | ||
return var | return var | ||
end | end | ||
elseif var == true or ( tvar == 'number' and var ~= 0 ) or tvar == 'function' then | elseif var == true or ( tvar == 'number' and var ~= 0 ) or tvar == 'function' then | ||
return var | return var | ||
end | end | ||
if select( '#', ... ) > 0 then | if select( '#', ... ) > 0 then | ||
return Outils.notEmpty( | return Outils.notEmpty( ... ) | ||
end | end | ||
end | end | ||
--[[ | --[[ | ||
extractArgs permet de récupérer les | extractArgs permet de récupérer les arguments du modèle, | ||
ou la table transmise à la fonction par une autre fonction d'un module | ou la table transmise à la fonction par une autre fonction d'un module | ||
Paramètre : | |||
1 - un objet frame ou une table contenant | 1 - un objet frame ou une table contenant les paramètres | ||
]] | ]] | ||
function Outils.extractArgs ( frame | function Outils.extractArgs ( frame ) | ||
if type( frame.getParent ) == 'function' then | |||
local args = frame:getParent().args | |||
for k,v in pairs( frame.args ) do | |||
args[k] = v; | |||
end | end | ||
return args | |||
return | |||
else | else | ||
return frame | |||
end | end | ||
end | end | ||
return Outils | return Outils | ||
Version actuelle datée du 9 avril 2021 à 11:52
La documentation pour ce module peut être créée à Module:Outils/doc
local Outils = { }
--[[
trim nettoie un paramètre non nommé (supprime les espaces et retours ligne au début et à la fin)
retourne nil si le texte est vide ou n'est pas du texte. Les nombres ne sont PAS considérés
comme du texte.
]]
function Outils.trim( texte )
if type( texte ) == 'string' and texte ~= '' then
texte = texte:gsub( '^%s*(%S?.-)%s*$', '%1' )
if texte ~= '' then
return texte
end
end
return nil
end
--[[
validTextArg renvoit le premier paramètre chaine non vide
Paramètre :
1 - tableau contenant tous paramètres
2, ... - les noms des paramètres qui doivent êtres testés.
]]
function Outils.validTextArg( args, name, ... )
local texte = Outils.trim( args[name] )
if texte then
return texte
end
if select( '#', ... ) > 0 then
return Outils.validTextArg( args, ... )
end
return nil
end
--[[
notEmpty renvoie le premier paramètre non vide ou nul.
Paramètre :
1, ... - les variables qui doivent êtres testés.
]]
function Outils.notEmpty( var, ... )
local texte = Outils.trim( var )
if texte then
return texte
end
local tvar = type( var )
if tvar == 'table' then
local nextFunc = pairs( var ) -- n'utilise pas next car non défini par mw.loadData
if nextFunc( var ) ~= nil then
return var
end
elseif var == true or ( tvar == 'number' and var ~= 0 ) or tvar == 'function' then
return var
end
if select( '#', ... ) > 0 then
return Outils.notEmpty( ... )
end
end
--[[
extractArgs permet de récupérer les arguments du modèle,
ou la table transmise à la fonction par une autre fonction d'un module
Paramètre :
1 - un objet frame ou une table contenant les paramètres
]]
function Outils.extractArgs ( frame )
if type( frame.getParent ) == 'function' then
local args = frame:getParent().args
for k,v in pairs( frame.args ) do
args[k] = v;
end
return args
else
return frame
end
end
return Outils