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

De Le Wiki de Lug
Aller à la navigation Aller à la recherche
Modèle>Zebulon84
(Les fonctions qui me semblent les plus utiles...)
 
m (57 revisions imported)
 
(56 versions intermédiaires par 7 utilisateurs non affichées)
Ligne 1 : Ligne 1 :
local Outil = { }
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 Outil.trim( texte )
trim nettoie un paramètre non nommé (supprime les espaces et retours ligne au début et à la fin)
    if type( texte ) == "string" and texte ~= "" then
retourne nil si le texte est vide ou n'est pas du texte. Les nombres ne sont PAS considérés
        return mw.text.trim( texte )
comme du texte.
    end
]]
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
end


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


-- validArg renvoie le premier paramètre non vide ou nul.
-- Paramètre :
--      1 - tableau contenant tous paramètres
--      2, ... - les noms des paramètres qui doivent êtres testés.
function Outil.validArg( args, name, ... )
    local arg = args[name]
    local targ = type( arg )
    if targ == "string" and arg ~= "" then
        return mw.text.trim( arg )
    end
    if targ == 'number' and arg ~= 0
        or targ == 'table' and #arg > 0
        or arg == true
    then
        return arg
    end
    if select( '#', ... ) > 0 then
        return Outil.validArg( args, ... )
    end
end


-- extractArgs permet de récupérer les arguements du modèle,
--[[
-- ou la table transmise à la fonction par une autre fonction d'un module
notEmpty renvoie le premier paramètre non vide ou nul.
-- Paramètres :  
Paramètre :
--      1 - un objet frame ou une table contenant les paramètre
1, ... - les variables qui doivent êtres testés.
--      2, ... - une liste de nom de paramètre pour déterminé si les paramètres sont transmis par #invoke:
]]
--          le premier paramètre sera systématiquement testé.
function Outils.notEmpty( var, ... )
function Outil.extractArgs ( frame, ... )
local texte = Outils.trim( var )
    if type( frame ) == 'table' then
if texte then
        if type( frame.getParent ) == 'function' then
return texte
            if Outil.validArg( frame.args, 1, ...) then
end
                return frame.args
 
            else
local tvar = type( var )
                return frame.getParent()
 
            end
if tvar == 'table' then
        else
local nextFunc = pairs( var )  -- n'utilise pas next car non défini par mw.loadData
            return frame
if nextFunc( var ) ~= nil then
        end
return var
    else
end
        return { frame }
elseif var == true or ( tvar == 'number' and var ~= 0 ) or tvar == 'function' then
    end
return var
end
 
if select( '#', ... ) > 0 then
return Outils.notEmpty( ... )
end
end
end


-- fonction abréviation, abréviation discrète
-- paramètres : 1 = abréviation, 2 = texte, 3 = langue, abrd = abréviation discrète
local function abr( frame )
    local args = Outil.extractArgs( frame )
    if args[2] == nil then
        return args[1] or ''                -- retoune l'abréviation ou au minimum une chaine vide s'il n'y a pas de texte
    end
    local wikiText = { '<abbr' }
    if args.abrd then
        table.insert( wikiText, ' class="abbr"' )
    end
    table.insert( wikiText, ' title="' )
    table.insert( wikiText, args[2] )
    if args[3] then
        table.insert( wikiText, '" lang="' )
        table.insert( wikiText, args[3] )
    end
    table.insert( wikiText, '">' )
    table.insert( wikiText, args[1] )
    table.insert( wikiText, '</abbr>' )


    return table.concat( wikiText )
--[[
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
local args = frame:getParent().args
for k,v in pairs( frame.args ) do
args[k] = v;
end
return args
else
return frame
end
end
end




return Outil
return Outils

Version actuelle datée du 9 avril 2021 à 11:52

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
		local args = frame:getParent().args
		for k,v in pairs( frame.args ) do
			args[k] = v;
		end
		return args
	else
		return frame
	end
end


return Outils