Module:Is infobox in lead: Difference between revisions
m Protected "Module:Is infobox in lead": High-risk Lua module ([Edit=Require template editor access] (indefinite) [Move=Require template editor access] (indefinite)) |
fix the case of two of an infobox in the same article |
||
Line 9: | Line 9: | ||
local offset = string.find(content, "==", 1 , true) |
local offset = string.find(content, "==", 1 , true) |
||
if offset then |
if offset then |
||
lead = string.sub(content, 1, offset-1) |
local lead = string.sub(content, 1, offset-1) |
||
if (string.find(lead, searchString)) then |
if (string.find(lead, searchString)) then |
||
iter = string.gmatch(lead, "[Ii]nfobox") |
local iter = string.gmatch(lead, "[Ii]nfobox") |
||
iter() |
iter() |
||
if not iter() then --if able to find two infoboxes, then don't return true |
if not iter() then --if able to find two infoboxes in the lead, then don't return true |
||
local iter2 = string.gmatch(content, searchString) --if able to find two of the specific infobox in the article, then return true |
|||
⚫ | |||
iter2() |
|||
if not iter2() then |
|||
⚫ | |||
end |
|||
end |
end |
||
end |
end |
Revision as of 12:00, 3 March 2019
![]() | This Lua module is used on approximately 451,000 pages, or roughly 1% of all 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. |
Module:Is infobox in lead checks if a given infobox is in the lead, is also the only infobox in the lead, and that there aren't two of that same infobox in the article. If that is the case, it returns true
, and if not returns nothing.
This is designed for use by infoboxes that automatically generate short descriptions, to make sure they only generate a short description if they are the lead infobox.
Usage
{{#invoke:Is infobox in lead|main|[Ii]nfobox [Ff]oo [Bb]ar}}
It does not detect redirects which do not match the parameter. Redirects can be handled with an extra invocation per redirect pattern, e.g.:
{{#invoke:Is infobox in lead|main|[Ii]nfobox [Ss]ong}}{{#invoke:Is infobox in lead|main|[Ii]nfobox [Ss]ingle}}
Redirects can be found with WhatLinksHere.
local p = {}
function p.main (frame)
return p._main (frame.args[1])
end
function p._main (searchString)
local content = mw.title.getCurrentTitle():getContent()
local offset = string.find(content, "==", 1 , true)
if offset then
local lead = string.sub(content, 1, offset-1)
if (string.find(lead, searchString)) then
local iter = string.gmatch(lead, "[Ii]nfobox")
iter()
if not iter() then --if able to find two infoboxes in the lead, then don't return true
local iter2 = string.gmatch(content, searchString) --if able to find two of the specific infobox in the article, then return true
iter2()
if not iter2() then
return true
end
end
end
end
end
return p