Модуль:Example: различия между версиями
Перейти к навигации
Перейти к поиску
(блин, автозаменяет редактор) |
(_link; формальное дополнение к девикифицирующей функции) |
||
Строка 29: | Строка 29: | ||
local res = str | local res = str | ||
str = string.gsub(str,'%[','[') | str = string.gsub(str,'%[','[') | ||
+ | str = string.gsub(str,'%]','\') | ||
str = string.gsub(str,'<','<') | str = string.gsub(str,'<','<') | ||
+ | str = string.gsub(str,'>','>') | ||
str = string.gsub(str,'{','{') | str = string.gsub(str,'{','{') | ||
+ | str = string.gsub(str,'}','}') | ||
return str | return str | ||
end | end | ||
Строка 42: | Строка 45: | ||
local tag = args._tag or 'code' | local tag = args._tag or 'code' | ||
local sep = args._sep or '→' -- по умолчанию "→" | local sep = args._sep or '→' -- по умолчанию "→" | ||
+ | local link = require('Module:Yesno')(args._link, false) | ||
local nwt = mw.html.create(tag):tag(tag) --"no-wiki tag", внутри него шаблон не вызывается | local nwt = mw.html.create(tag):tag(tag) --"no-wiki tag", внутри него шаблон не вызывается | ||
local content = '{{' --для накопления содержимого тэга | local content = '{{' --для накопления содержимого тэга | ||
Строка 49: | Строка 53: | ||
table.remove(args,1) | table.remove(args,1) | ||
end | end | ||
− | content = content .. tname | + | if link then |
+ | content = content .. '[[Шаблон:' .. tname .. '|' .. tname .. ']]' | ||
+ | else | ||
+ | content = content .. tname | ||
+ | end | ||
local targs = {} | local targs = {} | ||
for k, v in pairs(args) do | for k, v in pairs(args) do |
Версия от 14:31, 18 января 2016
Для документации этого модуля может быть создана страница Модуль:Example/doc
local p = {}
-- используется для того, чтобы можно было удалять элементы из таблицы
local function copy(other)
local res = {}
for k,v in pairs(other) do
res[k] = v
end
return res
end
-- вызов шаблона, при ошибке возвращает пустую строку
local function expand(frame, tname, targs)
local success, result = pcall(
frame.expandTemplate,
frame,
{title = tname, args = targs}
)
if success then
return result
else
return ''
end
--return frame:expandTemplate({title = tname, args = args})
end
--предотвращает обработку вики-текста в отображении образца
local function nowiki(str)
local res = str
str = string.gsub(str,'%[','[')
str = string.gsub(str,'%]','\')
str = string.gsub(str,'<','<')
str = string.gsub(str,'>','>')
str = string.gsub(str,'{','{')
str = string.gsub(str,'}','}')
return str
end
function p.main(frame)
if not getArgs then
getArgs = require('Module:Arguments').getArgs
end
local args = copy(getArgs(frame)) --copy(frame.args)
local tag = args._tag or 'code'
local sep = args._sep or '→' -- по умолчанию "→"
local link = require('Module:Yesno')(args._link, false)
local nwt = mw.html.create(tag):tag(tag) --"no-wiki tag", внутри него шаблон не вызывается
local content = '{{' --для накопления содержимого тэга
local tname = args._template or args[1]
if args._template == nil then --имя вызываемого шаблона в неименованном первом параметре, больше его обрабатывать не надо
table.remove(args,1)
end
if link then
content = content .. '[[Шаблон:' .. tname .. '|' .. tname .. ']]'
else
content = content .. tname
end
local targs = {}
for k, v in pairs(args) do
if type(k) == 'number' then --неименованные параметры
targs[k] = v
content = content .. '|' .. nowiki(v)
elseif not k:find('^_') then --именованные параметры, исключая модификаторы внешнего вида
targs[k] = v
content = content .. '|' .. k .. '=' .. nowiki(v)
end
end
content = content .. '}}'
nwt:wikitext(content):done()
return tostring(nwt) .. ' ' .. sep .. ' ' .. tostring(expand(frame, tname, targs))
end
return p