「モジュール:Yesno/doc」の版間の差分
m編集の要約なし |
|||
6行目: | 6行目: | ||
== 書式 == |
== 書式 == |
||
< |
<syntaxhighlight lang="lua">yesno(value, default)</syntaxhighlight> |
||
<code>value</code>は処理される入力です。ブール値またはブール値風の文字列が入力された場合は<code>true</code>または<code>false</code>を返し、<code>nil</code>が入力された場合は<code>nil</code>を返し、それ以外の場合は<code>default</code>を返します。 |
<code>value</code>は処理される入力です。ブール値またはブール値風の文字列が入力された場合は<code>true</code>または<code>false</code>を返し、<code>nil</code>が入力された場合は<code>nil</code>を返し、それ以外の場合は<code>default</code>を返します。 |
||
12行目: | 12行目: | ||
まず、モジュールをロードします。なお、このモジュールはほかのLuaモジュールでしか使用できません。テンプレートから使う場合は代わりに{{tl|yesno}}を使用してください。 |
まず、モジュールをロードします。なお、このモジュールはほかのLuaモジュールでしか使用できません。テンプレートから使う場合は代わりに{{tl|yesno}}を使用してください。 |
||
< |
<syntaxhighlight lang="lua"> |
||
local yesno = require('Module:Yesno') |
local yesno = require('Module:Yesno') |
||
</syntaxhighlight> |
|||
</source> |
|||
一部の入力値は必ず<code>true</code>を返し、一部は必ず<code>false</code>を返します。<code>nil</code>値は必ず<code>nil</code>を返します。 |
一部の入力値は必ず<code>true</code>を返し、一部は必ず<code>false</code>を返します。<code>nil</code>値は必ず<code>nil</code>を返します。 |
||
< |
<syntaxhighlight lang="lua"> |
||
-- 必ずtrueを返す |
-- 必ずtrueを返す |
||
yesno('yes') |
yesno('yes') |
||
39行目: | 39行目: | ||
-- nil値は必ずnil値を返す |
-- nil値は必ずnil値を返す |
||
yesno(nil) |
yesno(nil) |
||
</syntaxhighlight> |
|||
</source> |
|||
文字列はまず小文字に変換してから判別しています。 |
文字列はまず小文字に変換してから判別しています。 |
||
< |
<syntaxhighlight lang="lua"> |
||
-- 必ずtrueを返す |
-- 必ずtrueを返す |
||
yesno('Yes') |
yesno('Yes') |
||
57行目: | 57行目: | ||
yesno('N') |
yesno('N') |
||
yesno('fALsE') |
yesno('fALsE') |
||
</syntaxhighlight> |
|||
</source> |
|||
上記以外の入力の場合に返すdefault値を指定できます。指定しなかった場合は<code>nil</code>を返します。 |
上記以外の入力の場合に返すdefault値を指定できます。指定しなかった場合は<code>nil</code>を返します。 |
||
< |
<syntaxhighlight lang="lua"> |
||
-- nilを返す |
-- nilを返す |
||
yesno('foo') |
yesno('foo') |
||
79行目: | 79行目: | ||
yesno(5, 'bar') |
yesno(5, 'bar') |
||
yesno(function() return 'This is a function.' end, 'bar') |
yesno(function() return 'This is a function.' end, 'bar') |
||
</syntaxhighlight> |
|||
</source> |
|||
空文字列でも同じ扱いです。 |
空文字列でも同じ扱いです。 |
||
< |
<syntaxhighlight lang="lua"> |
||
yesno('') -- nilを返す |
yesno('') -- nilを返す |
||
yesno('', true) -- trueを返す |
yesno('', true) -- trueを返す |
||
yesno('', 'bar') -- "bar"を返す |
yesno('', 'bar') -- "bar"を返す |
||
</syntaxhighlight> |
|||
</source> |
|||
ウィキテキストでは一般的には空文字列をfalseとして扱うが、Luaではtrueとして扱われます。本モジュールではLuaでの挙動を採用しているため、空文字列をfalseとして扱う必要がある場合は別に処理してください。 |
ウィキテキストでは一般的には空文字列をfalseとして扱うが、Luaではtrueとして扱われます。本モジュールではLuaでの挙動を採用しているため、空文字列をfalseとして扱う必要がある場合は別に処理してください。 |
2020年7月6日 (月) 12:55時点における版
このモジュールはブール値、またはブール値風の文字列の入力を処理するための統一したインターフェースを提供します。Luaではtrue
とfalse
といったブール値がありますが、ウィキテキストにおけるテンプレートでは"yes"、"no"など文字列でしか処理できません。このモジュールはこれらの文字列を処理して、Luaで使用するためのブール値に変換します。また、nil
とfalse
を区別できるよう、nil
の入力はnil
として返します。このモジュールはブール値、数字、テーブル、関数の入力も受け付けており、ブール値とnil
として認識できなかった場合の返り値を指定することもできます。
書式
yesno(value, default)
value
は処理される入力です。ブール値またはブール値風の文字列が入力された場合はtrue
またはfalse
を返し、nil
が入力された場合はnil
を返し、それ以外の場合はdefault
を返します。
使用法
まず、モジュールをロードします。なお、このモジュールはほかのLuaモジュールでしか使用できません。テンプレートから使う場合は代わりに{{yesno}}を使用してください。
local yesno = require('Module:Yesno')
一部の入力値は必ずtrue
を返し、一部は必ずfalse
を返します。nil
値は必ずnil
を返します。
-- 必ずtrueを返す
yesno('yes')
yesno('y')
yesno('true')
yesno('t')
yesno('1')
yesno(1)
yesno(true)
-- 必ずfalseを返す
yesno('no')
yesno('n')
yesno('false')
yesno('f')
yesno('0')
yesno(0)
yesno(false)
-- nil値は必ずnil値を返す
yesno(nil)
文字列はまず小文字に変換してから判別しています。
-- 必ずtrueを返す
yesno('Yes')
yesno('YES')
yesno('yEs')
yesno('Y')
yesno('tRuE')
-- 必ずfalseを返す
yesno('No')
yesno('NO')
yesno('nO')
yesno('N')
yesno('fALsE')
上記以外の入力の場合に返すdefault値を指定できます。指定しなかった場合はnil
を返します。
-- nilを返す
yesno('foo')
yesno({})
yesno(5)
yesno(function() return 'This is a function.' end)
-- trueを返す
yesno('foo', true)
yesno({}, true)
yesno(5, true)
yesno(function() return 'This is a function.' end, true)
-- "bar"を返す
yesno('foo', 'bar')
yesno({}, 'bar')
yesno(5, 'bar')
yesno(function() return 'This is a function.' end, 'bar')
空文字列でも同じ扱いです。
yesno('') -- nilを返す
yesno('', true) -- trueを返す
yesno('', 'bar') -- "bar"を返す
ウィキテキストでは一般的には空文字列をfalseとして扱うが、Luaではtrueとして扱われます。本モジュールではLuaでの挙動を採用しているため、空文字列をfalseとして扱う必要がある場合は別に処理してください。