コンテンツにスキップ

英文维基 | 中文维基 | 日文维基 | 草榴社区

「モジュール:Yesno/doc」の版間の差分

削除された内容 追加された内容
m編集の要約なし
Cewbot (会話 | 投稿記録)
m Bot作業依頼: sourceタグをsyntaxhighlightタグに置換 (Category:非推奨のsourceタグを使用しているページ) - log
6行目: 6行目:


== 書式 ==
== 書式 ==
<source lang="lua">yesno(value, default)</source>
<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}}を使用してください。


<source lang="lua">
<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>を返します。


<source lang="lua">
<syntaxhighlight lang="lua">
-- 必ずtrueを返す
-- 必ずtrueを返す
yesno('yes')
yesno('yes')
39行目: 39行目:
-- nil値は必ずnil値を返す
-- nil値は必ずnil値を返す
yesno(nil)
yesno(nil)
</syntaxhighlight>
</source>


文字列はまず小文字に変換してから判別しています。
文字列はまず小文字に変換してから判別しています。


<source lang="lua">
<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>を返します。


<source lang="lua">
<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>


空文字列でも同じ扱いです。
空文字列でも同じ扱いです。
<source lang="lua">
<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ではtruefalseといったブール値がありますが、ウィキテキストにおけるテンプレートでは"yes"、"no"など文字列でしか処理できません。このモジュールはこれらの文字列を処理して、Luaで使用するためのブール値に変換します。また、nilfalseを区別できるよう、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として扱う必要がある場合は別に処理してください。