Module:Outils/Documentation : Différence entre versions

De Wikonsult
Sauter à la navigation Sauter à la recherche
m (1 révision importée)
m (1 révision importée)
 
(Une révision intermédiaire par un autre utilisateur non affichée)
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> – retourne une table avec les paramètres, à partir d'un objet frame, d'une table ou d'une liste de paramètres.
+
* <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>   
+
<code>Outils.extractArgs( frame )</code>   
* Si frame n'est pas une table, 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 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 le paramètre <code>invokeArgsOnly </code> n'est pas vide, seul les paramètres transmis à invoke seront utilisés.
+
* 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 ======
<source lang=lua>
+
<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
</source>
+
</syntaxhighlight>
  
* appel direct : <code>p.maFonction( 'oui', 'deux', 'Zebulon84' )</code> → « oui deux nil »  (impossible de transmettre un paramètre nommé)
 
*
 
 
* 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 »
** le modèle contient  <code><nowiki>{{#invoke:p |maFonction |nom = {{{nom|Zebulon84}}} |invokeArgsOnly = oui}}</nowiki></code>
 
*** <code><nowiki>{{Ma fonction |oui | deux }}</nowiki></code> → « nil nil Zebulon84 »
 
*** <code><nowiki>{{Ma fonction |oui | deux |nom = Hexasoft}}</nowiki></code> → « nil nil Hexasoft»
 
  
 
=== validTextArg ===
 
=== validTextArg ===
Ligne 58 : Ligne 52 :
  
 
====== exemple ======
 
====== exemple ======
<source lang=lua>
+
<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'
</source>
+
</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', '&nbsp;', 1, { '' },  { {} }, function () end|lua}}
 
* Sont considérés comme non vide : {{code|true, 'blabla', '&nbsp;', 1, { '' },  { {} }, function () end|lua}}
 +
 +
{{Projet Scribunto}}
  
 
<includeonly>
 
<includeonly>
{{Projet Scribunto}}
+
[[Catégorie:Module en langage Lua]]
 
</includeonly>
 
</includeonly>
<noinclude>
 
[[Catégorie:Documentation de module|{{BASEPAGENAME}}]]
 
</noinclude>
 

Version actuelle datée du 5 mai 2020 à 18:20

Ce module contient différentes fonctions pratiques.

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 »

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', '&nbsp;', 1, { '' }, { {} }, function () end