This module is rated as beta, and is ready for widespread use. It is still new and should be used with some caution to ensure the results are as expected. |
This Lua module is used on
approximately 281,000 pages. 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. Consider discussing changes on the talk page before implementing them. |
This module depends on the following other modules: |
This module is designed to serve as a back end for {{
R from alternative scientific name}}
, {{
R to scientific name}}
, {{
R from scientific name}}
, {{
R to monotypic taxon}}
and {{
R from monotypic taxon}}
.
The template parameters and recognized categories are set in Module:Science redirect/conf.
{{#invoke:Science redirect|R|template name excluding 'R'}}
For example, for {{
R to scientific name}}, you would use {{#invoke:Science redirect|R|to scientific name}}
to produce:
The template parameters and recognized categories are set in Module:Science redirect/conf. Instructions on how to add data are in the comments of that file.
For debugging, add parameter |debug=true
, e.g. {{#invoke:Science redirect|R|to scientific name|debug=true}}
produces:
{{Redirect template
| name = To scientific name of an organism
| from = a
vernacular ("common") name
| id = R_to_scientific_name
| printworthy = yes
| main category = Redirects to scientific names
| to = the
scientific name of an organism (or group of organisms)
}}
local conf = require( "Module:Science redirect/conf" )
local p = {}
function p.R(frame)
local template = mw.ustring.gsub(frame.args1], ' ', '_')
if conf.templatestemplate then
return p._main(frame, 'R_' .. template, conf.templatestemplate].name, conf.templatestemplate].from, conf.templatestemplate].to, conf.templatestemplate].category, conf.templatestemplate].info, conf.templatestemplate].removeA)
elseif template then
return '<span class="error">The template '..template..'is not valid.</span>\n'
else
return '<span class="error">No template specified</span>\n'
end
end
function p.list(frame)
local outstr = ""
local ocats={}
for k, v in pairs(conf.cats) do
if(v2]) then
ocatsv2]] = v1
end
end
for k, v in pairs(ocats) do
local h = mw.ustring.match(v, ".*%s(.*)")
outstr = outstr .. "\n=== " .. frame:expandTemplate{ title = 'cl', args = { (h .. " redirects"), (mw.language.getContentLanguage():ucfirst(h) .. " redirects"), count = "yes" } } .. " ===\n"
for kk, vv in pairs (conf.templates) do
outstr = outstr .. "*" .. frame:expandTemplate{ title = 'cl', args = { ("Redirects " .. vv.category .. " of " .. k), count = "yes" } } .. "\n"
end
end
return outstr
end
function p._main(frame, id, name, from, to, category, info, removeA)
--initialize variables
local args = frame:getParent().args
local singleNoun, pluralNoun = '', ''
local outStr = ''
--Check for known parameter 1
local cat = mw.ustring.match(mw.ustring.lower(args1 or 'none'), '^(.-)s?$')
if conf.catscat then singleNoun, pluralNoun = conf.catscat][1], conf.catscat][2 else
singleNoun, pluralNoun = 'an organism'
outStr = '[[Category:Redirects '..category..' using unknown values for parameter 1]]'
end
--strip article from singleNoun if removeA is true
if removeA == true then
if singleNoun == 'an organism' then singleNoun = '' else singleNoun = (mw.ustring.match(singleNoun, '^an? (.*)$') or singleNoun) end
end
--support alternative indications for printworthy
if args2 == 'unprintworthy' or args'unprintworthy' == 'true' then args'printworthy' = 'no' end
--build template arguments
local main_category = 'Redirects '..category
if pluralNoun then main_category = main_category..' of '..pluralNoun end
local outArgs = {
id = id,
name = mw.ustring.gsub(name, '$1', singleNoun),
from = mw.ustring.gsub(mw.ustring.gsub(from, '$1', singleNoun), '$2', (pluralNoun or 'organisms')),
to = mw.ustring.gsub(mw.ustring.gsub(to, '$1', singleNoun), '$2', (pluralNoun or 'organisms')),
'main category' = main_category,
printworthy = (args'printworthy' or 'yes'),
info = info,
}
--build output string
if frame.args'debug' == 'true' then
local debugStr = '{{Redirect template<br />\n'
for k,v in pairs( outArgs ) do
debugStr = debugStr..'| '..k..' = '..v..'<br />\n'
end
outStr = debugStr..'}}'..frame:extensionTag{ name = 'nowiki', content = outStr}
else
outStr = frame:expandTemplate{ title = 'Redirect template', args = outArgs }..outStr
end
return outStr
end
return p
This module is rated as beta, and is ready for widespread use. It is still new and should be used with some caution to ensure the results are as expected. |
This Lua module is used on
approximately 281,000 pages. 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. Consider discussing changes on the talk page before implementing them. |
This module depends on the following other modules: |
This module is designed to serve as a back end for {{
R from alternative scientific name}}
, {{
R to scientific name}}
, {{
R from scientific name}}
, {{
R to monotypic taxon}}
and {{
R from monotypic taxon}}
.
The template parameters and recognized categories are set in Module:Science redirect/conf.
{{#invoke:Science redirect|R|template name excluding 'R'}}
For example, for {{
R to scientific name}}, you would use {{#invoke:Science redirect|R|to scientific name}}
to produce:
The template parameters and recognized categories are set in Module:Science redirect/conf. Instructions on how to add data are in the comments of that file.
For debugging, add parameter |debug=true
, e.g. {{#invoke:Science redirect|R|to scientific name|debug=true}}
produces:
{{Redirect template
| name = To scientific name of an organism
| from = a
vernacular ("common") name
| id = R_to_scientific_name
| printworthy = yes
| main category = Redirects to scientific names
| to = the
scientific name of an organism (or group of organisms)
}}
local conf = require( "Module:Science redirect/conf" )
local p = {}
function p.R(frame)
local template = mw.ustring.gsub(frame.args1], ' ', '_')
if conf.templatestemplate then
return p._main(frame, 'R_' .. template, conf.templatestemplate].name, conf.templatestemplate].from, conf.templatestemplate].to, conf.templatestemplate].category, conf.templatestemplate].info, conf.templatestemplate].removeA)
elseif template then
return '<span class="error">The template '..template..'is not valid.</span>\n'
else
return '<span class="error">No template specified</span>\n'
end
end
function p.list(frame)
local outstr = ""
local ocats={}
for k, v in pairs(conf.cats) do
if(v2]) then
ocatsv2]] = v1
end
end
for k, v in pairs(ocats) do
local h = mw.ustring.match(v, ".*%s(.*)")
outstr = outstr .. "\n=== " .. frame:expandTemplate{ title = 'cl', args = { (h .. " redirects"), (mw.language.getContentLanguage():ucfirst(h) .. " redirects"), count = "yes" } } .. " ===\n"
for kk, vv in pairs (conf.templates) do
outstr = outstr .. "*" .. frame:expandTemplate{ title = 'cl', args = { ("Redirects " .. vv.category .. " of " .. k), count = "yes" } } .. "\n"
end
end
return outstr
end
function p._main(frame, id, name, from, to, category, info, removeA)
--initialize variables
local args = frame:getParent().args
local singleNoun, pluralNoun = '', ''
local outStr = ''
--Check for known parameter 1
local cat = mw.ustring.match(mw.ustring.lower(args1 or 'none'), '^(.-)s?$')
if conf.catscat then singleNoun, pluralNoun = conf.catscat][1], conf.catscat][2 else
singleNoun, pluralNoun = 'an organism'
outStr = '[[Category:Redirects '..category..' using unknown values for parameter 1]]'
end
--strip article from singleNoun if removeA is true
if removeA == true then
if singleNoun == 'an organism' then singleNoun = '' else singleNoun = (mw.ustring.match(singleNoun, '^an? (.*)$') or singleNoun) end
end
--support alternative indications for printworthy
if args2 == 'unprintworthy' or args'unprintworthy' == 'true' then args'printworthy' = 'no' end
--build template arguments
local main_category = 'Redirects '..category
if pluralNoun then main_category = main_category..' of '..pluralNoun end
local outArgs = {
id = id,
name = mw.ustring.gsub(name, '$1', singleNoun),
from = mw.ustring.gsub(mw.ustring.gsub(from, '$1', singleNoun), '$2', (pluralNoun or 'organisms')),
to = mw.ustring.gsub(mw.ustring.gsub(to, '$1', singleNoun), '$2', (pluralNoun or 'organisms')),
'main category' = main_category,
printworthy = (args'printworthy' or 'yes'),
info = info,
}
--build output string
if frame.args'debug' == 'true' then
local debugStr = '{{Redirect template<br />\n'
for k,v in pairs( outArgs ) do
debugStr = debugStr..'| '..k..' = '..v..'<br />\n'
end
outStr = debugStr..'}}'..frame:extensionTag{ name = 'nowiki', content = outStr}
else
outStr = frame:expandTemplate{ title = 'Redirect template', args = outArgs }..outStr
end
return outStr
end
return p