模組:Yesno
外觀
簡介
這個模塊提供一個統一的布爾式輸入界面。雖然Lua語言支持布爾式,但是維基代碼只支持通過類似“yes”和“no”這樣的字符串來表達布爾式。這個模塊的作用就是將這類字符串轉換為Lua語言中的布爾式。它同樣可以返回無效的nil,從而將nil與false區分開來。這個模塊同樣支持其他的lua元素,比如布爾式、數字、表和函數。如果輸入的值無法返回布爾式或者nil值,它同樣可以返回一個默認值。
語法
yesno(value, default)
value是一個待測參數。布爾式一般由true和false兩個值構成。空對象為nil。其他值則會返回default參數。
用法
首先,載入模塊。注意,它只能為其他Lua模塊調用而不能為模板調用。
local yesno = require('Module:Yesno')
-- Function allowing for consistent treatment of boolean-like wikitext input.
-- It works similarly to the template {{yesno}}.
return function (val, default)
val = type(val) == 'string' and mw.ustring.lower(val) or val -- put in lower case
if val == nil then
return nil
elseif val == false or val == 'no' or val == 'n' or val == 'false' or tonumber(val) == 0 then
return false
elseif val == true or val == 'yes' or val == 'y' or val == 'true' or tonumber(val) == 1 then
return true
else
return default
end
end