Модуль:Separated entries: различия между версиями
Материал из ChronoWiki
Перейти к навигацииПерейти к поискум (Защитил страницу Модуль:Separated entries: критический шаблон или модуль ([Редактирование=только администраторы] (бессрочно) [Переименование=т…) |
Lirik (обсуждение | вклад) м (1 версия импортирована) |
||
(не показаны 2 промежуточные версии 2 участников) | |||
Строка 28: | Строка 28: | ||
p.main = makeInvokeFunction() | p.main = makeInvokeFunction() | ||
p.br = makeInvokeFunction('<br />') | p.br = makeInvokeFunction('<br />') | ||
+ | p.newline = makeInvokeFunction('\n') | ||
p.comma = makeInvokeFunction(mw.message.new('comma-separator'):plain()) | p.comma = makeInvokeFunction(mw.message.new('comma-separator'):plain()) | ||
return p | return p |
Текущая версия на 22:47, 29 мая 2021
Для документации этого модуля может быть создана страница Модуль:Separated entries/doc
-- This module takes positional parameters as input and concatenates them with -- an optional separator. The final separator (the "conjunction") can be -- specified independently, enabling natural-language lists like -- "foo, bar, baz and qux". local compressSparseArray = require('Module:TableTools').compressSparseArray local p = {} function p._main(args) local separator = args.separator -- Decode (convert to Unicode) HTML escape sequences, such as " " for space. and mw.text.decode(args.separator) or '' local conjunction = args.conjunction and mw.text.decode(args.conjunction) or separator -- Discard named parameters. local values = compressSparseArray(args) return mw.text.listToText(values, separator, conjunction) end local function makeInvokeFunction(separator, conjunction) return function (frame) local args = require('Module:Arguments').getArgs(frame) args.separator = separator or args.separator args.conjunction = conjunction or args.conjunction return p._main(args) end end p.main = makeInvokeFunction() p.br = makeInvokeFunction('<br />') p.newline = makeInvokeFunction('\n') p.comma = makeInvokeFunction(mw.message.new('comma-separator'):plain()) return p