<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://en.stargatewiki.noip.me/index.php?action=history&amp;feed=atom&amp;title=Module%3AFind_sources</id>
	<title>Module:Find sources - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://en.stargatewiki.noip.me/index.php?action=history&amp;feed=atom&amp;title=Module%3AFind_sources"/>
	<link rel="alternate" type="text/html" href="https://en.stargatewiki.noip.me/index.php?title=Module:Find_sources&amp;action=history"/>
	<updated>2026-04-04T01:10:05Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.44.0</generator>
	<entry>
		<id>https://en.stargatewiki.noip.me/index.php?title=Module:Find_sources&amp;diff=16851&amp;oldid=prev</id>
		<title>LIMAFOX76: Created page with &quot;-- This module implements {{find sources}} and other similar templates, and -- also provides a mechanism to easily create new source-finding templates.  -- Define constants local ROOT_PAGE = &#039;Module:Find sources&#039; local TEMPLATE_ROOT = ROOT_PAGE .. &#039;/templates/&#039; -- for template config modules local LINK_CONFIG = ROOT_PAGE .. &#039;/links&#039; -- for link config modules local CONFIG_PAGE = ROOT_PAGE .. &#039;/config&#039; -- for global config  -- Load required modules local checkType = requi...&quot;</title>
		<link rel="alternate" type="text/html" href="https://en.stargatewiki.noip.me/index.php?title=Module:Find_sources&amp;diff=16851&amp;oldid=prev"/>
		<updated>2024-06-15T09:28:13Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;-- This module implements {{find sources}} and other similar templates, and -- also provides a mechanism to easily create new source-finding templates.  -- Define constants local ROOT_PAGE = &amp;#039;Module:Find sources&amp;#039; local TEMPLATE_ROOT = ROOT_PAGE .. &amp;#039;/templates/&amp;#039; -- for template config modules local LINK_CONFIG = ROOT_PAGE .. &amp;#039;/links&amp;#039; -- for link config modules local CONFIG_PAGE = ROOT_PAGE .. &amp;#039;/config&amp;#039; -- for global config  -- Load required modules local checkType = requi...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;-- This module implements {{find sources}} and other similar templates, and&lt;br /&gt;
-- also provides a mechanism to easily create new source-finding templates.&lt;br /&gt;
&lt;br /&gt;
-- Define constants&lt;br /&gt;
local ROOT_PAGE = &amp;#039;Module:Find sources&amp;#039;&lt;br /&gt;
local TEMPLATE_ROOT = ROOT_PAGE .. &amp;#039;/templates/&amp;#039; -- for template config modules&lt;br /&gt;
local LINK_CONFIG = ROOT_PAGE .. &amp;#039;/links&amp;#039; -- for link config modules&lt;br /&gt;
local CONFIG_PAGE = ROOT_PAGE .. &amp;#039;/config&amp;#039; -- for global config&lt;br /&gt;
&lt;br /&gt;
-- Load required modules&lt;br /&gt;
local checkType = require(&amp;#039;libraryUtil&amp;#039;).checkType&lt;br /&gt;
local cfg = mw.loadData(CONFIG_PAGE)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function maybeLoadData(page)&lt;br /&gt;
	local success, data = pcall(mw.loadData, page)&lt;br /&gt;
	return success and data&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function substituteParams(msg, ...)&lt;br /&gt;
	return mw.message.newRawMessage(msg, ...):plain()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderSearchString(searchTerms, separator, transformFunc)&lt;br /&gt;
	-- This takes a table of search terms and turns it into a search string&lt;br /&gt;
	-- that can be used in a URL or in a display value. The transformFunc&lt;br /&gt;
	-- parameter can be used to transform each search term in some way (for&lt;br /&gt;
	-- example, URL-encoding them).&lt;br /&gt;
	local searchStrings = {}&lt;br /&gt;
	for i, s in ipairs(searchTerms) do&lt;br /&gt;
		searchStrings[i] = s&lt;br /&gt;
	end&lt;br /&gt;
	if transformFunc then&lt;br /&gt;
		for i, s in ipairs(searchStrings) do&lt;br /&gt;
			searchStrings[i] = transformFunc(s)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return table.concat(searchStrings, separator)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._renderLink(code, searchTerms, display, tooltip)&lt;br /&gt;
	-- Renders the external link wikicode for one link, given the link code,&lt;br /&gt;
	-- a table of search terms, and an optional display value and tooltip.&lt;br /&gt;
&lt;br /&gt;
	-- Get link config.&lt;br /&gt;
	local links = maybeLoadData(LINK_CONFIG)&lt;br /&gt;
	local linkCfg = links[code]&lt;br /&gt;
	if not linkCfg then&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&amp;quot;invalid link code &amp;#039;%s&amp;#039;; no link config found at [[%s]]&amp;quot;,&lt;br /&gt;
			code,&lt;br /&gt;
			LINK_CONFIG&lt;br /&gt;
		))&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Make URL.&lt;br /&gt;
	local url&lt;br /&gt;
	do&lt;br /&gt;
		local separator = linkCfg.separator or &amp;quot;+&amp;quot;&lt;br /&gt;
		local searchString = renderSearchString(&lt;br /&gt;
			searchTerms,&lt;br /&gt;
			separator,&lt;br /&gt;
			mw.uri.encode&lt;br /&gt;
		)&lt;br /&gt;
		url = substituteParams(linkCfg.url, searchString)&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if tooltip then&lt;br /&gt;
		return string.format(&amp;#039;&amp;lt;span title=&amp;quot;%s&amp;quot; style=&amp;quot;border-bottom: 1px dotted;&amp;quot;&amp;gt;[%s %s]&amp;lt;/span&amp;gt;&amp;#039;, &lt;br /&gt;
			mw.text.encode(tooltip), url, display or linkCfg.display)&lt;br /&gt;
	else&lt;br /&gt;
		return string.format(&amp;#039;[%s %s]&amp;#039;, url, display or linkCfg.display)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(template, args)&lt;br /&gt;
	-- The main access point from Lua.&lt;br /&gt;
	checkType(&amp;#039;_main&amp;#039;, 1, template, &amp;#039;string&amp;#039;)&lt;br /&gt;
	checkType(&amp;#039;_main&amp;#039;, 2, args, &amp;#039;table&amp;#039;, true)&lt;br /&gt;
	args = args or {}&lt;br /&gt;
	local title = mw.title.getCurrentTitle()&lt;br /&gt;
&lt;br /&gt;
	-- Get the template config.&lt;br /&gt;
	local templateCfgPage = TEMPLATE_ROOT .. template&lt;br /&gt;
	local templateCfg = maybeLoadData(templateCfgPage)&lt;br /&gt;
	if not templateCfg then&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&amp;quot;invalid template name &amp;#039;%s&amp;#039;; no template config found at [[%s]]&amp;quot;,&lt;br /&gt;
			template, templateCfgPage&lt;br /&gt;
		))&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Namespace check.&lt;br /&gt;
	if not templateCfg.isUsedInMainspace and title.namespace == 0 then&lt;br /&gt;
		local formatString = &amp;#039;&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;%s&amp;lt;/strong&amp;gt;&amp;#039;&lt;br /&gt;
		if cfg[&amp;#039;namespace-error-category&amp;#039;] then&lt;br /&gt;
			formatString = formatString .. &amp;#039;[[%s:%s]]&amp;#039;&lt;br /&gt;
		end&lt;br /&gt;
		return string.format(&lt;br /&gt;
			formatString,&lt;br /&gt;
			cfg[&amp;#039;namespace-error&amp;#039;],&lt;br /&gt;
			mw.site.namespaces[14].name,&lt;br /&gt;
			cfg[&amp;#039;namespace-error-category&amp;#039;]&lt;br /&gt;
		)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Get the search terms from the arguments.&lt;br /&gt;
	local searchTerms = {}&lt;br /&gt;
	for i, s in ipairs(args) do&lt;br /&gt;
		searchTerms[i] = s&lt;br /&gt;
	end&lt;br /&gt;
	if not searchTerms[1] then&lt;br /&gt;
		-- Use the current subpage name as the default search term, unless &lt;br /&gt;
		-- another title is provided. If the page uses a disambiguator like&lt;br /&gt;
		-- &amp;quot;Foo (bar)&amp;quot;, make &amp;quot;Foo&amp;quot; the first term and &amp;quot;bar&amp;quot; the second.&lt;br /&gt;
		local searchTitle = args.title or title.subpageText&lt;br /&gt;
		local term, dab = searchTitle:match(&amp;#039;^(.*) (%b())$&amp;#039;)&lt;br /&gt;
		if dab then&lt;br /&gt;
			dab = dab:sub(2, -2) -- Remove parens&lt;br /&gt;
		end&lt;br /&gt;
		if term and dab then&lt;br /&gt;
			searchTerms[1] = term&lt;br /&gt;
			searchTerms[2] = dab&lt;br /&gt;
		else&lt;br /&gt;
			searchTerms[1] = searchTitle&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	searchTerms[1] = &amp;#039;&amp;quot;&amp;#039; .. searchTerms[1] .. &amp;#039;&amp;quot;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
	-- Make the intro link&lt;br /&gt;
	local introLink&lt;br /&gt;
	if templateCfg.introLink then&lt;br /&gt;
		local code = templateCfg.introLink.code&lt;br /&gt;
		local display = templateCfg.introLink.display or renderSearchString(&lt;br /&gt;
			searchTerms,&lt;br /&gt;
			&amp;#039;&amp;amp;nbsp;&amp;#039;&lt;br /&gt;
		)&lt;br /&gt;
		local tooltip = templateCfg.introLink.tooltip&lt;br /&gt;
		introLink = p._renderLink(code, searchTerms, display, tooltip)&lt;br /&gt;
	else&lt;br /&gt;
		introLink = &amp;#039;&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Make the other links&lt;br /&gt;
	local links = {}&lt;br /&gt;
	local separator = templateCfg.separator or cfg[&amp;#039;default-separator&amp;#039;]&lt;br /&gt;
	local sep = &amp;#039;&amp;#039;&lt;br /&gt;
	for i, t in ipairs(templateCfg.links) do&lt;br /&gt;
		links[i] = sep .. p._renderLink(t.code, searchTerms, t.display, t.tooltip) ..&lt;br /&gt;
			(t.afterDisplay or &amp;#039;&amp;#039;)&lt;br /&gt;
		sep = t.separator or separator&lt;br /&gt;
	end&lt;br /&gt;
	links = table.concat(links)&lt;br /&gt;
&lt;br /&gt;
	-- Make the blurb.&lt;br /&gt;
	local blurb = substituteParams(templateCfg.blurb, introLink, links)&lt;br /&gt;
	local span = mw.html.create(&amp;#039;span&amp;#039;)&lt;br /&gt;
	span&lt;br /&gt;
		:addClass(&amp;#039;plainlinks&amp;#039;)&lt;br /&gt;
		:addClass(templateCfg.class)&lt;br /&gt;
		:cssText(templateCfg.style)&lt;br /&gt;
		:wikitext(blurb)&lt;br /&gt;
&lt;br /&gt;
	return tostring(span)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
setmetatable(p, { __index = function(t, template)&lt;br /&gt;
	-- The main access point from #invoke.&lt;br /&gt;
	-- Invocations will look like {{#invoke:Find sources|template name}},&lt;br /&gt;
	-- where &amp;quot;template name&amp;quot; is a subpage of [[Module:Find sources/templates]].&lt;br /&gt;
	local tname = template&lt;br /&gt;
	if tname:sub(-8) == &amp;#039;/sandbox&amp;#039; then&lt;br /&gt;
		-- This makes {{Find sources/sandbox|Albert Einstein}} work.&lt;br /&gt;
		tname = tname:sub(1, -9)&lt;br /&gt;
	end&lt;br /&gt;
	return function(frame)&lt;br /&gt;
		local args = require(&amp;#039;Module:Arguments&amp;#039;).getArgs(frame, {&lt;br /&gt;
			wrappers = mw.site.namespaces[10].name .. &amp;#039;:&amp;#039; .. tname&lt;br /&gt;
		})&lt;br /&gt;
		return t._main(template, args)&lt;br /&gt;
	end&lt;br /&gt;
end})&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>LIMAFOX76</name></author>
	</entry>
</feed>