Jump to content
Wikipedia The Free Encyclopedia

Module:Namespace detect/data/sandbox

From Wikipedia, the free encyclopedia
Module documentation[view] [edit] [history] [purge]
This module is rated as ready for general use. It has reached a mature state, is considered relatively stable and bug-free, and may be used wherever appropriate. It can be mentioned on help pages and other Wikipedia resources as an option for new users. To minimise server load and avoid disruptive output, improvements should be developed through sandbox testing rather than repeated trial-and-error editing.
[画像:Warning] This Lua module is used in system messages, and on approximately 5,100,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. --
 --------------------------------------------------------------------------------

 localcfg=require('Module:Namespace detect/config')

 localfunctionaddKey(t,key,defaultKey)
 ifkey~=defaultKeythen
 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.

 localdefaultKeys={
 'main',
 'talk',
 'other',
 'subjectns',
 'demospace',
 'demopage'
 }

 localargKeys={}
 fori,defaultKeyinipairs(defaultKeys)do
 argKeys[defaultKey]={defaultKey}
 end

 fordefaultKey,tinpairs(argKeys)do
 localcfgValue=cfg[defaultKey]
 localcfgValueType=type(cfgValue)
 ifcfgValueType=='string'then
 addKey(t,cfgValue,defaultKey)
 elseifcfgValueType=='table'then
 fori,keyinipairs(cfgValue)do
 addKey(t,key,defaultKey)
 end
 end
 cfg[defaultKey]=nil-- Free the cfg value as we don't need it any more.
 end

 localfunctiongetParamMappings()
 --[[
 	-- 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'},
 	-- ...
 	-- }
 	--]]
 localmappings={}
 localmainNsName=mw.site.subjectNamespaces[0].name
 mainNsName=mw.ustring.lower(mainNsName)
 mappings[mainNsName]=mw.clone(argKeys.main)
 mappings['talk']=mw.clone(argKeys.talk)
 fornsid,nsinpairs(mw.site.subjectNamespaces)do
 ifnsid~=0then-- Exclude main namespace.
 localnsname=mw.ustring.lower(ns.name)
 localcanonicalName=mw.ustring.lower(ns.canonicalName)
 mappings[nsname]={nsname}
 ifcanonicalName~=nsnamethen
 table.insert(mappings[nsname],canonicalName)
 end
 for_,aliasinipairs(ns.aliases)do
 table.insert(mappings[nsname],mw.ustring.lower(alias))
 end
 end
 end
 returnmappings
 end

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

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