モジュール:Template invocation
表示
参照読み込みのウィキテキストを生成するメタモジュールです。
使い方
[編集]まず、モジュールを読み込みます。
local mTemplateInvocation = require('Module:Template invocation')
これにより、下記の関数が利用できるようになります。
name
[編集]mTemplateInvocation.name(title)
参照読み込みで使用するページ名を取得する関数です。テンプレート名前空間の場合は名前空間名を除去して、標準名前空間の場合は冒頭にコロン(:)をつけて、それ以外の場合はページ名をそのままで返します。titleには文字列かmw.titleのオブジェクトを渡せます。
invocation
[編集]mTemplateInvocation.invocation(name, args, format)
この関数は参照読み込みのウィキテキストを生成します。
引数:
- name - 参照読み込みで使用するページ名。たとえば、Template:Reflistの場合は「Reflist」を、ジョン・ウィルクスの場合は「:ジョン・ウィルクス」を入力します。name関数の返り値をそのまま入力できます。
- args - 参照読み込みの引数をテーブルで渡します。テーブルに含まれる引数名と引数値には文字列と数字を受け付けます。
- format - 出力形式。未指定の場合はウィキテキストをそのまま返し、「nowiki」を指定した場合はパイプなどの符号が文字参照に置換されます。
使用例
[編集]- 入力:
mTemplateInvocation.invocation('foo', {'bar', 'baz', abc = 'def'})
- 出力:
{{foo|bar|baz|abc=def}}
-- This module provides functions for making MediaWiki template invocations.
local checkType = require('libraryUtil').checkType
local p = {}
------------------------------------------------------------------------
-- Name: p.name
-- Purpose: Find a template invocation name from a page name or a
-- mw.title object.
-- Description: This function detects whether a string or a mw.title
-- object has been passed in, and uses that to find a
-- template name as it is used in template invocations.
-- Parameters: title - full page name or mw.title object for the
-- template (string or mw.title object)
-- Returns: String
------------------------------------------------------------------------
function p.name(title)
if type(title) == 'string' then
title = mw.title.new(title)
if not title or #title.prefixedText == 0 or #title.interwiki > 0 then
error("name関数のtitle引数の値が不正です", 2)
end
elseif type(title) ~= 'table' or type(title.getContent) ~= 'function' then
error("name関数の第1引数は文字列かmw.titleオブジェクトでなければなりません", 2)
end
if title.namespace == 10 then
local text = title.text
local check = mw.title.new(text, 10)
-- Exclude the prefix, unless we have something like "Template:Category:Foo", which can't be abbreviated to "Category:Foo".
return check and mw.title.equals(title, check) and text or title.prefixedText
elseif title.namespace == 0 then
return ':' .. title.prefixedText
else
return title.prefixedText
end
end
------------------------------------------------------------------------
-- Name: p.invocation
-- Purpose: Construct a MediaWiki template invocation.
-- Description: This function makes a template invocation from the
-- name and the arguments given. Note that it isn't
-- perfect: we have no way of knowing what whitespace was
-- in the original invocation, the named parameters will be
-- alphabetically sorted, and any parameters with duplicate keys
-- will be removed.
-- Parameters: name - the template name, formatted as it will appear
-- in the invocation. (string)
-- args - a table of template arguments. (table)
-- format - formatting options. (string, optional)
-- Set to "nowiki" to escape, curly braces, pipes and
-- equals signs with their HTML entities. The default
-- is unescaped.
-- Returns: String
------------------------------------------------------------------------
function p.invocation(name, args, format)
checkType('invocation', 1, name, 'string')
checkType('invocation', 2, args, 'table')
checkType('invocation', 3, format, 'string', true)
-- Validate the args table and make a copy to work from. We need to
-- make a copy of the table rather than just using the original, as
-- some of the values may be erased when building the invocation.
local invArgs = {}
for k, v in pairs(args) do
local typek = type(k)
local typev = type(v)
if typek ~= 'string' and typek ~= 'number'
or typev ~= 'string' and typev ~= 'number'
then
error("invocationの第2引数の値が不正です(引数名と引数値は文字列か数字しか受け付けません)", 2)
end
invArgs[k] = v
end
-- Get the separators to use.
local seps = {
openb = '{{',
closeb = '}}',
pipe = '|',
equals = '='
}
if format == 'nowiki' then
for k, v in pairs(seps) do
seps[k] = mw.text.nowiki(v)
end
end
-- Build the invocation body with numbered args first, then named.
local ret = {}
ret[#ret + 1] = seps.openb
ret[#ret + 1] = name
for k, v in ipairs(invArgs) do
if type(v) == 'string' and v:find('=', 1, true) then
-- Likely something like 1=foo=bar which needs to be displayed as a named arg.
else
ret[#ret + 1] = seps.pipe
ret[#ret + 1] = v
invArgs[k] = nil -- Erase the key so that we don't add the value twice
end
end
local keys = {} -- sort parameter list; better than arbitrary order
for k, _ in pairs(invArgs) do
keys[#keys + 1] = k
end
table.sort(keys,
function (a, b)
-- Sort with keys of type number first, then string.
if type(a) == type(b) then
return a < b
elseif type(a) == 'number' then
return true
end
end
)
local maybeSpace = '' -- First named parameter should not be separated by a space
for _, v in ipairs(keys) do -- Add named args based on sorted parameter list
ret[#ret + 1] = maybeSpace .. seps.pipe
ret[#ret + 1] = tostring(v)
ret[#ret + 1] = seps.equals
ret[#ret + 1] = invArgs[v]
maybeSpace = ' '
end
ret[#ret + 1] = seps.closeb
return table.concat(ret)
end
return p