Module:Outils/Documentation : Différence entre versions
w.fr>Lofhi (cela fait un an que la fonction n'existe plus) |
m (1 révision importée) |
||
(2 révisions intermédiaires par 2 utilisateurs non affichées) | |||
Ligne 4 : | Ligne 4 : | ||
Fonctions exportables : | Fonctions exportables : | ||
* <code>trim( texte )</code> – similaire à mw.text.trim mais retourne nil lorsque la chaine est vide ou lorsque le paramètre n'est pas une chaine (ne génère pas d'erreur). | * <code>trim( texte )</code> – similaire à mw.text.trim mais retourne nil lorsque la chaine est vide ou lorsque le paramètre n'est pas une chaine (ne génère pas d'erreur). | ||
− | * <code>[[#extractArgs|extractArgs]]( frame | + | * <code>[[#extractArgs|extractArgs]]( frame )</code> – retourne une table avec les paramètres, à partir d'un objet frame ou d'une table. |
* <code>[[#validTextArg|validTextArg]]( args, name, ... )</code> – retourne le premier paramètre chaine non vide à partir de la table des paramètres et d'une liste de noms de paramètres. | * <code>[[#validTextArg|validTextArg]]( args, name, ... )</code> – retourne le premier paramètre chaine non vide à partir de la table des paramètres et d'une liste de noms de paramètres. | ||
* <code>[[#notEmpty|notEmpty]]( var, ... )</code> – retourne le premier élément non vide. | * <code>[[#notEmpty|notEmpty]]( var, ... )</code> – retourne le premier élément non vide. | ||
Ligne 11 : | Ligne 11 : | ||
=== extractArgs === | === extractArgs === | ||
====== Syntaxe ====== | ====== Syntaxe ====== | ||
− | <code>Outils.extractArgs( frame | + | <code>Outils.extractArgs( frame )</code> |
− | |||
* Si frame est une table simple et non un [[:mw:Extension:Scribunto/Lua reference manual/fr#L'objet Frame|objet Frame]], retourne <code>frame</code> | * Si frame est une table simple et non un [[:mw:Extension:Scribunto/Lua reference manual/fr#L'objet Frame|objet Frame]], retourne <code>frame</code> | ||
− | * Si frame est un objet créé par <code>#invoke:</code>, retourne les paramètres passés à #invoke: (en priorité) et ceux passés au modèle | + | * Si frame est un objet créé par <code>#invoke:</code>, retourne les paramètres passés à #invoke: (en priorité) et ceux passés au modèle. |
'''Attention''' : cette fonction peut modifier la table <code>frame.getParent().args</code>. S'il est probable qu'un autre module passe un objet <code>frame</code> à votre fonction, il est préférable de l'indiquer dans la documentation. | '''Attention''' : cette fonction peut modifier la table <code>frame.getParent().args</code>. S'il est probable qu'un autre module passe un objet <code>frame</code> à votre fonction, il est préférable de l'indiquer dans la documentation. | ||
====== Exemple ====== | ====== Exemple ====== | ||
− | < | + | <syntaxhighlight lang="lua"> |
− | function p.maFonction( frame | + | function p.maFonction( frame ) |
− | local args = Outils.extractArgs( frame | + | local args = Outils.extractArgs( frame ) |
return ( args[1] or 'nil' ) .. ' ' .. ( args[2] or 'nil' ) .. ' ' .. ( args['nom'] or 'nil' ) | return ( args[1] or 'nil' ) .. ' ' .. ( args[2] or 'nil' ) .. ' ' .. ( args['nom'] or 'nil' ) | ||
end | end | ||
− | </ | + | </syntaxhighlight> |
− | |||
− | |||
* appel par table : <code>p.maFonction{ 'oui', 'deux', nom = 'Zebulon84' }</code> → « oui deux Zebulon84 » | * appel par table : <code>p.maFonction{ 'oui', 'deux', nom = 'Zebulon84' }</code> → « oui deux Zebulon84 » | ||
* | * | ||
Ligne 42 : | Ligne 39 : | ||
*** <code><nowiki>{{Ma fonction |oui | deux |nom = Hexasoft}}</nowiki></code> → « oui deux Hexasoft » | *** <code><nowiki>{{Ma fonction |oui | deux |nom = Hexasoft}}</nowiki></code> → « oui deux Hexasoft » | ||
*** <code><nowiki>{{Ma fonction |oui | deux |nom = }}</nowiki></code> → « oui deux nil » | *** <code><nowiki>{{Ma fonction |oui | deux |nom = }}</nowiki></code> → « oui deux nil » | ||
− | |||
− | |||
− | |||
=== validTextArg === | === validTextArg === | ||
Ligne 58 : | Ligne 52 : | ||
====== exemple ====== | ====== exemple ====== | ||
− | < | + | <syntaxhighlight lang="lua"> |
local args = { '1', '2', 3, nom1 = nil, nom2 = '', nom3 = 'a' } | local args = { '1', '2', 3, nom1 = nil, nom2 = '', nom3 = 'a' } | ||
local v1 = Outils.validTextArg( args, 'nom1' } -- v1 = nil | local v1 = Outils.validTextArg( args, 'nom1' } -- v1 = nil | ||
Ligne 70 : | Ligne 64 : | ||
local v4 = validArg( 'nom' ) -- v4 = nil | local v4 = validArg( 'nom' ) -- v4 = nil | ||
local v5 = validArg( 'nom2', 'nom3' ) -- v5 = 'a' | local v5 = validArg( 'nom2', 'nom3' ) -- v5 = 'a' | ||
− | </ | + | </syntaxhighlight> |
=== notEmpty === | === notEmpty === | ||
Ligne 79 : | Ligne 73 : | ||
* Sont considérés comme vide : {{code|nil, false, '', ' \t \n ', 0, { }|lua}} | * Sont considérés comme vide : {{code|nil, false, '', ' \t \n ', 0, { }|lua}} | ||
* Sont considérés comme non vide : {{code|true, 'blabla', ' ', 1, { '' }, { {} }, function () end|lua}} | * Sont considérés comme non vide : {{code|true, 'blabla', ' ', 1, { '' }, { {} }, function () end|lua}} | ||
+ | |||
+ | {{Projet Scribunto}} | ||
<includeonly> | <includeonly> | ||
− | + | [[Catégorie:Module en langage Lua]] | |
</includeonly> | </includeonly> | ||
− | |||
− | |||
− |
Version actuelle datée du 5 mai 2020 à 17:20
Ce module contient différentes fonctions pratiques.
Sommaire
Résumé des fonctions
Fonctions exportables :
trim( texte )
– similaire à mw.text.trim mais retourne nil lorsque la chaine est vide ou lorsque le paramètre n'est pas une chaine (ne génère pas d'erreur).extractArgs( frame )
– retourne une table avec les paramètres, à partir d'un objet frame ou d'une table.validTextArg( args, name, ... )
– retourne le premier paramètre chaine 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
extractArgs
Syntaxe
Outils.extractArgs( frame )
- Si frame est une table simple et non un objet Frame, retourne
frame
- Si frame est un objet créé par
#invoke:
, retourne les paramètres passés à #invoke: (en priorité) et ceux passés au modèle.
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
function p.maFonction( frame )
local args = Outils.extractArgs( frame )
return ( args[1] or 'nil' ) .. ' ' .. ( args[2] or 'nil' ) .. ' ' .. ( args['nom'] or 'nil' )
end
- 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
validTextArg
Syntaxe
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 un texte valide.
exemple
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
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