<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="fr">
	<id>https://wiki.deprelledelanieppe.be/mediawiki/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.deprelledelanieppe.be/mediawiki/index.php?action=history&amp;feed=atom&amp;title=Module%3AOutils"/>
	<link rel="alternate" type="text/html" href="https://wiki.deprelledelanieppe.be/mediawiki/index.php?title=Module:Outils&amp;action=history"/>
	<updated>2026-04-28T13:47:50Z</updated>
	<subtitle>Historique des versions pour cette page sur le wiki</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki.deprelledelanieppe.be/mediawiki/index.php?title=Module:Outils&amp;diff=357&amp;oldid=prev</id>
		<title>Apn : Page créée avec « 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;es... »</title>
		<link rel="alternate" type="text/html" href="https://wiki.deprelledelanieppe.be/mediawiki/index.php?title=Module:Outils&amp;diff=357&amp;oldid=prev"/>
		<updated>2019-02-08T11:07:09Z</updated>

		<summary type="html">&lt;p&gt;Page créée avec « 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;es... »&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nouvelle page&lt;/b&gt;&lt;/p&gt;&lt;div&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 = texte:gsub( &amp;#039;^%s*(%S?.-)%s*$&amp;#039;, &amp;#039;%1&amp;#039; )&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 arguements 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ètres : &lt;br /&gt;
		1 - un objet frame ou une table contenant les paramètre&lt;br /&gt;
		2, ...  - une liste de nom de paramètre pour déterminé si les paramètres sont transmis &lt;br /&gt;
			par #invoke. Le premier paramètre de frame sera systématiquement testé.&lt;br /&gt;
]]&lt;br /&gt;
function Outils.extractArgs ( frame, ... )&lt;br /&gt;
	if type( frame ) == &amp;#039;table&amp;#039; then&lt;br /&gt;
		if type( frame.getParent ) == &amp;#039;function&amp;#039; then&lt;br /&gt;
			if Outils.notEmpty( frame.args.invokeArgsOnly ) then&lt;br /&gt;
				return frame.args&lt;br /&gt;
			else&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;
			end&lt;br /&gt;
		else&lt;br /&gt;
			return frame &lt;br /&gt;
		end&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>Apn</name></author>
	</entry>
</feed>