<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="fr">
	<id>https://wiki.noethoumy.fr/index.php?action=history&amp;feed=atom&amp;title=Module%3AOutils</id>
	<title>Module:Outils - Historique des versions</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.noethoumy.fr/index.php?action=history&amp;feed=atom&amp;title=Module%3AOutils"/>
	<link rel="alternate" type="text/html" href="https://wiki.noethoumy.fr/index.php?title=Module:Outils&amp;action=history"/>
	<updated>2026-04-27T18:19:33Z</updated>
	<subtitle>Historique des versions pour cette page sur le wiki</subtitle>
	<generator>MediaWiki 1.41.1</generator>
	<entry>
		<id>https://wiki.noethoumy.fr/index.php?title=Module:Outils&amp;diff=304&amp;oldid=prev</id>
		<title>Jaggerwock : Page créée avec « 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&#039;est pas du texte. Les nombres ne sont PAS considérés 	comme du texte.  function Outils.trim( texte ) 	if type( texte ) == &#039;string&#039; and texte ~= &#039;&#039; then 		texte = mwTrim( texte ) 		if texte ~= &#039;&#039; then 			return texte 		end 	end 	return nil end   --[[ 	validTextArg re... »</title>
		<link rel="alternate" type="text/html" href="https://wiki.noethoumy.fr/index.php?title=Module:Outils&amp;diff=304&amp;oldid=prev"/>
		<updated>2024-09-20T14:04:08Z</updated>

		<summary type="html">&lt;p&gt;Page créée avec « 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&amp;#039;est pas du texte. Les nombres ne sont PAS considérés 	comme du texte. ]] function Outils.trim( texte ) 	if type( texte ) == &amp;#039;string&amp;#039; and texte ~= &amp;#039;&amp;#039; then 		texte = mwTrim( texte ) 		if texte ~= &amp;#039;&amp;#039; then 			return texte 		end 	end 	return nil end   --[[ 	validTextArg re... »&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nouvelle page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;local mwTrim = mw.text.trim&lt;br /&gt;
&lt;br /&gt;
local Outils = { }&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
	trim nettoie un paramètre non nommé (supprime les espaces et retours ligne au début et à la fin)&lt;br /&gt;
	retourne nil si le texte est vide ou n&amp;#039;est pas du texte. Les nombres ne sont PAS considérés&lt;br /&gt;
	comme du texte.&lt;br /&gt;
]]&lt;br /&gt;
function Outils.trim( texte )&lt;br /&gt;
	if type( texte ) == &amp;#039;string&amp;#039; and texte ~= &amp;#039;&amp;#039; then&lt;br /&gt;
		texte = mwTrim( texte )&lt;br /&gt;
		if texte ~= &amp;#039;&amp;#039; then&lt;br /&gt;
			return texte&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
	validTextArg renvoit le premier paramètre chaine non vide&lt;br /&gt;
	Paramètre :&lt;br /&gt;
		1 - tableau contenant tous paramètres&lt;br /&gt;
		2, ... - les noms des paramètres qui doivent êtres testés.&lt;br /&gt;
]]&lt;br /&gt;
function Outils.validTextArg( args, name, ... )&lt;br /&gt;
	local texte = Outils.trim( args[name] )&lt;br /&gt;
	if texte then&lt;br /&gt;
		return texte&lt;br /&gt;
	end&lt;br /&gt;
	if select( &amp;#039;#&amp;#039;, ... ) &amp;gt; 0 then&lt;br /&gt;
		return Outils.validTextArg( args, ... )&lt;br /&gt;
	end&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
	notEmpty renvoie le premier paramètre non vide ou nul.&lt;br /&gt;
	Paramètre :&lt;br /&gt;
		1, ... - les variables qui doivent êtres testés.&lt;br /&gt;
]]&lt;br /&gt;
function Outils.notEmpty( var, ... )&lt;br /&gt;
	local texte = Outils.trim( var )&lt;br /&gt;
	if texte then&lt;br /&gt;
		return texte&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local tvar = type( var )&lt;br /&gt;
&lt;br /&gt;
	if tvar == &amp;#039;table&amp;#039; then&lt;br /&gt;
		local nextFunc = pairs( var )   -- n&amp;#039;utilise pas next car non défini par mw.loadData&lt;br /&gt;
		if nextFunc( var ) ~= nil then&lt;br /&gt;
			return var&lt;br /&gt;
		end&lt;br /&gt;
	elseif var == true or ( tvar == &amp;#039;number&amp;#039; and var ~= 0 ) or tvar == &amp;#039;function&amp;#039; then&lt;br /&gt;
		return var&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if select( &amp;#039;#&amp;#039;, ... ) &amp;gt; 0 then&lt;br /&gt;
		return Outils.notEmpty( ... )&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
	extractArgs permet de récupérer les arguments du modèle,&lt;br /&gt;
	ou la table transmise à la fonction par une autre fonction d&amp;#039;un module&lt;br /&gt;
	Paramètre :&lt;br /&gt;
		1 - un objet frame ou une table contenant les paramètres&lt;br /&gt;
]]&lt;br /&gt;
function Outils.extractArgs ( frame )&lt;br /&gt;
	if type( frame.getParent ) == &amp;#039;function&amp;#039; then&lt;br /&gt;
		local args = frame:getParent().args&lt;br /&gt;
		for k,v in pairs( frame.args ) do&lt;br /&gt;
			args[k] = v;&lt;br /&gt;
		end&lt;br /&gt;
		return args&lt;br /&gt;
	else&lt;br /&gt;
		return frame&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
return Outils&lt;/div&gt;</summary>
		<author><name>Jaggerwock</name></author>
	</entry>
</feed>