Module:Outils/Documentation
Ceci est la page de documentation pour Module:Outils
Ce module contient différentes fonction pratiques.
Résumé des fonctions
[modifier le wikicode]Fonctions exportables :
trim( texte )
– similaire à mw.text.trim mais retourne nil lorsque la chaîne est vide ou lorsque le paramètre n’est pas une chaîne (ne génère pas d’erreur).erreur( texte )
– destiné à afficher un message d’erreur en gros et rouge. Retourne la chaîne transmise dans un span de class "error". Par défaut erreur : raison non précisée.extractArgs( frame, ... )
– retourne une table avec les paramètres, à partir d’un objet frame, d’une table ou d’une liste de paramètre.validTextArg( args, name, ... )
– retourne le premier paramètre chaîne non vide à partir de la table des paramètres et d’une liste de noms de paramètres.notEmpty( var, ... )
– retourne le premier élément non vide.
Détail par fonction
[modifier le wikicode]extractArgs
[modifier le wikicode]Syntaxe
[modifier le wikicode]Outils.extractArgs( frame, ... )
- si frame n’est pas une table, retourne
{ frame, ... }
- Si frame est une table simple et non une objet Frame, retourne
frame
- Si frame est un objet créé par
#invoke:
, retourne les paramètres passé à #invoke: (en priorité) et ceux passées au modèle. Si le paramètreinvokeArgsOnly
n’est pas vide, seul les paramètres transmis à invoke seront utilisés.
Attention : cette fonction peut modifier la table frame.getParent().args
. S’il est probable qu’un autre module passe un objet frame
à votre fonction, il est préférable de l’indiquer dans la documentation.
Exemple
[modifier le wikicode]function p.maFonction( frame, ... )
local args = Outils.extractArgs( frame, ... )
return ( args[1] or 'nil' ) .. ' ' .. ( args[2] or 'nil' ) .. ' ' .. ( args['nom'] or 'nil' )
end
- appel direct :
p.maFonction( 'oui', 'deux', 'Zebulon84' )
→ « oui deux nil » (impossible de transmettre un paramètre nommé) - appel par table :
p.maFonction{ 'oui', 'deux', nom = 'Zebulon84' }
→ « oui deux Zebulon84 » - appel par
#invoke:
:{{#invoke:p |maFonction |oui |2 |nom = Zebulon84}}
→ « oui deux Zebulon84 » - appel par modèle
{{Ma fonction}}
:- le modèle contient
{{#invoke:p |maFonction}}
,{{Ma fonction|oui | deux |nom= Zebulon84}}
→ « oui deux Zebulon84 »
- le modèle contient
{{#invoke:p |maFonction |nom = Zebulon84}}
{{Ma fonction |oui | deux }}
→ « oui deux Zebulon84 »{{Ma fonction |oui | deux |nom = Hexasoft}}
→ « oui deux Zebulon84 »
- le modèle contient
{{#invoke:p |maFonction |nom = {{{nom|Zebulon84}}} }}
{{Ma fonction |oui | deux }}
→ « oui deux Zebulon84 »{{Ma fonction |oui | deux |nom = Hexasoft}}
→ « oui deux Hexasoft »{{Ma fonction |oui | deux |nom = }}
→ « oui deux nil »
- le modèle contient
{{#invoke:p |maFonction |nom = {{{nom|Zebulon84}}} |invokeArgsOnly = oui}}
{{Ma fonction |oui | deux }}
→ « nil nil Zebulon84 »{{Ma fonction |oui | deux |nom = Hexasoft}}
→ « nil nil Hexasoft»
- le modèle contient
validTextArg
[modifier le wikicode]Syntaxe
[modifier le wikicode]Outils.validTextArg( args, name, ... )
Retourne args.name si c’est un texte valide. Sinon teste les autres éléments transmis à la fonction. S’il n’y en a pas ou s’ils ne correspondent pas à un texte valide dans la table args, retourne nil
.
Cette fonction est pratique pour obtenir le contenu d’un paramètre pouvant avoir plusieurs noms.
Attention : les nombres (type 'number') ne sont pas considérés comme du texte valide.
exemple
[modifier le wikicode]local args = { '1', '2', 3, nom1 = nil, nom2 = '', nom3 = 'a' }
local v1 = Outils.validTextArg( args, 'nom1' } -- v1 = nil
local v2 = Outils.validTextArg( args, 'nom1', 'nom2', 'nom3' ) -- v2 = 'a'
local v3 = Outils.validTextArg( args, 3, 2, 1 ) -- v3 = '2'
local function validArg( ... )
return Outils.validTextArg( args, ... }
end
local v4 = validArg( 'nom' ) -- v4 = nil
local v5 = validArg( 'nom2', 'nom3' ) -- v5 = 'a'
notEmpty
[modifier le wikicode]Outils.notEmpty( var, ... )
Retourne le premier élément non vide, sinon retourne nil.
- Sont considérés comme vide : }
nil, false, '', ' \t \n ', 0, {
- Sont considérés comme non vide :
true, 'blabla', ' ', 1, { '' }, { {} }, function () end