Module:Other uses

local mHatnote = require('Module:Hatnote') local mHatlist = require('Module:Hatnote list') local mArguments --initialize lazily local mTableTools --initialize lazily local libraryUtil = require('libraryUtil') local checkType = libraryUtil.checkType local p = {}

-- Produces standard implementation function p.otheruses(frame) mArguments = require('Dev:Arguments') mTableTools = require('Dev:TableTools') local args = mTableTools.compressSparseArray(mArguments.getArgs(frame)) local title = mw.title.getCurrentTitle.prefixedText return p._otheruses(args, {title=title}) end

--Implements "other [x]" templates with otherText supplied at invocation function p.otherX(frame) mArguments = require('Dev:Arguments') mTableTools = require('Dev:TableTools') local x = frame.args[1] local args = mTableTools.compressSparseArray(		mArguments.getArgs(frame, {parentOnly = true})	) local options = { title = mw.title.getCurrentTitle.prefixedText, otherText = x	} return p._otheruses(args, options) end

-- Main generator function p._otheruses(args, options) --Type-checks and defaults checkType('_otheruses', 1, args, 'table', true) args = args or {} 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 local emptyArgs = true for k, v in pairs(args) do		if type(k) == 'number' then emptyArgs = false break end end if emptyArgs then args = { options.defaultPage or			mHatnote.disambiguate(options.title, options.disambiguator) }	end --Generate and return hatnote local text = mHatlist.forSeeTableToString return mHatnote._hatnote(text) end

return p