Module:Other uses
Module documentation[create]
You might want to create a documentation page for this Scribunto module. Editors can experiment in this module's sandbox (create | mirror) and testcases (create) pages. Please add categories to the /doc subpage. Subpages of this module. |
local mHatnote = require('Module:Hatnote')
local mArguments --initialize lazily
local mTableTools --initialize lazily
local libraryUtil = require('libraryUtil')
local checkType = libraryUtil.checkType
local p = {}
--Produces standard {{other uses}} implementation
function p.otheruses(frame)
mArguments = require('Module:Arguments')
mTableTools = require('Module:TableTools')
local args = mTableTools.compressSparseArray(mArguments.getArgs(frame))
local title = mw.title.getCurrentTitle().text
return p._otheruses(args, {title=title})
end
--Main generator
--Two parameters, args and options, each tables:
-- * args: can be empty or nil, in which case the defaults kick in.
-- Otherwise assumed to be a table of unbracketed page strings, no table gaps
-- * options: must not be nil; it must have in a "defaultPage" or "title" option,
-- since this function doesn't use a frame object to do the defaulting itself.
-- Summary of options available:
-- * defaultPage: sets full default "other uses" target; overrides title and disambiguator
-- * title: sets title assumed that gets the suffix added
-- * disambiguator: sets default text appearing in parens, defaults to "disambiguation"
-- * otherText: allows setting more "other" options, defaults to "uses"
function p._otheruses(args, options)
checkType('_otheruses', 1, args, 'table', true)
if not args then args = {} end
checkType('_otheruses', 2, options, 'table')
if not (options.defaultPage or options.title) then
error('No default title data provided in "_otheruses" options table', 2)
end
if #args == 0 then
args = {
options.defaultPage or
(options.title .. ' (' .. (options.disambiguator or 'disambiguation') .. ')')
}
end
local forOther = 'For other ' .. (options.otherText or 'uses') .. ', '
local see = 'see ' .. mw.text.listToText(mHatnote.formatPages(unpack(args))) .. "."
local text = forOther .. see
return mHatnote._hatnote(text)
end
return p