Jump to content
Wikipedia The Free Encyclopedia

Module:Namespace detect/data/sandbox

From Wikipedia, the free encyclopedia
Module documentation[view] [edit] [history] [purge]
[画像:Ready for use] This module is rated as ready for general use. It has reached a mature form and is thought to be relatively bug-free and ready for use wherever appropriate. It is ready to mention on help pages and other Wikipedia resources as an option for new users to learn. To reduce server load and bad output, it should be improved by sandbox testing rather than repeated trial-and-error editing.
[画像:Protected] This module is subject to page protection. It is a highly visible module in use by a very large number of pages, or is substituted very frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it is protected from editing.
[画像:Warning] This Lua module is used in system messages, and on approximately 4,920,000 pages, or roughly 8% of all pages.
Changes to it can cause immediate changes to the Wikipedia user interface.
To avoid major disruption and server load, any changes should be tested in the module's /sandbox or /testcases subpages, or in your own module sandbox. The tested changes can be added to this page in a single edit. Please discuss changes on the talk page before implementing them.
This module depends on the following other modules:

This is a data page for Module:Namespace detect and Module:Category handler/shared. It is loaded by the main module using mw.loadData, which means it is only processed once per page, rather than once per #invoke.

The above documentation is transcluded from Module:Namespace detect/data/doc. (edit | history)
Editors can experiment in this module's sandbox (edit | diff) and testcases (create) pages.
Add categories to the /doc subpage. Subpages of this module.
 --------------------------------------------------------------------------------
 -- Namespace detect data --
 -- This module holds data for [[Module:Namespace detect]] to be loaded per --
 -- page, rather than per #invoke, for performance reasons. --
 --------------------------------------------------------------------------------

 local cfg = require('Module:Namespace detect/config')

 local function addKey(t, key, defaultKey)
	if key ~= defaultKey then
		t[#t + 1] = key
	end
 end

 -- Get a table of parameters to query for each default parameter name.
 -- This allows wikis to customise parameter names in the cfg table while
 -- ensuring that default parameter names will always work. The cfg table
 -- values can be added as a string, or as an array of strings.

 local defaultKeys = {
	'main',
	'talk',
	'other',
	'subjectns',
	'demospace',
	'demopage'
 }

 local argKeys = {}
 for i, defaultKey in ipairs(defaultKeys) do
	argKeys[defaultKey] = {defaultKey}
 end

 for defaultKey, t in pairs(argKeys) do
	local cfgValue = cfg[defaultKey]
	local cfgValueType = type(cfgValue)
	if cfgValueType == 'string' then
		addKey(t, cfgValue, defaultKey)
	elseif cfgValueType == 'table' then
		for i, key in ipairs(cfgValue) do
			addKey(t, key, defaultKey)
		end
	end
	cfg[defaultKey] = nil -- Free the cfg value as we don't need it any more.
 end

 local function getParamMappings()
	--[[
 	-- Returns a table of how parameter names map to namespace names. The keys
 	-- are the actual namespace names, in lower case, and the values are the
 	-- possible parameter names for that namespace, also in lower case. The
 	-- table entries are structured like this:
 	-- {
 	-- [''] = {'main'},
 	-- ['wikipedia'] = {'wikipedia', 'project', 'wp'},
 	-- ...
 	-- }
 	--]]
	local mappings = {}
	local mainNsName = mw.site.subjectNamespaces[0].name
	mainNsName = mw.ustring.lower(mainNsName)
	mappings[mainNsName] = mw.clone(argKeys.main)
	mappings['talk'] = mw.clone(argKeys.talk)
	for nsid, ns in pairs(mw.site.subjectNamespaces) do
		if nsid ~= 0 then -- Exclude main namespace.
			local nsname = mw.ustring.lower(ns.name)
			local canonicalName = mw.ustring.lower(ns.canonicalName)
			mappings[nsname] = {nsname}
			if canonicalName ~= nsname then
				table.insert(mappings[nsname], canonicalName)
			end
			for _, alias in ipairs(ns.aliases) do
				table.insert(mappings[nsname], mw.ustring.lower(alias))
			end
		end
	end
	return mappings
 end

 return {
	argKeys = argKeys,
	cfg = cfg,
	mappings = getParamMappings()
 }

AltStyle によって変換されたページ (->オリジナル) /