Module:Namespace detect/data/sandbox
Appearance
From Wikipedia, the free encyclopedia
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.
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.
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() }