Difference between revisions of "Module:Yesno/Documentation"
wiki_crypto>DavidL (ortho) |
m (1 revision imported) |
Latest revision as of 08:36, 2 January 2022
Ce module propose une fonction cohérente pour transformer des valeur ou chaine en booléen.
Utilisation
Le wikicode ne permet pas de saisir directement des valeur booléenne, seulement des chaine type « oui » ou « non ». Ce module les évalue et détermine une valeur booléenne true
ou false
que lua pourra utiliser. Il retourne nil
en l’absence de paramètre, pour permettre la distinction entre nil
et false
. Lorsque ce paramètre a une valeur imprévue, le module retourne la valeur par défaut ou nil
.
Syntaxe
<syntaxhighlight lang="lua">yesno(valeur, défaut, défautVide)</syntaxhighlight>
valeur
– est la valeur à tester.défaut
– valeur par défaut pour les valeurs qui ne sont ni assimilé à des booléens ninil
.défautVide
– si ce paramètre n'est pasnil
ce sera la valeur par défaut pour les chaines vides ou uniquement composées d'espaces, sauts de ligne....
Exemples
Il faut commencer par charger le module. Il ne peut être appelé que depuis un autre module Lua, il ne peut pas être appelé directement par un modèle. <syntaxhighlight lang="lua"> local yesno = require('Module:Yesno') </syntaxhighlight>
Certaines valeurs retournent toujours true
, d'autres valeurs retournent toujours false
. La valeur nil
retourne toujours nil
.
<syntaxhighlight lang="lua"> -- Ces valeurs retournent toujours true : yesno('oui') yesno('yes') yesno('y') yesno('true') yesno('1') yesno(1) yesno(true)
-- Ces valeurs retournent toujours false : yesno('non') yesno('no') yesno('n') yesno('false') yesno('0') yesno(0) yesno(false)
-- Une valeur nil retourne nil : yesno(nil) </syntaxhighlight>
Les chaines sont converties en minuscules avant d'être évaluées :
<syntaxhighlight lang="lua"> -- Ces valeurs retournent toujours true : yesno('Oui') yesno('OUI') yesno('oUi') yesno('tRuE')
-- Ces valeurs retournent toujours false : yesno('Non') yesno('NON') yesno('nOn') yesno('fALsE') </syntaxhighlight>
Une valeur par défaut peut être spécifiée pour les valeurs autres que celle listée ci-dessus. Si aucune valeur par défaut n'est fournie le module retourne nil
pour ces valeurs.
<syntaxhighlight lang="lua">
-- Ces valeurs retournent nil :
yesno('foo')
yesno({})
yesno(5)
yesno(function() return 'Ceci est une fonction.' end)
-- Ces valeurs retournent true : yesno('foo', true) yesno({}, true) yesno(5, true) yesno(function() return 'This is a function.' end, true)
-- Ces valeurs retournent "bar" : yesno('foo', 'bar') yesno({}, 'bar') yesno(5, 'bar') yesno(function() return 'This is a function.' end, 'bar') </syntaxhighlight>
Une chaine vide est évalué à la valeur du troisième paramètre s'il est défini, sinon à la valeur par défaut. <syntaxhighlight lang="lua"> yesno() -- Retourne nil. yesno(, true) -- Retourne true. yesno(, true, nil) -- Retourne true. yesno(, true, false) -- Retourne false. yesno(, 'foo', 'bar') -- Retourne 'bar'. </syntaxhighlight>
Attention, cette dernière fonctionnalité est différente du module présent sur en: qui n'a qu'une valeur par défaut.
Catégorie:Documentation de module