<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://mindpowe.red/wiki/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://mindpowe.red/wiki/index.php?action=history&amp;feed=atom&amp;title=Module%3AFind_sources"/>
	<link rel="alternate" type="text/html" href="https://mindpowe.red/wiki/index.php?title=Module:Find_sources&amp;action=history"/>
	<updated>2026-04-06T02:12:04Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.34.2</generator>
	<entry>
		<id>https://mindpowe.red/wiki/index.php?title=Module:Find_sources&amp;diff=622&amp;oldid=prev</id>
		<title>WikiSysop: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="https://mindpowe.red/wiki/index.php?title=Module:Find_sources&amp;diff=622&amp;oldid=prev"/>
		<updated>2020-08-07T21:31:16Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 21:31, 7 August 2020&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>WikiSysop</name></author>
		
	</entry>
	<entry>
		<id>https://mindpowe.red/wiki/index.php?title=Module:Find_sources&amp;diff=621&amp;oldid=prev</id>
		<title>en&gt;Pppery: Support custom title param per edit request</title>
		<link rel="alternate" type="text/html" href="https://mindpowe.red/wiki/index.php?title=Module:Find_sources&amp;diff=621&amp;oldid=prev"/>
		<updated>2020-07-31T00:54:55Z</updated>

		<summary type="html">&lt;p&gt;Support custom title param per edit request&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 = 'Module:Find sources'&lt;br /&gt;
local TEMPLATE_ROOT = ROOT_PAGE .. '/templates/' -- for template config modules&lt;br /&gt;
local LINK_ROOT = ROOT_PAGE .. '/links/' -- for link config modules&lt;br /&gt;
local CONFIG_PAGE = ROOT_PAGE .. '/config' -- for global config&lt;br /&gt;
&lt;br /&gt;
-- Load required modules&lt;br /&gt;
local checkType = require('libraryUtil').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)&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.&lt;br /&gt;
&lt;br /&gt;
	-- Get link config.&lt;br /&gt;
	local linkCfg = maybeLoadData(LINK_ROOT .. code)&lt;br /&gt;
	if not linkCfg then&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&amp;quot;invalid link code '%s'; no link config found at [[%s]]&amp;quot;,&lt;br /&gt;
			code,&lt;br /&gt;
			LINK_ROOT .. code&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;
	return string.format('[%s %s]', url, display or linkCfg.display)&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('_main', 1, template, 'string')&lt;br /&gt;
	checkType('_main', 2, args, 'table', 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 '%s'; 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;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;%s&amp;lt;/strong&amp;gt;'&lt;br /&gt;
		if cfg['namespace-error-category'] then&lt;br /&gt;
			formatString = formatString .. '[[%s:%s]]'&lt;br /&gt;
		end&lt;br /&gt;
		return string.format(&lt;br /&gt;
			formatString,&lt;br /&gt;
			cfg['namespace-error'],&lt;br /&gt;
			mw.site.namespaces[14].name,&lt;br /&gt;
			cfg['namespace-error-category']&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('^(.*) (%b())$')&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;quot;' .. searchTerms[1] .. '&amp;quot;'&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;amp;nbsp;'&lt;br /&gt;
		)&lt;br /&gt;
		introLink = p._renderLink(code, searchTerms, display)&lt;br /&gt;
	else&lt;br /&gt;
		introLink = ''&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['default-separator']&lt;br /&gt;
	local sep = ''&lt;br /&gt;
	for i, t in ipairs(templateCfg.links) do&lt;br /&gt;
		links[i] = sep .. p._renderLink(t.code, searchTerms, t.display) ..&lt;br /&gt;
			(t.afterDisplay or '')&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('span')&lt;br /&gt;
	span&lt;br /&gt;
		:addClass('plainlinks')&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) == '/sandbox' 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('Module:Arguments').getArgs(frame, {&lt;br /&gt;
			wrappers = mw.site.namespaces[10].name .. ':' .. 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>en&gt;Pppery</name></author>
		
	</entry>
</feed>