Module:Yesno : Différence entre versions

De Lagny-sur-Marne Wiki
Aller à : navigation, rechercher
(Copie de en:Module:Yesno)
 
m (A protégé « Module:Yesno » : Modèle très utilisé : plus 1,5 million d'inclusions ([Modifier=Autoriser uniquement les administrateurs] (infini) [Renommer=Autoriser uniquement les administrateurs] (infini)))
 
(4 révisions intermédiaires par le même utilisateur non affichées)
Ligne 2 : Ligne 2 :
 
-- It works similarly to the template {{yesno}}.
 
-- It works similarly to the template {{yesno}}.
  
return function (val, default)
+
return function (val, default, emptyDefault)
 
-- If your wiki uses non-ascii characters for any of "yes", "no", etc., you
 
-- If your wiki uses non-ascii characters for any of "yes", "no", etc., you
 
-- should replace "val:lower()" with "mw.ustring.lower(val)" in the
 
-- should replace "val:lower()" with "mw.ustring.lower(val)" in the
Ligne 12 : Ligne 12 :
 
or val == 'yes'
 
or val == 'yes'
 
or val == 'y'
 
or val == 'y'
 +
or val == 'oui'
 +
or val == 'o'
 
or val == 'true'
 
or val == 'true'
 
or tonumber(val) == 1
 
or tonumber(val) == 1
Ligne 19 : Ligne 21 :
 
or val == 'no'
 
or val == 'no'
 
or val == 'n'
 
or val == 'n'
 +
or val == 'non'
 
or val == 'false'
 
or val == 'false'
 
or tonumber(val) == 0
 
or tonumber(val) == 0
 
then
 
then
 
return false
 
return false
 +
elseif emptyDefault ~= nil and type(val) == 'string' and val:match( '^%s*$' ) then
 +
return emptyDefault
 
else
 
else
 
return default
 
return default
 
end
 
end
 
end
 
end

Version actuelle datée du 12 janvier 2016 à 11:05

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

-- Function allowing for consistent treatment of boolean-like wikitext input.
-- It works similarly to the template {{yesno}}.

return function (val, default, emptyDefault)
	-- If your wiki uses non-ascii characters for any of "yes", "no", etc., you
	-- should replace "val:lower()" with "mw.ustring.lower(val)" in the
	-- following line.
	val = type(val) == 'string' and val:lower() or val
	if val == nil then
		return nil
	elseif val == true 
		or val == 'yes'
		or val == 'y'
		or val == 'oui'
		or val == 'o'
		or val == 'true'
		or tonumber(val) == 1
	then
		return true
	elseif val == false
		or val == 'no'
		or val == 'n'
		or val == 'non'
		or val == 'false'
		or tonumber(val) == 0
	then
		return false
	elseif emptyDefault ~= nil and type(val) == 'string' and val:match( '^%s*$' ) then
		return emptyDefault
	else
		return default
	end
end