Module:Format title
Usage
Links and formats article titles in body text for use on disambiguation or other pages. Used by templates {{fti}} and {{ftq}}.
- Function p._italic italicizes the non-parenthetical portion (or, optionally, only the parenthetical portion) of its argument (typically a page name).
- Function p._quotes encloses the non-parenthetical portion (or, optionally, only the parenthetical portion) of its argument (typically a page name) in quotation marks.
{{#invoke:Format title|function_name|article_title}}
local getArgs = require('Module:Arguments').getArgs local p = {} local function makeInvokeFunc(funcName) return function (frame) local args = getArgs(frame) return p[funcName](args) end end p.italic = makeInvokeFunc('_italic') function p._italic(args) local title = args[1] local invert = args[2] local prefix, parenthetical = mw.ustring.match(title, '^(.+) %(([^%(%)]+)%)$') local result if prefix and parenthetical and args.all ~= 'yes' then if invert == 'i' or invert == 'inv' or invert == 'invert' then result = string.format("%s \(\'\'%s\'\'\)", prefix, parenthetical) else result = string.format("\'\'%s\'\' \(%s\)", prefix, parenthetical) end else result = string.format("\'\'%s\'\'", title) end return result end p.quotes = makeInvokeFunc('_quotes') function p._quotes(args) local title = args[1] local invert = args[2] local prefix, parenthetical = mw.ustring.match(title, '^(.+) %(([^%(%)]+)%)$') local result if prefix and parenthetical and args.all ~= 'yes' then if invert == 'i' or invert == 'inv' or invert == 'invert' then result = string.format("%s \(\"%s\"\)", prefix, parenthetical) else result = string.format("\"%s\" \(%s\)", prefix, parenthetical) end else result = string.format("\"%s\"", title) end return result end return p