« Module:Outils » : différence entre les versions
(code de trim plus performant ; quand on multiplie par le nombre d'utilisations de cette fonction sur tout le wiki, le gain doit être intéressant) |
m (1 version importée) |
||
(2 versions intermédiaires par 2 utilisateurs non affichées) | |||
Ligne 1 : | Ligne 1 : | ||
local mwTrim = mw.text.trim | |||
local Outils = { } | local Outils = { } | ||
Ligne 9 : | Ligne 11 : | ||
function Outils.trim( texte ) | function Outils.trim( texte ) | ||
if type( texte ) == 'string' and texte ~= '' then | if type( texte ) == 'string' and texte ~= '' then | ||
texte = mwTrim( texte ) | |||
texte = | |||
if texte ~= '' then | if texte ~= '' then | ||
return texte | return texte |
Dernière version du 7 janvier 2024 à 15:05
La documentation pour ce module peut être créée à Module:Outils/doc
local mwTrim = mw.text.trim 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 = mwTrim( texte ) 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