« Module:Outils » : différence entre les versions

De Le Wiki de Lug
Aller à la navigation Aller à la recherche
Modèle>Od1n
m (indentation suite à la modif précédente)
Modèle>Od1n
m (proprage)
Ligne 65 : Ligne 65 :


--[[
--[[
extractArgs permet de récupérer les arguements du modèle,  
extractArgs permet de récupérer les arguments du modèle,  
ou la table transmise à la fonction par une autre fonction d'un module
ou la table transmise à la fonction par une autre fonction d'un module
Paramètre :  
Paramètre :  
1 - un objet frame ou une table contenant les paramètre
1 - un objet frame ou une table contenant les paramètres
]]
]]
function Outils.extractArgs ( frame )
function Outils.extractArgs ( frame )
Ligne 75 : Ligne 75 :
return frame.args
return frame.args
else
else
local args = frame:getParent().args;
local args = frame:getParent().args
for k,v in pairs( frame.args ) do
for k,v in pairs( frame.args ) do
args[k] = v;
args[k] = v;
Ligne 82 : Ligne 82 :
end
end
else
else
return frame  
return frame
end
end
end
end

Version du 27 mars 2019 à 16:24

La documentation pour ce module peut être créée à Module:Outils/doc

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'est pas du texte. Les nombres ne sont PAS considérés 
	comme du texte.
]]
function Outils.trim( texte )
	if type( texte ) == 'string' and texte ~= '' then
		texte = texte:gsub( '^%s*(%S?.-)%s*$', '%1' )
		if texte ~= '' then
			return texte
		end
	end
	return nil
end


--[[
	validTextArg renvoit le premier paramètre chaine non vide
	Paramètre : 
		1 - tableau contenant tous paramètres
		2, ... - les noms des paramètres qui doivent êtres testés.
]]
function Outils.validTextArg( args, name, ... ) 
	local texte = Outils.trim( args[name] )
	if texte then
		return texte
	end
	if select( '#', ... ) > 0 then
		return Outils.validTextArg( args, ... )
	end
	return nil
end


--[[
	notEmpty renvoie le premier paramètre non vide ou nul. 
	Paramètre : 
		1, ... - les variables qui doivent êtres testés.
]]
function Outils.notEmpty( var, ... )
	local texte = Outils.trim( var )
	if texte then
		return texte
	end

	local tvar = type( var )
	
	if tvar == 'table' then
		local nextFunc = pairs( var )   -- n'utilise pas next car non défini par mw.loadData
		if nextFunc( var ) ~= nil then
			return var
		end 
	elseif var == true or ( tvar == 'number' and var ~= 0 ) or tvar == 'function' then
		return var
	end
	
	if select( '#', ... ) > 0 then
		return Outils.notEmpty(  ... )
	end
end


--[[
	extractArgs permet de récupérer les arguments du modèle, 
	ou la table transmise à la fonction par une autre fonction d'un module
	Paramètre : 
		1 - un objet frame ou une table contenant les paramètres
]]
function Outils.extractArgs ( frame )
	if type( frame.getParent ) == 'function' then
		if Outils.notEmpty( frame.args.invokeArgsOnly ) then
			return frame.args
		else
			local args = frame:getParent().args
			for k,v in pairs( frame.args ) do
				args[k] = v;
			end
			return args
		end
	else
		return frame
	end
end


return Outils