<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en-GB">
	<id>https://stockhub.co/index.php?action=history&amp;feed=atom&amp;title=Module%3ACheck_DYK_hook</id>
	<title>Module:Check DYK hook - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://stockhub.co/index.php?action=history&amp;feed=atom&amp;title=Module%3ACheck_DYK_hook"/>
	<link rel="alternate" type="text/html" href="https://stockhub.co/index.php?title=Module:Check_DYK_hook&amp;action=history"/>
	<updated>2026-04-16T20:26:32Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.5</generator>
	<entry>
		<id>https://stockhub.co/index.php?title=Module:Check_DYK_hook&amp;diff=135538&amp;oldid=prev</id>
		<title>imported&gt;Mr. Stradivarius: fix whitespace trimming; only trim whitespace in p.isValidHook, not in the Lua p._isValidHook interface; add a &quot;hook&quot; keyword parameter; and check the type of the input in p._isValidHook</title>
		<link rel="alternate" type="text/html" href="https://stockhub.co/index.php?title=Module:Check_DYK_hook&amp;diff=135538&amp;oldid=prev"/>
		<updated>2020-11-29T12:31:57Z</updated>

		<summary type="html">&lt;p&gt;fix whitespace trimming; only trim whitespace in p.isValidHook, not in the Lua p._isValidHook interface; add a &amp;quot;hook&amp;quot; keyword parameter; and check the type of the input in p._isValidHook&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;-- This module performs validation checks for [[WP:DYK]] hooks&lt;br /&gt;
&lt;br /&gt;
local libraryUtil = require(&amp;#039;libraryUtil&amp;#039;)&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local validationPatternGroups = {&lt;br /&gt;
	{&lt;br /&gt;
		-- Check that hooks start with three periods, followed by an acceptable&lt;br /&gt;
		-- follow-on word.&lt;br /&gt;
		&amp;quot;^%.%.%. *that&amp;quot;,&lt;br /&gt;
		&amp;quot;^%.%.%. *about&amp;quot;,	&lt;br /&gt;
	},&lt;br /&gt;
	{&lt;br /&gt;
		-- Check that hooks end with a question mark, or another acceptable&lt;br /&gt;
		-- phrase.&lt;br /&gt;
		[[.%?%]*&amp;#039;*&amp;quot;?$]],&lt;br /&gt;
		[[.&amp;amp;#63;&amp;lt;/span&amp;gt;%]*&amp;#039;*&amp;quot;?$]],&lt;br /&gt;
		&amp;quot;[Yy]ou probably did%.+$&amp;quot;,&lt;br /&gt;
	}&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
function p._isValidHook(hook)&lt;br /&gt;
	-- Whether the given hook is valid.&lt;br /&gt;
	-- We use the patterns in the validationPatternGroups table to find whether&lt;br /&gt;
	-- a hook is valid or not. Hooks are treated as valid if they match at least&lt;br /&gt;
	-- one pattern from each group.&lt;br /&gt;
	libraryUtil.checkType(&amp;quot;_isValidHook&amp;quot;, 1, hook, &amp;quot;string&amp;quot;)&lt;br /&gt;
	for _, patternGroup in ipairs(validationPatternGroups) do&lt;br /&gt;
		local found = false&lt;br /&gt;
		for _, pattern in ipairs(patternGroup) do&lt;br /&gt;
			if mw.ustring.find(hook, pattern) then&lt;br /&gt;
				found = true&lt;br /&gt;
				break&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		if not found then&lt;br /&gt;
			return false&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return true&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.isValidHook(frame)&lt;br /&gt;
	local args = frame.args&lt;br /&gt;
	local hook = args.hook or args[1]&lt;br /&gt;
	if not hook then&lt;br /&gt;
		error(&amp;quot;No hook specified&amp;quot;)&lt;br /&gt;
	end&lt;br /&gt;
	hook = hook:match(&amp;#039;^%s*(.-)%s*$&amp;#039;) -- Trim whitespace&lt;br /&gt;
	if p._isValidHook(hook) then&lt;br /&gt;
		return &amp;quot;yes&amp;quot;&lt;br /&gt;
	else&lt;br /&gt;
		return &amp;quot;&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>imported&gt;Mr. Stradivarius</name></author>
	</entry>
</feed>