<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wiki.hackforums.net/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ethereal</id>
	<title>Hack Forums Wiki - User contributions [en]</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.hackforums.net/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ethereal"/>
	<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/Special:Contributions/Ethereal"/>
	<updated>2026-06-22T00:00:52Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.43.1</generator>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=T3h_Hack3r&amp;diff=6498</id>
		<title>T3h Hack3r</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=T3h_Hack3r&amp;diff=6498"/>
		<updated>2015-09-14T13:43:37Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{MemberBox&lt;br /&gt;
| Username    = T3h Hack3r&lt;br /&gt;
| UserID      = 128873&lt;br /&gt;
| JoinDate    = 12-22-2009&lt;br /&gt;
| Status      = Active&lt;br /&gt;
| IsStaff     = True&lt;br /&gt;
| IsMentor    = True&lt;br /&gt;
| IsWriter    = True&lt;br /&gt;
| Biography   = T3h Hack3r has declined to speak with the team and has made himself unavailable for interview. A biography may be included regardless of this at a later stage.&lt;br /&gt;
| History     = * Former Staff member&lt;br /&gt;
* Former Mentor&lt;br /&gt;
* Former Leader of [[The Alliance]]&lt;br /&gt;
* Former Leader of [[Null]]&lt;br /&gt;
* Former [[HiJack This! Team]] and [[Malware Removal Team]] Leader, Teacher, and Log Analyzer&lt;br /&gt;
| PersonComm  = &lt;br /&gt;
| Alias1      = &lt;br /&gt;
| Alias2      = &lt;br /&gt;
| Alias3      = &lt;br /&gt;
| Alias4      = &lt;br /&gt;
| AwardName1  = Sapphire of Ub3r&lt;br /&gt;
| AwardName2  = Support Feather&lt;br /&gt;
| AwardName3  = Liberty Reserve Head&lt;br /&gt;
| AwardName4  = Member of the Month&lt;br /&gt;
| AwardName5  = MRT Graduate&lt;br /&gt;
| AwardName6  = White Hat Helper&lt;br /&gt;
| AwardName7  = Emerald Donator&lt;br /&gt;
| AwardName8  = Rich Bitch&lt;br /&gt;
| AwardName9  = Gift&lt;br /&gt;
| AwardName10 = HackerCraft&lt;br /&gt;
| AwardName11 = Litecoinage&lt;br /&gt;
| AwardName12 = HackerCraft Purple&lt;br /&gt;
| GroupName1  = Null&lt;br /&gt;
| GroupName2  = Instinct&lt;br /&gt;
| GroupName3  = Ub3r&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=%D3%8DeshCollider&amp;diff=6488</id>
		<title>ӍeshCollider</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=%D3%8DeshCollider&amp;diff=6488"/>
		<updated>2015-09-12T08:45:42Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{MemberBox&lt;br /&gt;
| Username    = ӍeshCollider&lt;br /&gt;
| UserID      = 2015410&lt;br /&gt;
| JoinDate    = 10-13-2013&lt;br /&gt;
| JoinYear    = 2013&lt;br /&gt;
| Status      = Active&lt;br /&gt;
| IsWriter    = True&lt;br /&gt;
| IsOMC       = True&lt;br /&gt;
| Biography   = MeshCollider first found his way into [[Hack Forums]] whilst searching for methods and ways to perform SQL injection. His interest piqued by the forum, he soon registered an account, but left it for a couple of months before finally logging back and becoming active.&lt;br /&gt;
&lt;br /&gt;
MeshCollider first involved himself with the [[Programming, Coding, and Languages]] category. Some notable boards that he was active in were the [[C/C++/Obj-C Programming]], [[Java Language, JVM, and the JRE]], and [[Android Operating System]] board (before the [[Android Operating System]] board was reclassified). During his period of high activity, he made many contributions and friends, including some notable users eg. [[Looka]], the current Java Language, JVM and the JRE moderator.&lt;br /&gt;
&lt;br /&gt;
Whilst he was contributing to the coding sector in Hack Forums, he also contributed to the [[Omnicoin]] sub-board. For his vast unofficial contributions to Omnicoin as an individual, he was offered an official position as a member of the Omnicoin development team, which he gladly accepted. By the time he was invited, his contributions were well received by the community. &lt;br /&gt;
&lt;br /&gt;
As MeshCollider&#039;s popularity rose, he was invited into then new group [[Specialists]] by [[Bull™]] as the leader of its coding sector. He ran numerous helpdesks under the Specialists’ name. Before he was invited into the group, he created many hacking tutorials to help benefit the community.&lt;br /&gt;
&lt;br /&gt;
In conjunction with [[Abraham Lincoln]], MeshCollider coded the OMC plugin for managing Omnicoin wallets; this plugin also came with a number of other features. The plugin was implemented into Hack Forums, and was well received by the community as way to introduce more users to Omnicoin. In return for his hard work, MeshCollider was awarded [[3p1c]] (when the HF XMPP was launched), [[Great Thinker]] (after he sent his and Abraham Lincoln’s OMC plugin to Omniscient) and the OMC award. MeshCollider also won the Member of the Month competition at August 2015. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
| History     = *Member of Omnicoin Development Team&lt;br /&gt;
*Leader of [[Divine]]&lt;br /&gt;
*HFNT member&lt;br /&gt;
*Former member of [[Specialists]]&lt;br /&gt;
*Former member of [[Polymath]]&lt;br /&gt;
*Former member of [[Echo]]&lt;br /&gt;
*Former member of [[Null]]&lt;br /&gt;
*Former member of [[Brotherhood]]&lt;br /&gt;
*Former member of [[Titans]]&lt;br /&gt;
*Former member of [[Revolution]]&lt;br /&gt;
*Former member of [[Crypto]]&lt;br /&gt;
*Former member of [[Debug]]&lt;br /&gt;
*Former member of [[Divine]]&lt;br /&gt;
| PersonComm  = *Martial Arts (Taekwondo)&lt;br /&gt;
*Likes to play table tennis and hockey&lt;br /&gt;
*Likes to learn more about coding and hacking&lt;br /&gt;
*Likes to learn about random stuff&lt;br /&gt;
*Has a penchant for Maths, Chemistry, Physics, Computer Science and German&lt;br /&gt;
| Alias1= MeshCollider&lt;br /&gt;
| AwardName1= Sapphire of Ub3r&lt;br /&gt;
| AwardName2= Great Thinker&lt;br /&gt;
| AwardName3= Gift&lt;br /&gt;
| AwardName4= OMC&lt;br /&gt;
| AwardName5= Member of the Month&lt;br /&gt;
| GroupName1= Divine&lt;br /&gt;
| GroupName2= 3p1c&lt;br /&gt;
| GroupName3= Writers&lt;br /&gt;
| GroupName4= Ub3r&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=%D3%8DeshCollider&amp;diff=6487</id>
		<title>ӍeshCollider</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=%D3%8DeshCollider&amp;diff=6487"/>
		<updated>2015-09-12T08:45:20Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Fixing.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{MemberBox&lt;br /&gt;
| Username    = ӍeshCollider&lt;br /&gt;
| UserID      = 2015410&lt;br /&gt;
| JoinDate    = 10-13-2013&lt;br /&gt;
| JoinYear    = 2013&lt;br /&gt;
| Status      = Active&lt;br /&gt;
| IsWriter    = True&lt;br /&gt;
| IsOMC       = True&lt;br /&gt;
| Biography   = MeshCollider first found his way into [[Hack Forums]] whilst searching for methods and ways to perform SQL injection. His interest piqued by the forum, he soon registered an account, but left it for a couple of months before finally logging back and becoming active.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
MeshCollider first involved himself with the [[Programming, Coding, and Languages]] category. Some notable boards that he was active in were the [[C/C++/Obj-C Programming]], [[Java Language, JVM, and the JRE]], and [[Android Operating System]] board (before the [[Android Operating System]] board was reclassified). During his period of high activity, he made many contributions and friends, including some notable users eg. [[Looka]], the current Java Language, JVM and the JRE moderator.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Whilst he was contributing to the coding sector in Hack Forums, he also contributed to the [[Omnicoin]] sub-board. For his vast unofficial contributions to Omnicoin as an individual, he was offered an official position as a member of the Omnicoin development team, which he gladly accepted. By the time he was invited, his contributions were well received by the community. &lt;br /&gt;
&lt;br /&gt;
As MeshCollider&#039;s popularity rose, he was invited into then new group [[Specialists]] by [[Bull™]] as the leader of its coding sector. He ran numerous helpdesks under the Specialists’ name. Before he was invited into the group, he created many hacking tutorials to help benefit the community.&lt;br /&gt;
&lt;br /&gt;
In conjunction with [[Abraham Lincoln]], MeshCollider coded the OMC plugin for managing Omnicoin wallets; this plugin also came with a number of other features. The plugin was implemented into Hack Forums, and was well received by the community as way to introduce more users to Omnicoin. In return for his hard work, MeshCollider was awarded [[3p1c]] (when the HF XMPP was launched), [[Great Thinker]] (after he sent his and Abraham Lincoln’s OMC plugin to Omniscient) and the OMC award. MeshCollider also won the Member of the Month competition at August 2015. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
| History     = *Member of Omnicoin Development Team&lt;br /&gt;
*Leader of [[Divine]]&lt;br /&gt;
*HFNT member&lt;br /&gt;
*Former member of [[Specialists]]&lt;br /&gt;
*Former member of [[Polymath]]&lt;br /&gt;
*Former member of [[Echo]]&lt;br /&gt;
*Former member of [[Null]]&lt;br /&gt;
*Former member of [[Brotherhood]]&lt;br /&gt;
*Former member of [[Titans]]&lt;br /&gt;
*Former member of [[Revolution]]&lt;br /&gt;
*Former member of [[Crypto]]&lt;br /&gt;
*Former member of [[Debug]]&lt;br /&gt;
*Former member of [[Divine]]&lt;br /&gt;
| PersonComm  = *Martial Arts (Taekwondo)&lt;br /&gt;
*Likes to play table tennis and hockey&lt;br /&gt;
*Likes to learn more about coding and hacking&lt;br /&gt;
*Likes to learn about random stuff&lt;br /&gt;
*Has a penchant for Maths, Chemistry, Physics, Computer Science and German&lt;br /&gt;
| Alias1= MeshCollider&lt;br /&gt;
| AwardName1= Sapphire of Ub3r&lt;br /&gt;
| AwardName2= Great Thinker&lt;br /&gt;
| AwardName3= Gift&lt;br /&gt;
| AwardName4= OMC&lt;br /&gt;
| AwardName5= Member of the Month&lt;br /&gt;
| GroupName1= Divine&lt;br /&gt;
| GroupName2= 3p1c&lt;br /&gt;
| GroupName3= Writers&lt;br /&gt;
| GroupName4= Ub3r&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=HF_News_Edition_247&amp;diff=6056</id>
		<title>HF News Edition 247</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=HF_News_Edition_247&amp;diff=6056"/>
		<updated>2015-07-27T23:07:27Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Blanked the page&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=MOTM_Timeline&amp;diff=6044</id>
		<title>MOTM Timeline</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=MOTM_Timeline&amp;diff=6044"/>
		<updated>2015-07-27T13:54:44Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;__TOC__&lt;br /&gt;
==Introduction==&lt;br /&gt;
The original thread can be found [http://www.hackforums.net/showthread.php?tid=3947060 here] and was written by [[D3xus]]. With his permission it has been updated and published on the Wiki.&lt;br /&gt;
&lt;br /&gt;
==Timeline==&lt;br /&gt;
*2009&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
*2010&lt;br /&gt;
**December&lt;br /&gt;
*2011&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**Farch&lt;br /&gt;
**April&lt;br /&gt;
**May&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
**September&lt;br /&gt;
**October&lt;br /&gt;
**November&lt;br /&gt;
**December&lt;br /&gt;
*2012&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**Farch&lt;br /&gt;
**April&lt;br /&gt;
**May&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
**September&lt;br /&gt;
**October&lt;br /&gt;
**November&lt;br /&gt;
**December&lt;br /&gt;
*2013&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**Farch&lt;br /&gt;
**April&lt;br /&gt;
**May&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
**September&lt;br /&gt;
**October&lt;br /&gt;
**November&lt;br /&gt;
**December&lt;br /&gt;
*2014&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**Farch&lt;br /&gt;
**April&lt;br /&gt;
**May&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
**September&lt;br /&gt;
**October&lt;br /&gt;
**November&lt;br /&gt;
**December&lt;br /&gt;
*2015&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
&lt;br /&gt;
*January {{!}} 2009 {{!}} 2010 {{!}} 2011 {{!}} 2012 {{!}} 2013&lt;br /&gt;
*February&lt;br /&gt;
*March&lt;br /&gt;
*April&lt;br /&gt;
*May&lt;br /&gt;
*June&lt;br /&gt;
*July&lt;br /&gt;
*August&lt;br /&gt;
*September&lt;br /&gt;
*October&lt;br /&gt;
*November&lt;br /&gt;
*December&lt;br /&gt;
&lt;br /&gt;
[[Category:Archives]]&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=MOTM_Timeline&amp;diff=6043</id>
		<title>MOTM Timeline</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=MOTM_Timeline&amp;diff=6043"/>
		<updated>2015-07-27T13:51:44Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;__TOC__&lt;br /&gt;
==Introduction==&lt;br /&gt;
The original thread can be found [http://www.hackforums.net/showthread.php?tid=3947060 here] and was written by [[D3xus]]. With his permission it has been updated and published on the Wiki.&lt;br /&gt;
&lt;br /&gt;
==Timeline==&lt;br /&gt;
*2009&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
*2010&lt;br /&gt;
**December&lt;br /&gt;
*2011&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**Farch&lt;br /&gt;
**April&lt;br /&gt;
**May&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
**September&lt;br /&gt;
**October&lt;br /&gt;
**November&lt;br /&gt;
**December&lt;br /&gt;
*2012&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**Farch&lt;br /&gt;
**April&lt;br /&gt;
**May&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
**September&lt;br /&gt;
**October&lt;br /&gt;
**November&lt;br /&gt;
**December&lt;br /&gt;
*2013&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**Farch&lt;br /&gt;
**April&lt;br /&gt;
**May&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
**September&lt;br /&gt;
**October&lt;br /&gt;
**November&lt;br /&gt;
**December&lt;br /&gt;
*2014&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**Farch&lt;br /&gt;
**April&lt;br /&gt;
**May&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
**August&lt;br /&gt;
**September&lt;br /&gt;
**October&lt;br /&gt;
**November&lt;br /&gt;
**December&lt;br /&gt;
*2015&lt;br /&gt;
**January&lt;br /&gt;
**February&lt;br /&gt;
**June&lt;br /&gt;
**July&lt;br /&gt;
&lt;br /&gt;
[[Category:Archives]]&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=HF_News_Edition_247&amp;diff=6042</id>
		<title>HF News Edition 247</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=HF_News_Edition_247&amp;diff=6042"/>
		<updated>2015-07-27T12:30:37Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Using the template.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{HFNewsArticle&lt;br /&gt;
| NewsEdition             = 248&lt;br /&gt;
| NewsEIC                 = iHydra&lt;br /&gt;
| NewsDatePublish         = July 13th, 2015&lt;br /&gt;
| HeadlinesAuthor1        = [[HFProfile:1891811|Colligan]]&lt;br /&gt;
| HeadlinesAuthor2        = [[HFProfile:85546|Odus]]&lt;br /&gt;
| HeadlinesContent        = Omniscient provides the community with a roadmap of what changes are coming to Hack Forums. &amp;lt;span style=&amp;quot;font-size: x-small; font-style: italic;&amp;quot;&amp;gt;]http://www.hackforums.net/showthread.php?tid=4905748 &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
| UserNewsAuthor1         = [[HFProfile:797403|630]]&lt;br /&gt;
| UserNewsAuthor2         = [[Cody]]&lt;br /&gt;
| UserNewsContent         = * [[iHydra|&amp;lt;span style=&amp;quot;color:#EFEFEF;&amp;quot;&amp;gt;iHydra&amp;lt;/span&amp;gt;]] won MOTM.&lt;br /&gt;
* [[adampelletgun|&amp;lt;span style=&amp;quot;color:#EFEFEF;&amp;quot;&amp;gt;adampelletgun&amp;lt;/span&amp;gt;]] hit 4,000 reputation points.&lt;br /&gt;
* [[HFProfile:1498588|&amp;lt;span style=&amp;quot;color: #00AAFF;&amp;quot;&amp;gt;WaterSpice&amp;lt;/span&amp;gt;]] and [[HFProfile:2214473|&amp;lt;span style=&amp;quot;color: #EFEFEF;&amp;quot;&amp;gt;.Sinister&amp;lt;/span&amp;gt;]] hit 1,000 reputation points.&lt;br /&gt;
===Bans===&lt;br /&gt;
* [[HFProfile:651474|&amp;lt;span style=&amp;quot;color: black;&amp;quot;&amp;gt;+Cyan&amp;lt;/span&amp;gt;]] was banned.&lt;br /&gt;
* [[HFProfile:860828|&amp;lt;span style=&amp;quot;color: black;&amp;quot;&amp;gt;Teh Afro&amp;lt;/span&amp;gt;]] was banned with the reason: &amp;quot;Scumbag scammer who tried to manipulate. Goodbye.&amp;quot;&lt;br /&gt;
* [[Understalker|&amp;lt;span style=&amp;quot;color: black;&amp;quot;&amp;gt;Understalker&amp;lt;/span&amp;gt;]] was banned as a precaution after their account was compromised.&lt;br /&gt;
* [[HFProfile:1216255|&amp;lt;span style=&amp;quot;color: black;&amp;quot;&amp;gt;Craze Z&amp;lt;/span&amp;gt;]] was banned as a precaution after their account was compromised.&lt;br /&gt;
&lt;br /&gt;
===Vacations===&lt;br /&gt;
:* [[HFProfile:1535763|&amp;lt;span style=&amp;quot;color: black;&amp;quot;&amp;gt;Chisisi&amp;lt;/span&amp;gt;]] took a vacation ban.&lt;br /&gt;
:* [[HFProfile:1648934|&amp;lt;span style=&amp;quot;color: black;&amp;quot;&amp;gt;Clark&amp;lt;/span&amp;gt;]] took a vacation ban.&lt;br /&gt;
&lt;br /&gt;
===Closures===&lt;br /&gt;
* [[HFProfile:1617327|&amp;lt;span style=&amp;quot;color: #383838;&amp;quot;&amp;gt;ca9a2536fd8b17df76f7ee082&amp;lt;/span&amp;gt;]] had their account closed.&lt;br /&gt;
* [[HFProfile:1425901|&amp;lt;span style=&amp;quot;color: #383838;&amp;quot;&amp;gt;Matheus&amp;lt;/span&amp;gt;]] had their account closed.&lt;br /&gt;
* [[HFProfile:1313896|&amp;lt;span style=&amp;quot;color: #383838;&amp;quot;&amp;gt;Chrome Sparks&amp;lt;/span&amp;gt;]] had their account closed.&lt;br /&gt;
* [[HFProfile:1528462|&amp;lt;span style=&amp;quot;color: #383838;&amp;quot;&amp;gt;yungloungegod&amp;lt;/span&amp;gt;]] had their account closed.&lt;br /&gt;
&lt;br /&gt;
===Repfucks===&lt;br /&gt;
* [[HFProfile:2548722|&amp;lt;span style=&amp;quot;color: #EFEFEF;&amp;quot;&amp;gt;Payne&amp;lt;/span&amp;gt;]] was repfucked.&lt;br /&gt;
* [[HFProfile:1425901|&amp;lt;span style=&amp;quot;color: #383838;&amp;quot;&amp;gt;Matheus&amp;lt;/span&amp;gt;]] was repfucked.&lt;br /&gt;
* [[HFProfile:651474|&amp;lt;span style=&amp;quot;color: black;&amp;quot;&amp;gt;+Cyan&amp;lt;/span&amp;gt;]] was repfucked.&lt;br /&gt;
* [[HFProfile:860828|&amp;lt;span style=&amp;quot;color: black;&amp;quot;&amp;gt;Teh Afro&amp;lt;/span&amp;gt;]] was repfucked.&lt;br /&gt;
* [[HFProfile:2608028|&amp;lt;span style=&amp;quot;color: #00AAFF;&amp;quot;&amp;gt;Αnime&amp;lt;/span&amp;gt;]] was repfucked.&lt;br /&gt;
* [[HFProfile:1929404|&amp;lt;span style=&amp;quot;color: #00AAFF;&amp;quot;&amp;gt;Evocati&amp;lt;/span&amp;gt;]] was repfucked.&lt;br /&gt;
&lt;br /&gt;
===Awards===&lt;br /&gt;
* [[iHydra|&amp;lt;span style=&amp;quot;color:#EFEFEF;&amp;quot;&amp;gt;iHydra&amp;lt;/span&amp;gt;]] won MOTM.&lt;br /&gt;
| NotableThreadsAuthor1   = [[HFProfile:1446355|Trust]]&lt;br /&gt;
| NotableThreadsContent   = &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;font-weight: bold; color: white; text-transform: underline;&amp;quot;&amp;gt;Announcement Thread&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;[http://www.hackforums.net/showthread.php?tid=4851162&amp;amp;pid=46958850#pid46958850 &#039;&#039;&#039;HF is not hacked&#039;&#039;&#039;] - [[Omniscient|&amp;lt;span style=&amp;quot;color: #FF66FF;&amp;quot;&amp;gt;Omniscient&amp;lt;/span&amp;gt;]]&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;Following rumors stating that the Hack Forums database was hacked, Omniscient has released another statement regarding these rumors.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;font-weight: bold; color: white; text-transform: underline;&amp;quot;&amp;gt;Entertaining Thread&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;[http://www.hackforums.net/showthread.php?tid=4905591 &#039;&#039;&#039;What is the last illegal thing you did?&#039;&#039;&#039;] - [[HFProfile:1423220|&amp;lt;span style=&amp;quot;color: #00aaff;&amp;quot;&amp;gt;Ekmete&amp;lt;/span&amp;gt;]]&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;Ekmete invites you to share the last illegal thing you did and got away with.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;font-weight: bold; color: white; text-transform: underline;&amp;quot;&amp;gt;Member Feedback Thread&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;[http://www.hackforums.net/showthread.php?tid=4887980 &#039;&#039;&#039;WOW - GROUP LEADER - DRAMA - 4 YEARS - LOVE, LAUGHTER AND LIFE - FEEDBACK&#039;&#039;&#039;] - [[HFProfile:892404|&amp;lt;span style=&amp;quot;color: white;&amp;quot;&amp;gt;Haydrazs&amp;lt;/span&amp;gt;]]&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;Haydrazs gives an account of his time and experiences on Hack Forums.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;font-weight: bold; color: white; text-transform: underline;&amp;quot;&amp;gt;Contests &amp;amp; Giveaways&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;[http://www.hackforums.net/showthread.php?tid=4903410 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt;[CAPO&#039;S GIVEAWAY]&amp;lt;/nowiki&amp;gt; UPGRADING ONE MEMBER TO 3P1C, L33T, OR UB3R!&#039;&#039;&#039;] - [[HFProfile:2390777|&amp;lt;span style=&amp;quot;color: #99FF00;&amp;quot;&amp;gt;Capo™&amp;lt;/span&amp;gt;]]&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;Test your luck with Capo’s upgrade contest. Who knows, you might be upgraded at the end of it!&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;font-weight: bold; color: white; text-transform: underline;&amp;quot;&amp;gt;Miscellaneous&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;[http://www.hackforums.net/showthread.php?tid=4894139 &#039;&#039;&#039;Cinema4D House *Finished*&#039;&#039;&#039;] - [[HFProfile:2017155|&amp;lt;span style=&amp;quot;color: #00aaff;&amp;quot;&amp;gt;Iggy Azalea&amp;lt;/span&amp;gt;]]&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;color: #333333;&amp;quot;&amp;gt;---&amp;lt;/span&amp;gt;Come check out Iggy Azalea’s house made in Cinema4D. If you like it, tell them why. If you don’t, explain what they can improve on.&lt;br /&gt;
&lt;br /&gt;
| InterviewsAuthor1       = [[D3xus]]&lt;br /&gt;
| InterviewsContent       = &amp;lt;div style=&amp;quot;text-align: center;&amp;quot;&amp;gt;&amp;lt;span style=&amp;quot;color: white; font-size: large; font-family: Monotype Corsiva;&amp;quot;&amp;gt;Interview - [[HFProfile:1148878|&amp;lt;span style=&amp;quot;font-family: Monotype Corsiva; font-weight: normal;&amp;quot;&amp;gt;Clique&amp;lt;/span&amp;gt;]]&amp;lt;/span&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[D3xus|&amp;lt;span style=&amp;quot;color: lime;&amp;quot;&amp;gt;D3xus:&amp;lt;/span&amp;gt;]] For the 248th edition of the HF News, the clicky and everlasting Clique is here. Any shoutouts you&#039;d like to make?&lt;br /&gt;
&lt;br /&gt;
[[HFProfile:1148878|&amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Clique:&amp;lt;/span&amp;gt;]] Shoutout to my buds. You know who you are.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[D3xus|&amp;lt;span style=&amp;quot;color: lime;&amp;quot;&amp;gt;D3xus:&amp;lt;/span&amp;gt;]] You&#039;ve got a lot of friends from what I gather. Where did you meet them all? Or at least the majority of them?&lt;br /&gt;
&lt;br /&gt;
[[HFProfile:1148878|Clique:]] From previous groups, writers, few from empire and such. Met a few people on League/CSGO that surprisingly were on HF as well. It&#039;s a small world.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[D3xus|&amp;lt;span style=&amp;quot;color: lime;&amp;quot;&amp;gt;D3xus:&amp;lt;/span&amp;gt;]] A small world for us, but a giant world for others. How did you get involved with your groups? What attracted you to them?&lt;br /&gt;
&lt;br /&gt;
[[HFProfile:1148878|Clique:]] I just wanted to see what the hype was about, really. When I signed up I believe Eminence was still around and that was my first one that I&#039;ve been into. I remember Viral Dragon made tutorials and I saved most of them on my laptop for later use. Usually about making money, you know the drill.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[D3xus|&amp;lt;span style=&amp;quot;color: lime;&amp;quot;&amp;gt;D3xus:&amp;lt;/span&amp;gt;]] Money is always a big deal around here. Have you gotten into monetization, or do you have other interests on HF?&lt;br /&gt;
&lt;br /&gt;
[[HFProfile:1148878|Clique:]] At first yeah I was crazed with making money online. I&#039;ve sold a few randoms things on here but never really had the time to fully pursue it. I play a bit of League so that&#039;s what I do here mainly.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[D3xus|&amp;lt;span style=&amp;quot;color: lime;&amp;gt;D3xus:&amp;lt;/span&amp;gt;]] The League scene has always been big on HF; are you a casual player or are you on a team/clan?&lt;br /&gt;
&lt;br /&gt;
[[HFProfile:1148878|Clique:]] I&#039;ve tried 5s/3s teams but those never really work out because of people&#039;s schedules. :(&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[D3xus|&amp;lt;span style=&amp;quot;color: lime;&amp;quot;&amp;gt;D3xus:&amp;lt;/span&amp;gt;]] That happens a lot of the time, I&#039;m sure. D: What other things on HF are you involved in? Or not even HF, but just online?&lt;br /&gt;
&lt;br /&gt;
[[HFProfile:1148878|Clique:]] That&#039;s pretty much it. Was a writer for almost 2 years. Just chillin right now. Job starts on monday so I should be busy.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[D3xus|&amp;lt;span style=&amp;quot;color: lime;&amp;quot;&amp;gt;D3xus:&amp;lt;/span&amp;gt;]] Do you take anything from HF into real life? Is your job relevant to anything you&#039;ve learned here, or are they totally separate?&lt;br /&gt;
&lt;br /&gt;
[[HFProfile:1148878|Clique:]] Learned a bit about computers here so that&#039;ll help. :cool:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[D3xus|&amp;lt;span style=&amp;quot;color: lime;&amp;quot;&amp;gt;D3xus:&amp;lt;/span&amp;gt;]] As it will with anything. That&#039;s all the room we have for now; any closing comments or remarks?&lt;br /&gt;
&lt;br /&gt;
[[HFProfile:1148878|Clique:]] https://soundcloud.com/fouram/fouram-nyquill-no-more&lt;br /&gt;
&lt;br /&gt;
| CustomSection1_Title    = Group News&lt;br /&gt;
| CustomSection1_Author1  = [[Nobility|Nobility]]&lt;br /&gt;
| CustomSection1_Author2  = [[HFProfile:1595524|Ventures]]&lt;br /&gt;
| CustomSection1_Content  = &lt;br /&gt;
&amp;lt;span style=&amp;quot;font-weight: bold; color: white&amp;quot;&amp;gt;Current Open Group Recruitments&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4897102 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt;&amp;gt;&amp;gt; [Official Group Debug] &amp;lt;&amp;lt; || Summertime Student Sector || Learn how to Code ||&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4577596 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt;L&#039;appel du vide recruitment&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4876267 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt;Specialists | Official Group | General Recruitment | Opened Again for Limited Time&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4896227 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt;The Brotherhood \\ White Hat Helper Course \\ Student Program&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;font-weight: bold; color: white&amp;quot;&amp;gt;Group Related Buy-ins &amp;amp; Informational Threads&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4827973 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt; - Instinct Buy Ins - BTC Only - Official Group - Super Active &amp;amp; Fun -&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4851548 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt; Debug Leadership&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4881279 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt; Null Consolidated | Monthly Students $100 &amp;amp; Lifetime Students $400 |&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4456035 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt;Titans | Official Group&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;span style=&amp;quot;font-weight: bold; color: white&amp;quot;&amp;gt;Important Group Related Threads&amp;lt;/span&amp;gt;&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4704732 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt;$75 and group spot (GFX REQUEST)&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
* [http://www.hackforums.net/showthread.php?tid=4812674 &#039;&#039;&#039;&amp;lt;nowiki&amp;gt;&amp;quot;Selling&amp;quot; group leader spot 1k for as long as two weeks!&amp;lt;/nowiki&amp;gt;&#039;&#039;&#039;]&lt;br /&gt;
| CustomSection2_Title    = Site News&lt;br /&gt;
| CustomSection2_Author1  = [[HFProfile:1079277|Harlem]]&lt;br /&gt;
| CustomSection2_Author1  = [[HFProfile:2585207|Charlemagne]]&lt;br /&gt;
| CustomSection2_Content  = &lt;br /&gt;
&lt;br /&gt;
===Site Statistics===&lt;br /&gt;
&lt;br /&gt;
* &#039;&#039;&#039;Total&#039;&#039;&#039;&lt;br /&gt;
* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt; 46,970,660 ( &amp;lt;span style=&amp;quot;color: #32CD32;&amp;quot;&amp;gt;+0.18%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt;  3,401,664 (&amp;lt;span style=&amp;quot;color: #32CD32;&amp;quot;&amp;gt;+0.26%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Members:&amp;lt;/span&amp;gt; 2,794,346 ( &amp;lt;span style=&amp;quot;color: #32CD32;&amp;quot;&amp;gt;+0.27%&amp;lt;/span&amp;gt; )&lt;br /&gt;
&lt;br /&gt;
* &#039;&#039;&#039;Average&#039;&#039;&#039;&lt;br /&gt;
* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Daily Posts:&amp;lt;/span&amp;gt; 14,005( &amp;lt;span style=&amp;quot;color: #FFD700;&amp;quot;&amp;gt;~&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Daily Threads:&amp;lt;/span&amp;gt; 1,014( &amp;lt;span style=&amp;quot;color: #32CD32;&amp;quot;&amp;gt;+0.15%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Daily New Members:&amp;lt;/span&amp;gt; 833 ( &amp;lt;span style=&amp;quot;color: #32CD32;&amp;quot;&amp;gt;+0.18%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts Per Member:&amp;lt;/span&amp;gt; 16 (  &amp;lt;span style=&amp;quot;color: #FFD700;&amp;quot;&amp;gt;~&amp;lt;/span&amp;gt;)&lt;br /&gt;
* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Replies Per Thread:&amp;lt;/span&amp;gt; 12 (  &amp;lt;span style=&amp;quot;color: #FFD700;&amp;quot;&amp;gt;~&amp;lt;/span&amp;gt; )&lt;br /&gt;
&lt;br /&gt;
===Ban Statistics===&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Last Week&#039;s Bans&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Staff Bans:&amp;lt;/span&amp;gt; 170&lt;br /&gt;
::* &amp;lt;span style=&amp;quot;font-style: italic;&amp;quot;&amp;gt;... Change from Last Edition:&amp;lt;/span&amp;gt; &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-12&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Vacation Bans:&amp;lt;/span&amp;gt; 16&lt;br /&gt;
::* &amp;lt;span style=&amp;quot;font-style: italic;&amp;quot;&amp;gt;... Change from Last Edition:&amp;lt;/span&amp;gt; &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-8&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Combined Bans:&amp;lt;/span&amp;gt; 186&lt;br /&gt;
::* &amp;lt;span style=&amp;quot;font-style: italic;&amp;quot;&amp;gt;... Change from Last Edition:&amp;lt;/span&amp;gt; &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-20&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Total Bans&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Staff Bans:&amp;lt;/span&amp;gt; 645&lt;br /&gt;
::* &amp;lt;span style=&amp;quot;font-style: italic;&amp;quot;&amp;gt;... Change from Last Edition:&amp;lt;/span&amp;gt; &amp;lt;span style=&amp;quot;color: #32CD32;&amp;quot;&amp;gt;+40&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Vacation Bans:&amp;lt;/span&amp;gt; 87&lt;br /&gt;
::* &amp;lt;span style=&amp;quot;font-style: italic;&amp;quot;&amp;gt;... Change from Last Edition:&amp;lt;/span&amp;gt; &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-12&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Combined Bans:&amp;lt;/span&amp;gt; 732&lt;br /&gt;
::* &amp;lt;span style=&amp;quot;font-style: italic;&amp;quot;&amp;gt;... Change from Last Edition:&amp;lt;/span&amp;gt; &amp;lt;span style=&amp;quot;color: #32CD32;&amp;quot;&amp;gt;+30&amp;lt;/span&amp;gt;&lt;br /&gt;
===Forum Counts===&lt;br /&gt;
&lt;br /&gt;
* &#039;&#039;&#039;Tab Counts&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
* &#039;&#039;&#039;Notable Sections&#039;&#039;&#039;&lt;br /&gt;
* [http://www.hackforums.net/forumdisplay.php?fid=25 &amp;lt;span style=&amp;quot;font-weight: bold; text-decoration: underline;&amp;quot;&amp;gt;Lounge&amp;lt;/span&amp;gt;] &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads&amp;lt;/span&amp;gt;: 429,120 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.13%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* [http://www.hackforums.net/forumdisplay.php?fid=25 &amp;lt;span style=&amp;quot;font-weight: bold; text-decoration: underline;&amp;quot;&amp;gt;Lounge&amp;lt;/span&amp;gt;] &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts&amp;lt;/span&amp;gt;: 6,073,735 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.15%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* [http://www.hackforums.net/forumdisplay.php?fid=2 &amp;lt;span style=&amp;quot;font-weight: bold; text-decoration: underline;&amp;quot;&amp;gt;RANF&amp;lt;/span&amp;gt;] &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads&amp;lt;/span&amp;gt;:46,476( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.23%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* [http://www.hackforums.net/forumdisplay.php?fid=2 &amp;lt;span style=&amp;quot;font-weight: bold; text-decoration: underline;&amp;quot;&amp;gt;RANF&amp;lt;/span&amp;gt;] &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts&amp;lt;/span&amp;gt;:  605,560 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.19%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;General&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 695,997 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.17%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt; 10,271,736 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.18%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Hacking&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 641,971( &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-7.57%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt;5,627,301( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.26%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Computing&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 193,241 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.19%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt; 1,645,144 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.16%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Coding&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 155,032( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.11%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt; 1,340,608( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.11%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Gaming&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 404,625 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.21%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt; 4,170,255( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.21%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Groups&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 6,281 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.14%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt; 275,073( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.13%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Webmaster&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 74,182 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.13%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt;540,723 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.12%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Graphics&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 124,672( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.10%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt; 939,700 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.08%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Marketplace&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 815,356 ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.23%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt; 7,633,241 (&amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.19%&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Money&amp;lt;/span&amp;gt;&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Threads:&amp;lt;/span&amp;gt; 125,460  ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+0.17%&amp;lt;/span&amp;gt; )&lt;br /&gt;
:* &amp;lt;span style=&amp;quot;text-decoration: underline;&amp;quot;&amp;gt;Posts:&amp;lt;/span&amp;gt; 1678259( &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-0.06%&amp;lt;/span&amp;gt; )&lt;br /&gt;
===Membership Counts===&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold; text-decoration: underline;&amp;quot;&amp;gt;Groups&amp;lt;/span&amp;gt;&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Null&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 45 Members ( &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-2&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Specialists&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 62 Members ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+12&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Red Lions&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 19 Members ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+1&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Archive&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 12 Members ( &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-2&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Crypto&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 66 Members ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+18&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;L&#039;appel du Vide&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 101 Members ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+5&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;The Brotherhood&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 23 Members ( &amp;lt;span style=&amp;quot;color: #FFD700;&amp;quot;&amp;gt;~&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Echo&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 62 Members ( &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-18&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;AnimeFAN!&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 64 Members ( &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-3&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Pirates&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 184 Members ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+4&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Instinct&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 133 Members ( &amp;lt;span style=&amp;quot;color: #32CD32:&amp;quot;&amp;gt;+10&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Debug&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 3 Members ( &amp;lt;span style=&amp;quot;color: #FFD700;&amp;quot;&amp;gt;-73&amp;lt;/span&amp;gt; )&lt;br /&gt;
* &amp;lt;span style=&amp;quot;font-weight: bold;&amp;quot;&amp;gt;Titans&amp;lt;/span&amp;gt;&lt;br /&gt;
:* 30 Members ( &amp;lt;span style=&amp;quot;color: #FF0000;&amp;quot;&amp;gt;-3&amp;lt;/span&amp;gt; )&lt;br /&gt;
&lt;br /&gt;
| CustomSection3_Title    = Memo&lt;br /&gt;
| CustomSection3_Author1  = [[iHydra]]&lt;br /&gt;
| CustomSection3_Content  = &lt;br /&gt;
===Dry Week===&lt;br /&gt;
Not much has occurred besides a few drama scenes flowing through the Deal Disputes subforum.&lt;br /&gt;
&lt;br /&gt;
===eJDJbuKdevSefK=efK=eOdGGl2fynHeqbhn1jg81RJJVQYz9ih1Yjb55===&lt;br /&gt;
http://crypo.in.ua/tools/eng_megan35c.php&lt;br /&gt;
&lt;br /&gt;
===Have a wonderful day===&lt;br /&gt;
Enjoy your shitty moments and fun/great moments in life.&lt;br /&gt;
&lt;br /&gt;
| CustomSection4_Title    = Security News&lt;br /&gt;
| CustomSection4_Author1  = [[HFProfile:1696750|Harbo5]]&lt;br /&gt;
| CustomSection4_Content  = &lt;br /&gt;
===OPM Hack Revealed To Include Data of 21.5 Million People and Director Archuleta Resigned===&lt;br /&gt;
The recent data breach at the Office of Personal Management seems to be ever expanding. It has been discovered that it includes the Social Security Numbers of over 21.5 million people. The group of compromised people includes OPM director Katherine Archuleta who resigned early Friday. Ever since the attack was discovered las month, Archuleta has been under increasing pressure. US Legislators took Archuleta and CIO Donna Seymor last month to task for not addressing security issues and failing to add security and control features such as database encryption or agency-wide two-factor authentication. &amp;quot;You have completely and utterly failed, if that was your mission,&amp;quot; Rep. Jason Chaffetz (R-Utah) said during the hearing. Archuleta told President Barack Obama on Friday that she was resigning from her position as Director of OPM. She had been the director since 2013. Congressional Members have said there are still may issues awaiting the next director of OPM. The new total of affected people by the data breach comes as DHS, FBI, and OPM official continue to investigate the attack on OPM, which began last December. Officials said that in addition to the 4.2 million affected people who had already been notified, 19.7 million people who applied for a background check, and 1.8 million non-applicants such as spouses also have been affected. The OPM believes there were two separate attacks, one the affected 4.2 million current and former US government employees, and the second that affected 21.5 million addition people. &amp;lt;span style=&amp;quot;font-style: italic; font-size: x-small;&amp;quot;&amp;gt;[https://threatpost.com/opm-hack-expands-to-include-data-of-21-5-million-people/113717 &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Census Project Identifies Open Source Tools at Risk===&lt;br /&gt;
While Heartbleed may have brought on a major disaster for System Admins worldwide, but a positive offshoot of the biggest of the Internet-wife bugs was that it opened a lot of eyes to the lack of support afforded even ubiquitous open source software projects. Shortly after Heartbleed was found in OpenSSL, a consortium by the name of Core Infrastructure, originally backed by the Linux Foundation, Google, Microsoft, Facebook, Amazon, Dell and other tech giants, began dumping money into the OpenSSL Project. The benefits were immediate for the maintainers of the crypto library who were able to fund two full-time employees and around a dozen part-timers to get the code cleaned up and audited. Soon thereafter, money also began being funneled to OpenSSH, NTP, and GnuPG. On Thursday, the CII announced more help for under-funded and under-resourced open source projects via the release to open source of the full source and data from the Census Project. Until recently, the tool was used to assess risks to open source projects and helped the CII decide which were in the most immediate need of support, or deprecation if suitable alternatives existed. Along with a white paper. The Census Project currently maintains a list of hundreds open source software projects that it analyzed, and some of the metrics used to include the number of contributions made to a project and the number of CVEs posted against it, all of which factor into a risk index for each project. Ratliff said the CII has already received suggestions for metrics based on those used in other open source projects, such as Fedora, the open source Linux-based system made by the Fedora Project and sponsored by Red hat. &amp;lt;span style=&amp;quot;font-style: italic; font-size: x-small;&amp;quot;&amp;gt;[https://threatpost.com/census-project-identifies-open-source-tools-at-risk/113726 &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===OpenSSL Patches Critical Certificate Validation Vulnerability===&lt;br /&gt;
The Organizations that installed the OpenSSL update released on June 11th need to pull it back immediately. A serious certificate validation error was discovered and patched today in a new update. The bug was reported to the OpenSSL project by Google researcher Adam Langley and BoringSSL&#039;s David Benjamin, and affects only OpenSSL 1.0.1 and 1.0.2. “It’s a bad bug, but only affects anyone who installed the release from June,” said Rich Salz, a member of the OpenSSL development team. The bug was introduced during that update and affected relatively few organizations. “It’s a bad bug, but the impact is low. We haven’t heard any reports of it being used in production.” The vulnerability allows an attacker with an untrusted TLS certificate the be considered a certificate authority and spoof another website. This allows attackers to redirect traffic, setup man-in-the-middle attacks, phishing schemes, and anything that compromises supposedly encrypted traffic. As of Thursday, said Salz, there are no public reports of exploitation. During certificate verification, OpenSSL will attempt to find an alternative certificate chain if the first attempt to build such a chain fails,” OpenSSL said in today’s advisory. “An error in the implementation of this logic can mean that an attacker could use certain checks on untrusted certificates to be bypassed, such as the CA flag, enabling them to use a valid leaf certificate to act as a CA and ‘issue’ an invalid certificate. Salz said that the patch required one line of code. A test case will also be developed for this type of bug he added. &amp;lt;span style=&amp;quot;font-style: italic; font-size: x-small;&amp;quot;&amp;gt;[https://threatpost.com/openssl-patches-critical-certificate-validation-vulnerability/113703 &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
| CustomSection5_Title    = Gaming News&lt;br /&gt;
| CustomSection5_Author1  = [[HFProfile:981500|Premortal]]&lt;br /&gt;
| CustomSection5_Author2  = [[HFProfile:1864779|Red Sox]]&lt;br /&gt;
| CustomSection5_Content  = &lt;br /&gt;
===&#039;&#039;Black Ops 3&#039;&#039; Juggernog Edition Leak and Announcement===&lt;br /&gt;
A leaked product listing from New Zealand retailer Mighty Ape shows a special edition of the upcoming &#039;&#039;Black Ops 3&#039;&#039; Call of Duty game, called the Juggernog Edition. The leak doesn’t name a price, but it shows that this edition comes with some collectible Perk-A-Cola coasters, a working mini fridge replica of the Juggernog machine, and some online perks that includes the &#039;&#039;Black Ops 3&#039;&#039; season pass, nine cards for Specialist characters in &#039;&#039;Black Ops 3&#039;&#039; online gameplay, and a bonus map for zombies based on Der Riese. It was later made public by Gamestop and other retailers that the price for this edition would be $199.99 USD. &#039;&#039;Black Ops 3&#039;&#039; is set to release on the Xbox One, Playstation 4, and PC on November 6. It’s also currently in development for both the Xbox 360 and the Playstation 3. &#039;&#039;&amp;lt;span style=&amp;quot;font-size: x-small;&amp;quot;&amp;gt;[http://www.polygon.com/2015/7/9/8922461/call-of-duty-black-ops-3-juggernog-edition-leak &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Kojima Productions Allegedly Disbanded===&lt;br /&gt;
It has been reported by several sources in the past few months that there have been troubles between Konami and Metal Gear Solid creator Hideo Kojima. A new voice of confirmation recently was from Otsuka Akio, who has voiced Snake in multiple Metal Gear Solid Games, saying that Kojima Productions no longer exists as a development studio. This news comes from his official twitter page, found in Japanese [https://twitter.com/AkioOtsuka/status/619604474022096896 here]. In the process he voiced how he thinks &#039;&#039;Metal Gear Solid V: The Phantom Pain&#039;&#039; will be the team’s greatest work. Official news regarding the status of Kojima Productions has still not been released by Konami.  &#039;&#039;&amp;lt;span style=&amp;quot;font-size: x-small;&amp;quot;&amp;gt;[http://www.gamespot.com/articles/kojima-productions-has-disbanded-says-metal-gear-s/1100-6428811/ &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===&#039;&#039;Doom&#039;&#039;, &#039;&#039;Fallout 4&#039;&#039;, and &#039;&#039;The Elder Scrolls Online&#039;&#039; to be Featured at QuakeCon 2015===&lt;br /&gt;
It has been posted on the official QuakeCon site the schedule for the event, including and featuring title such as Doom, Fallout 4, and The Elder Scrolls Online. The event is set to take place from July 23 to July 25. Registration for the event, which takes place in Dallas, Texas, can be done [https://registration.quakecon.org/ here]. Those who can’t attend can view the event on its official Twitch page, which can be found [http://www.twitch.tv/QuakeCon here]. &#039;&#039;&amp;lt;span style=&amp;quot;font-size: x-small;&amp;quot;&amp;gt;[http://www.polygon.com/2015/7/9/8924331/quakecon-2015-doom-fallout-4-elder-scrolls-schedule &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
| CustomSection6_Title    = Tech News&lt;br /&gt;
| CustomSection6_Author1  = [[HFProfile:1356937|Angel]]&lt;br /&gt;
| CustomSection6_Author2  = [[HFProfile:1730460|Gladly]]&lt;br /&gt;
| CustomSection6_Content  = &lt;br /&gt;
===Adobe Patches Flash Bug Exploited After Hacking Team Leak===&lt;br /&gt;
The weekend breach of Hacking Team, an Italian firm who sells spying software to intelligence agencies around the world, left Adobe Flash vulnerable to attack. On Sunday, 400 gigabytes of private data stolen from the company, including details of the software flaw, were published online, indicating it knew about a serious flaw in Flash, but had not told Adobe.&lt;br /&gt;
&lt;br /&gt;
Inside the leaked source code lies an Adobe Flash exploit for which no patch had existed: it can be used against Internet Explorer, Firefox, Chrome and Safari, and affects Flash Player 9 to the latest version, 18.0.0.194. Adobe released a patch for the bug on Wednesday, which covers Flash Player for all existing platforms. &amp;quot;These updates address critical vulnerabilities that could potentially allow an attacker to take control of the affected system,&amp;quot; Adobe said. [http://www.bbc.com/news/technology-33442789 &amp;lt;span style=&amp;quot;font-style: italic; font-size: x-small;&amp;quot;&amp;gt; &amp;gt;&amp;gt;Source&amp;lt;/span&amp;gt;]&lt;br /&gt;
&lt;br /&gt;
===Microsoft to Cut Thousands of Jobs Due to Failing Smartphone Business===&lt;br /&gt;
Computer giant Microsoft said Wednesday it would wave a white flag of sorts for its struggling smartphone division, slashing up to 7,800 worldwide jobs and writing down a $7.6 billion loss amid a massive restructuring to better compete with the new titans in American tech. The move is a clear acknowledgment that the deal was a multibillion-dollar strategic blunder by Mr. Ballmer, who had envisioned it as a way to make Microsoft more competitive in the mobile market dominated by Apple, Google and Samsung. Mr. Nadella is said to have disliked the acquisition originally, though he publicly endorsed it after becoming chief executive.&lt;br /&gt;
&lt;br /&gt;
The second-biggest layoff in Microsoft history will hit about 6 percent of the tech legend&#039;s 118,000 employees, a cut nearly twice the size of Twitter&#039;s entire workforce. The company was already reeling from 18,000 layoffs announced last year, mostly in its Windows Phone division. [http://www.nytimes.com/2015/07/09/technology/microsoft-layoffs.html &amp;lt;span style=&amp;quot;font-style: italic; font-size: x-small;&amp;quot;&amp;gt; &amp;gt;&amp;gt;Source&amp;lt;/span&amp;gt;]&lt;br /&gt;
&lt;br /&gt;
===Google Is Now Selling an Ethernet Adapter For Chromecast===&lt;br /&gt;
Google&#039;s Chromecast is one of the easiest to use and most widely supported TV streaming sticks out there, but the only way to use it has been over a Wi-Fi connection. If you live in an area where you can’t get a good wireless signal or would rather prefer an Ethernet connection for your Internet needs, Google has just released a product to its web store that will make using your Chromecast much easier. The newest little accessory in the Google Store is a hardwired Ethernet adapter for the Chromecast, and it’s conveniently priced at only $15. This new device is a power brick that plugs directly into your Chromecast’s MicroUSB port. You can then plug your Ethernet cable in to the power brick, and never have to worry about dealing with spotty Wi-Fi connections again.&lt;br /&gt;
&lt;br /&gt;
Although the new accessory just launched in the Google Store recently, it’s unfortunately already sold out. No announcements have been made on when the company will have more units for sale. Also, it seems as though this is a U.S.-only accessory for now. [http://arstechnica.com/gadgets/2015/07/googles-chromecast-gets-a-hardwired-ethernet-adapter/ &amp;lt;span style=&amp;quot;font-style: italic; font-size: x-small;&amp;quot;&amp;gt; &amp;gt;&amp;gt;Source&amp;lt;/span&amp;gt;]&lt;br /&gt;
| CustomSection7_Title    = World News&lt;br /&gt;
| CustomSection7_Author1  = [[Happeh]]&lt;br /&gt;
| CustomSection7_Content  = &lt;br /&gt;
===Mexican Drug Lord Escapes===&lt;br /&gt;
Mexican drug lord Joaquin Guzman who is also known as El Chapo or &amp;quot;Shorty&amp;quot; has used an &#039;elaborate tunnel&#039; to break out of a maximum security prison. His escape from Altiplano jail was over a mile long and had ventilation and stairs. This is now his second time escaping from prison. Earlier in the year the government had dismissed claims that Guzman could escape again but the worst has happened and the escape is a huge embarrassment to the government of President Enrique Pena Nieto. Guzman is approximately worth $1bn and a country-wide manhunt is in progress to track him down and recapture him. &amp;lt;span style=&amp;quot;font-style: italic; font-size: x-small;&amp;quot;&amp;gt;[http://www.bbc.co.uk/news/world-latin-america-33498573 &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Islamic State Behind Blast At The Italian Consulate===&lt;br /&gt;
Islamic State (IS) have said they were behind a deadly explosion outisde the Italian consulate which has killed one person and several more were injured. The blast was caused by a car bomb at Egypt&#039;s capital, Cairo, with the building also being severely damaged. A tweet from a Twitter account which is linked to the IS has claimed that Muslims should stay away from buildings like the consulate as they are &amp;quot;legitimate targets&amp;quot; for strikes. &amp;quot;Italy will not let itself be intimidated,&amp;quot; the country&#039;s foreign minister Paolo Gentiloni said in a tweet, adding that there had been no Italian casualties. &amp;lt;span style=&amp;quot;font-style: italic; font-size: x-small;&amp;quot;&amp;gt;[http://www.bbc.co.uk/news/world-middle-east-33491512 &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Typhoon Hits China===&lt;br /&gt;
A powerful typhoon named Chan-hom has made landfall along the coast of China&#039;s eastern Zhejiang province. An estimated number of one million people have been evacuated from the coastal areas in anticipation of the typhoon carrying wind speeds of 173km/h (107mph). Some 100mm of rain has fallen since Friday. Chan-hom is now heading north past the city of Shanghai. The typhoon hit Taiwan and Japan earlier in the week, uprooting trees and injuring several people. So far there have been no deaths caused by the typhoon and only a few minor injuries. Over 400 flights have also been cancelled due to the typhoon along with numerous public events amidst concerns of safety. 100s of train services and Zhejiang province has called its entire fishing fleet back to port. The highest red-alert warning remains in force, despite the storm being downgraded in category from super to strong. &amp;lt;span style=&amp;quot;font-style: italic; font-size: x-small;&amp;quot;&amp;gt;[http://www.bbc.co.uk/news/world-asia-33491507 &amp;gt;&amp;gt;Source]&amp;lt;/span&amp;gt;&lt;br /&gt;
| CustomSection8_Title    = Battlestations&lt;br /&gt;
| CustomSection8_Author1  = [[iHydra]]&lt;br /&gt;
| CustomSection8_Content  = &lt;br /&gt;
Need to add ihydra.net as an external image whitelist&lt;br /&gt;
http://ihydra.net/hfnt/headers/BattlestationImage_248.png&lt;br /&gt;
&lt;br /&gt;
| CustomSection9_Title    = Battlestations&lt;br /&gt;
| CustomSection9_Author1  = [[HFProfile:1138866|Rivalry]]&lt;br /&gt;
| CustomSection9_Content  = &lt;br /&gt;
Need to add ihydra.net as an external image whitelist&lt;br /&gt;
http://i.minus.com/iygkIqqjBn4gd.png&lt;br /&gt;
&lt;br /&gt;
Are comics necessary?&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
THIS IS WIP, IGNORE THE INCORRECT DATA&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Hack_Forums_Wiki:General_disclaimer&amp;diff=6041</id>
		<title>Hack Forums Wiki:General disclaimer</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Hack_Forums_Wiki:General_disclaimer&amp;diff=6041"/>
		<updated>2015-07-27T09:26:03Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Redirected page to Terms Of Use&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Terms Of Use]]&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=MOTM_Timeline&amp;diff=6038</id>
		<title>MOTM Timeline</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=MOTM_Timeline&amp;diff=6038"/>
		<updated>2015-07-26T23:52:02Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Created page with &amp;quot;Category:Archives&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:Archives]]&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Wiki_Team&amp;diff=4764</id>
		<title>Wiki Team</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Wiki_Team&amp;diff=4764"/>
		<updated>2015-07-18T12:16:43Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;__TOC__&lt;br /&gt;
This Wiki has been created and maintained by the HF Wiki Team, a sub-section of the [[Writ3rs]]. The team consists of a group of volunteers who perform tasks in several different roles. &lt;br /&gt;
&lt;br /&gt;
==The Roles==&lt;br /&gt;
*&#039;&#039;&#039;Leaders&#039;&#039;&#039;&lt;br /&gt;
** The leaders are in place to manage, organize and provide general support and advice to the team. They have absolute authority over all things related to the Wiki. Any issues within the team should be taken to the leaders to be addressed. Finally, they are directly in control of the the Wiki, its location and security.&lt;br /&gt;
&lt;br /&gt;
*&#039;&#039;&#039;Editors&#039;&#039;&#039;&lt;br /&gt;
** The editors are charged with the task of editing, re-writing, proofreading and amending articles created by the writers. They deal directly with the writers and can offer advice on grammar, structure and expansion of articles.&lt;br /&gt;
&lt;br /&gt;
*&#039;&#039;&#039;Publishers&#039;&#039;&#039;&lt;br /&gt;
** The publishers are assigned the task of structuring and maintaining the Wiki. They will upload and format all articles created by the team to the Wiki. They also manage the Wiki&#039;s structure and ensure all articles are neatly categorized and easily accessible to the forum members.&lt;br /&gt;
&lt;br /&gt;
*&#039;&#039;&#039;Writers&#039;&#039;&#039;&lt;br /&gt;
** The writers form the backbone of the team. They write the content and articles that forms the Wiki. They work with the editors in order to finalize an article and ensure it is of quality.&lt;br /&gt;
==Current Members==&lt;br /&gt;
With the publicization of the Wiki, the roles are no longer held in strict regard and everyone pitches in with publishing, editing, writing and updating. However, a general idea is provided below.&lt;br /&gt;
&lt;br /&gt;
*[[Ethereal]] | Leader; team and server&lt;br /&gt;
*[[iceybunneh]] | Previously RHW; editing&lt;br /&gt;
*[[Viral Dragon]] | Previous leader; server&lt;br /&gt;
*[[Roger Waters]] | Templates and accuracy&lt;br /&gt;
*[[D3xus]] | Templates and theme&lt;br /&gt;
*[[Premortal]] | General&lt;br /&gt;
*[[Happeh]] | General&lt;br /&gt;
*[[Tony Stark]] | General&lt;br /&gt;
*[[Thornzzz]] | General&lt;br /&gt;
*[[Phoenix]] | Graphic and design&lt;br /&gt;
&lt;br /&gt;
==Past Members==&lt;br /&gt;
Past members of the Wiki team in alphabetical order. To be considered for this list, you have to have contributed at least one article in &lt;br /&gt;
the Writ3rs wiki forum. &lt;br /&gt;
*[[!!* Alone Vampire *!!]]&lt;br /&gt;
*[[+Reckless]]&lt;br /&gt;
*[[Analog]]&lt;br /&gt;
*[[Ariana]]&lt;br /&gt;
*[[Bandors]]&lt;br /&gt;
*[[CarrotMilk]]&lt;br /&gt;
*[[Coffee]]&lt;br /&gt;
*[[Cyber-Security]]&lt;br /&gt;
*[[DragScope]]&lt;br /&gt;
*[[Empowerment]]&lt;br /&gt;
*[[Froggy]]&lt;br /&gt;
*[[Foe]]&lt;br /&gt;
*[[Glassy]]&lt;br /&gt;
*[[Grin]]&lt;br /&gt;
*[[Harry Dresden]]&lt;br /&gt;
*[[Hexicidal]]&lt;br /&gt;
*[[Kōtei]]&lt;br /&gt;
*[[KoolDude87]]&lt;br /&gt;
*[[Lemonade]]&lt;br /&gt;
*[[Lions]]&lt;br /&gt;
*[[Milf]]&lt;br /&gt;
*[[Mr. Anderson]]&lt;br /&gt;
*[[opiates]]&lt;br /&gt;
*[[Paradoxum]]&lt;br /&gt;
*[[Penar]]&lt;br /&gt;
*[[Peter L]]&lt;br /&gt;
*[[Phytrix]]&lt;br /&gt;
*[[RDCA]]&lt;br /&gt;
*[[Revenge]]&lt;br /&gt;
*[[Roger Waters]]&lt;br /&gt;
*[[SkyGuy]]&lt;br /&gt;
*[[SomeWhiteGuy]]&lt;br /&gt;
*[[T3h Hack3r]]&lt;br /&gt;
*[[Tando]]&lt;br /&gt;
*[[Thornzzz]]&lt;br /&gt;
*[[Ultimatum™]]&lt;br /&gt;
*[[Venusaur]]&lt;br /&gt;
*[[Wallet]]&lt;br /&gt;
*[[Wonders]]&lt;br /&gt;
*[[xadamkx]]&lt;br /&gt;
*[[ιnѕιdιoυѕ]]&lt;br /&gt;
*[[ラジカル]]&lt;br /&gt;
&lt;br /&gt;
==Contact us==&lt;br /&gt;
Any and all queries can be directed towards one of the leaders. Our preferred method of contact is via PM on [http://www.hackforums.net/ Hack Forums].&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=NewsFeed&amp;diff=4626</id>
		<title>NewsFeed</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=NewsFeed&amp;diff=4626"/>
		<updated>2015-07-17T12:10:26Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Test content.&lt;br /&gt;
[[Category:Bulletins]]&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=NewsFeed&amp;diff=4623</id>
		<title>NewsFeed</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=NewsFeed&amp;diff=4623"/>
		<updated>2015-07-17T12:03:38Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Header 1==&lt;br /&gt;
*Test Content&lt;br /&gt;
==Header 2==&lt;br /&gt;
*Test Content 2&lt;br /&gt;
[[Category:Bulletins]]&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=NewsFeed&amp;diff=4622</id>
		<title>NewsFeed</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=NewsFeed&amp;diff=4622"/>
		<updated>2015-07-17T12:01:58Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Header 1==&lt;br /&gt;
Test Content&lt;br /&gt;
==Header 2==&lt;br /&gt;
Test Content 2&lt;br /&gt;
[[Category:Bulletins]]&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=NewsFeed&amp;diff=4621</id>
		<title>NewsFeed</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=NewsFeed&amp;diff=4621"/>
		<updated>2015-07-17T11:59:56Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Created page with &amp;quot;==Header 1==  ==Header 2==  Category:Bulletins&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Header 1==&lt;br /&gt;
&lt;br /&gt;
==Header 2==&lt;br /&gt;
&lt;br /&gt;
[[Category:Bulletins]]&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Main_Page&amp;diff=4620</id>
		<title>Main Page</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Main_Page&amp;diff=4620"/>
		<updated>2015-07-17T11:59:25Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;span style=&amp;quot;float: right; width: 15%;&amp;quot;&amp;gt;&amp;lt;wikitwidget class=&amp;quot;twitter-timeline&amp;quot; href=&amp;quot;https://twitter.com/hackforumsnet&amp;quot; data-widget-id=&amp;quot;619582438273085440&amp;quot; /&amp;gt;&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Welcome to the Hack Forums Official Wiki!&lt;br /&gt;
&lt;br /&gt;
The [[Hack Forums]] Wiki is a collaboration of useful and unique information about the website [http://hackforums.net HackForums.net]. It details user biographies, award information, the history of the website, and much more. The Wiki is a place where members new and old can find out more about a certain user, an in-depth analysis on one of the popular tools or people on the forum, or even just have some clarification of a specific hacking term that they may not have heard before. The Wiki is constantly being updated, checked, and scrutinized to make sure that members have the most accurate information on a particular topic.&lt;br /&gt;
&lt;br /&gt;
It is currently maintained by the [[Wiki Team]].&lt;br /&gt;
&lt;br /&gt;
==How to Contribute==&lt;br /&gt;
&lt;br /&gt;
Unlike other public wikis, the Hack Forums Wiki is carefully moderated. Because of this, the ability to freely edit articles is restricted, in order to preserve the integrity and accuracy of the site&#039;s articles. If you wish to make a suggestion or contribution, please contact [http://www.hackforums.net/private.php?action=send&amp;amp;uid=458069 Ethereal] via the Hack Forums Instant Message or Private Message systems.&lt;br /&gt;
&lt;br /&gt;
Alternatively, you can [http://wiki.hackforums.net/index.php?title=Special:UserLogin&amp;amp;returnto=Main+Page&amp;amp;type=signup register] for the Wiki, or contribute to the public [http://www.hackforums.net/forumdisplay.php?fid=336 Wiki forum].&lt;br /&gt;
&lt;br /&gt;
==Recent HF News==&lt;br /&gt;
&amp;lt;newsBulletins&amp;gt;&amp;lt;/newsBulletins&amp;gt;&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=The_Brotherhood&amp;diff=4461</id>
		<title>The Brotherhood</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=The_Brotherhood&amp;diff=4461"/>
		<updated>2015-07-16T12:25:22Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{GroupBox&lt;br /&gt;
| GroupName         = The Brotherhood&lt;br /&gt;
| GroupBanner       = The Brotherhood (Banner).png&lt;br /&gt;
| GroupUserbar      = The Brotherhood (Userbar).png&lt;br /&gt;
| Userbar2          = &lt;br /&gt;
| Userbar3          = &lt;br /&gt;
| GroupDesc         = The Brotherhood is a usergroup of individuals who are bound by loyalty to exercise their skills, knowledge, and time, which will encourage the acts of assisting oneself and others. &lt;br /&gt;
| Status            = Active&lt;br /&gt;
| Type              = Paid&lt;br /&gt;
| Parent            = The Marketers&lt;br /&gt;
| DateFounded       = June 24th, 2013&lt;br /&gt;
| Owner             = Cryptic&lt;br /&gt;
| Leaders           = [[Roger Waters]] {{o}} xflat {{o}} [[Aura]]&lt;br /&gt;
| PastLeaders       = [[Connected]] {{o}} [[-Nas]] {{o}} [[&#039;Snorlax]]&lt;br /&gt;
| PreviousIteration = The Marketers&lt;br /&gt;
| NextIteration     = -&lt;br /&gt;
| Introduction      = The Brotherhood is currently a closed group that helps members and recruits members for sections like Gaming, White Hat Help, Computing, Pentesting, Graphics, Music and Server Administration. They also have the Brotherhood Spy Squad.&lt;br /&gt;
| History           = The group was initially invitation only, but opened recruitment due to such high interest from members in joining the group. The group was formerly known as the [[Marketers]], until it was closed due to members&#039; involvement in massive thread bumping. It was purchased by [[Cryptic™]] and remained a blank group for approximately a month, until June 2013. In November of 2013, the group had plans to sell to another member and become something else, but they ended when the member [[xflat]] purchased [[Connected]]&#039;s leadership in the group.&lt;br /&gt;
| CurrentStatus     = The group actively recruits in its range of areas, recruitment threads are area-specific and are most commonly listed by a sector leader.&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=-Nas&amp;diff=4342</id>
		<title>-Nas</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=-Nas&amp;diff=4342"/>
		<updated>2015-07-15T09:40:26Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Reverted edits by Nas (talk) to last revision by Roger Waters&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{MemberBox&lt;br /&gt;
| Username    = -Nas&lt;br /&gt;
| UserID      = 1452196&lt;br /&gt;
| JoinDate    = 07-07-2012&lt;br /&gt;
| Status      = Active&lt;br /&gt;
| Biography   = &amp;lt;!-- Leave blank if nothing has been written --&amp;gt;&lt;br /&gt;
| History     = &amp;lt;!-- Leave blank if nothing has been written --&amp;gt;&lt;br /&gt;
| NotabInvolv = &amp;lt;!-- Leave blank if nothing has been written --&amp;gt;&lt;br /&gt;
| PersonComm  = &amp;lt;!-- Leave blank if nothing has been written --&amp;gt;&lt;br /&gt;
| Alias1= -Nas&lt;br /&gt;
| Alias2= &lt;br /&gt;
| Alias3= &lt;br /&gt;
| Alias4= &lt;br /&gt;
| AwardName1= Sapphire of Ub3r&lt;br /&gt;
| AwardName2= &lt;br /&gt;
| AwardName3= &lt;br /&gt;
| GroupName1= Archive&lt;br /&gt;
| GroupName2= Writer&lt;br /&gt;
| GroupName3= Ub3r&lt;br /&gt;
| GroupName4= &lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Wiki_Team&amp;diff=4249</id>
		<title>Wiki Team</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Wiki_Team&amp;diff=4249"/>
		<updated>2015-07-14T23:01:39Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;__TOC__&lt;br /&gt;
This Wiki has been created and maintained by the HF Wiki Team, a sub-section of the [[Writ3rs]]. The team consists of a group of volunteers who perform tasks in several different roles. &lt;br /&gt;
&lt;br /&gt;
==The Roles==&lt;br /&gt;
*&#039;&#039;&#039;Leaders&#039;&#039;&#039;&lt;br /&gt;
** The leaders are in place to manage, organize and provide general support and advice to the team. They have absolute authority over all things related to the Wiki. Any issues within the team should be taken to the leaders to be addressed. Finally, they are directly in control of the the Wiki, its location and security.&lt;br /&gt;
&lt;br /&gt;
*&#039;&#039;&#039;Editors&#039;&#039;&#039;&lt;br /&gt;
** The editors are charged with the task of editing, re-writing, proofreading and amending articles created by the writers. They deal directly with the writers and can offer advice on grammar, structure and expansion of articles.&lt;br /&gt;
&lt;br /&gt;
*&#039;&#039;&#039;Publishers&#039;&#039;&#039;&lt;br /&gt;
** The publishers are assigned the task of structuring and maintaining the Wiki. They will upload and format all articles created by the team to the Wiki. They also manage the Wiki&#039;s structure and ensure all articles are neatly categorized and easily accessible to the forum members.&lt;br /&gt;
&lt;br /&gt;
*&#039;&#039;&#039;Writers&#039;&#039;&#039;&lt;br /&gt;
** The writers form the backbone of the team. They write the content and articles that forms the Wiki. They work with the editors in order to finalize an article and ensure it is of quality.&lt;br /&gt;
==Current Members==&lt;br /&gt;
With the publicization of the Wiki, the roles are no longer held in strict regard and everyone pitches in with publishing, editing, writing and updating. However, a general idea is provided below.&lt;br /&gt;
&lt;br /&gt;
*[[Ethereal]] | Leader; team and server&lt;br /&gt;
*[[iceybunneh]] | Previously RHW; editing&lt;br /&gt;
*[[Viral Dragon]] | Previous leader; server&lt;br /&gt;
*[[Roger Waters]] | Templates and accuracy&lt;br /&gt;
*[[D3xus]] | Templates and theme&lt;br /&gt;
*[[Premortal]] | General&lt;br /&gt;
*[[Happeh]] | General&lt;br /&gt;
*[[Tony Stark]] | General&lt;br /&gt;
&lt;br /&gt;
==Past Members==&lt;br /&gt;
In no particular order. To be considered for this list, you have to have contributed at least one article in &lt;br /&gt;
the Writ3rs wiki forum. &lt;br /&gt;
*[[D3xus]]&lt;br /&gt;
*[[Thornzzz]]&lt;br /&gt;
*[[Revenge]]&lt;br /&gt;
*[[SomeWhiteGuy]]&lt;br /&gt;
*[[RDCA]]&lt;br /&gt;
*[[Bandors]]&lt;br /&gt;
*[[Froggy]]&lt;br /&gt;
*[[Roger Waters]]&lt;br /&gt;
*[[Wonders]]&lt;br /&gt;
*[[Wallet]]&lt;br /&gt;
*[[Kōtei]]&lt;br /&gt;
*[[Coffee]]&lt;br /&gt;
*[[Empowerment]]&lt;br /&gt;
*[[SkyGuy]]&lt;br /&gt;
*[[Ariana]]&lt;br /&gt;
*[[Penar]]&lt;br /&gt;
*[[Harry Dresden]]&lt;br /&gt;
*[[Lemonade]]&lt;br /&gt;
*[[Peter L]]&lt;br /&gt;
*[[Analog]]&lt;br /&gt;
*[[ιnѕιdιoυѕ]]&lt;br /&gt;
*[[opiates]]&lt;br /&gt;
*[[Foe]]&lt;br /&gt;
*[[Tando]]&lt;br /&gt;
*[[CarrotMilk]]&lt;br /&gt;
*[[Milf]]&lt;br /&gt;
*[[ラジカル]]&lt;br /&gt;
*[[Hexicidal]]&lt;br /&gt;
*[[KoolDude87]]&lt;br /&gt;
*[[Paradoxum]]&lt;br /&gt;
*[[T3h Hack3r]]&lt;br /&gt;
*[[+Reckless]]&lt;br /&gt;
*[[xadamkx]]&lt;br /&gt;
*[[Ultimatum™]]&lt;br /&gt;
*[[Phytrix]]&lt;br /&gt;
*[[Glassy]]&lt;br /&gt;
*[[Lions]]&lt;br /&gt;
*[[DragScope]]&lt;br /&gt;
*[[Mr. Anderson]]&lt;br /&gt;
*[[Grin]]&lt;br /&gt;
*[[!!* Alone Vampire *!!]]&lt;br /&gt;
*[[Cyber-Security]]&lt;br /&gt;
*[[Venusaur]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Contact us==&lt;br /&gt;
Any and all queries can be directed towards one of the leaders. Our preferred method of contact is via PM on [http://www.hackforums.net/ Hack Forums].&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Wiki_Team&amp;diff=4244</id>
		<title>Wiki Team</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Wiki_Team&amp;diff=4244"/>
		<updated>2015-07-14T22:52:12Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;__TOC__&lt;br /&gt;
This Wiki has been created and maintained by the HF Wiki Team, a sub-section of the [[Writ3rs]]. The team consists of a group of volunteers who perform tasks in several different roles. &lt;br /&gt;
&lt;br /&gt;
==The Roles==&lt;br /&gt;
*&#039;&#039;&#039;Leaders&#039;&#039;&#039;&lt;br /&gt;
** The leaders are in place to manage, organize and provide general support and advice to the team. They have absolute authority over all things related to the Wiki. Any issues within the team should be taken to the leaders to be addressed. Finally, they are directly in control of the the Wiki, its location and security.&lt;br /&gt;
&lt;br /&gt;
*&#039;&#039;&#039;Editors&#039;&#039;&#039;&lt;br /&gt;
** The editors are charged with the task of editing, re-writing, proofreading and amending articles created by the writers. They deal directly with the writers and can offer advice on grammar, structure and expansion of articles.&lt;br /&gt;
&lt;br /&gt;
*&#039;&#039;&#039;Publishers&#039;&#039;&#039;&lt;br /&gt;
** The publishers are assigned the task of structuring and maintaining the Wiki. They will upload and format all articles created by the team to the Wiki. They also manage the Wiki&#039;s structure and ensure all articles are neatly categorized and easily accessible to the forum members.&lt;br /&gt;
&lt;br /&gt;
*&#039;&#039;&#039;Writers&#039;&#039;&#039;&lt;br /&gt;
** The writers form the backbone of the team. They write the content and articles that forms the Wiki. They work with the editors in order to finalize an article and ensure it is of quality.&lt;br /&gt;
==Current Members==&lt;br /&gt;
With the publicization of the Wiki, the roles are no longer held in strict regard and everyone pitches in with publishing, editing, writing and updating. However, a general idea is provided below.&lt;br /&gt;
&lt;br /&gt;
*[[Ethereal]] | Leader; team and server&lt;br /&gt;
*[[iceybunneh]] | Previously RHW; editing&lt;br /&gt;
*[[Viral Dragon]] | Previous leader; server&lt;br /&gt;
*[[Roger Waters]] | Templates and accuracy&lt;br /&gt;
*[[D3xus]] | Templates and theme&lt;br /&gt;
*[[Premortal]] | General&lt;br /&gt;
*[[Tony Stark]] | General&lt;br /&gt;
&lt;br /&gt;
==Past Members==&lt;br /&gt;
In no particular order. To be considered for this list, you have to have contributed at least one article in &lt;br /&gt;
the Writ3rs wiki forum. &lt;br /&gt;
*[[D3xus]]&lt;br /&gt;
*[[Thornzzz]]&lt;br /&gt;
*[[Revenge]]&lt;br /&gt;
*[[SomeWhiteGuy]]&lt;br /&gt;
*[[RDCA]]&lt;br /&gt;
*[[Bandors]]&lt;br /&gt;
*[[Froggy]]&lt;br /&gt;
*[[Roger Waters]]&lt;br /&gt;
*[[Wonders]]&lt;br /&gt;
*[[Wallet]]&lt;br /&gt;
*[[Kōtei]]&lt;br /&gt;
*[[Coffee]]&lt;br /&gt;
*[[Empowerment]]&lt;br /&gt;
*[[SkyGuy]]&lt;br /&gt;
*[[Ariana]]&lt;br /&gt;
*[[Penar]]&lt;br /&gt;
*[[Harry Dresden]]&lt;br /&gt;
*[[Lemonade]]&lt;br /&gt;
*[[Peter L]]&lt;br /&gt;
*[[Analog]]&lt;br /&gt;
*[[ιnѕιdιoυѕ]]&lt;br /&gt;
*[[opiates]]&lt;br /&gt;
*[[Foe]]&lt;br /&gt;
*[[Tando]]&lt;br /&gt;
*[[CarrotMilk]]&lt;br /&gt;
*[[Milf]]&lt;br /&gt;
*[[ラジカル]]&lt;br /&gt;
*[[Hexicidal]]&lt;br /&gt;
*[[KoolDude87]]&lt;br /&gt;
*[[Paradoxum]]&lt;br /&gt;
*[[T3h Hack3r]]&lt;br /&gt;
*[[+Reckless]]&lt;br /&gt;
*[[xadamkx]]&lt;br /&gt;
*[[Ultimatum™]]&lt;br /&gt;
*[[Phytrix]]&lt;br /&gt;
*[[Glassy]]&lt;br /&gt;
*[[Lions]]&lt;br /&gt;
*[[DragScope]]&lt;br /&gt;
*[[Mr. Anderson]]&lt;br /&gt;
*[[Grin]]&lt;br /&gt;
*[[!!* Alone Vampire *!!]]&lt;br /&gt;
*[[Cyber-Security]]&lt;br /&gt;
*[[Venusaur]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Contact us==&lt;br /&gt;
Any and all queries can be directed towards one of the leaders. Our preferred method of contact is via PM on [http://www.hackforums.net/ Hack Forums].&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Template:OMCTeamNavBox&amp;diff=3773</id>
		<title>Template:OMCTeamNavBox</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Template:OMCTeamNavBox&amp;diff=3773"/>
		<updated>2015-07-13T07:52:32Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Ethereal moved page Template:OMCTeamNavBox to Template:OMCTeamNavbox: Keep it in line with the other Navboxes.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Template:OMCTeamNavbox]]&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Template:OMCTeamNavbox&amp;diff=3772</id>
		<title>Template:OMCTeamNavbox</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Template:OMCTeamNavbox&amp;diff=3772"/>
		<updated>2015-07-13T07:52:32Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Ethereal moved page Template:OMCTeamNavBox to Template:OMCTeamNavbox: Keep it in line with the other Navboxes.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Navbox&lt;br /&gt;
| bodystyle = margin-top: 15px; width: 100%; border: 1px solid #072948;&lt;br /&gt;
| state  = uncollapsed&lt;br /&gt;
| title  = [[Omnicoin|&amp;lt;span style=&amp;quot;color: purple;&amp;quot;&amp;gt;Omnicoin Team&amp;lt;/span&amp;gt;]]&lt;br /&gt;
| titlestyle = background: #f2e500; vertical-align: middle; text-align: center; width: 100%;&lt;br /&gt;
| groupstyle = background: #072948; color: white; vertical-align: middle; border-top: 1px solid black; border-bottom: 1px solid black;&lt;br /&gt;
| abovestyle = background: #6B6A6A; color: blue; vertical-align: middle; width: 100%;&lt;br /&gt;
| liststyle  = border: 1px solid #072948;&lt;br /&gt;
| group1 = Members&lt;br /&gt;
| list1  = [[ӍeshCollider]] {{o}} [[Crypto™]] {{o}} [[Doctor Blue]] {{o}} [[Abraham Lincoln]] {{o}} [[Omniscient]]&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;noinclude&amp;gt;&lt;br /&gt;
[[Category:Templates]]&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Xbox_Live_Membership_Codes&amp;diff=3550</id>
		<title>Xbox Live Membership Codes</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Xbox_Live_Membership_Codes&amp;diff=3550"/>
		<updated>2015-07-12T17:07:54Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Forum Name==&lt;br /&gt;
&lt;br /&gt;
==Sub Forums==&lt;br /&gt;
None.&lt;br /&gt;
&lt;br /&gt;
==Description==&lt;br /&gt;
This section is now closed.&lt;br /&gt;
&lt;br /&gt;
==Forum Rules==&lt;br /&gt;
General sitewide rules.&lt;br /&gt;
&lt;br /&gt;
[[Category:Sections]]&lt;br /&gt;
{{ForumNavbox}}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Zero&amp;diff=3548</id>
		<title>Zero</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Zero&amp;diff=3548"/>
		<updated>2015-07-12T17:04:38Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&#039;&#039;&#039;Zero&#039;&#039;&#039; is a group based around marketing, business, monetization and other relatively topics. Members in the group specialize in some area of the topics they cover.&lt;br /&gt;
&lt;br /&gt;
==Leaders==&lt;br /&gt;
&lt;br /&gt;
===Current===&lt;br /&gt;
*[[Syrah]]&lt;br /&gt;
*[[Lani]]&lt;br /&gt;
*[[Maximum]]&lt;br /&gt;
&lt;br /&gt;
===Past===&lt;br /&gt;
*[[CarrotMilk]]&lt;br /&gt;
&lt;br /&gt;
==Group History==&lt;br /&gt;
The group was formed on September 2nd, 2014, having been purchased from [[iNviZ]] and [[Judge Dredd]] when it was known as [[Infamous]].&lt;br /&gt;
&lt;br /&gt;
==Goal or Manifesto==&lt;br /&gt;
Zero is a group of individuals who specialize in marketing.&lt;br /&gt;
&lt;br /&gt;
==Recruitment==&lt;br /&gt;
Recruitment is closed, as of March 15th, 2015.&lt;br /&gt;
&lt;br /&gt;
==Group Images==&lt;br /&gt;
TBD&lt;br /&gt;
&lt;br /&gt;
==External Links==&lt;br /&gt;
&lt;br /&gt;
==References==&lt;br /&gt;
&lt;br /&gt;
[[Category:Group]]&lt;br /&gt;
{{GroupNavbox}}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=File:HF_Avatar_2.png&amp;diff=3547</id>
		<title>File:HF Avatar 2.png</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=File:HF_Avatar_2.png&amp;diff=3547"/>
		<updated>2015-07-12T16:53:31Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=File:Standard_Avatar.png&amp;diff=3534</id>
		<title>File:Standard Avatar.png</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=File:Standard_Avatar.png&amp;diff=3534"/>
		<updated>2015-07-12T16:30:40Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=File:Test.png&amp;diff=3124</id>
		<title>File:Test.png</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=File:Test.png&amp;diff=3124"/>
		<updated>2015-07-11T07:38:58Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Test&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Test&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Main_Page&amp;diff=2907</id>
		<title>Main Page</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Main_Page&amp;diff=2907"/>
		<updated>2015-07-10T19:05:26Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Added twitter feed.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Welcome to the Hack Forums Official Wiki!&lt;br /&gt;
&lt;br /&gt;
The [[Hack Forums]] Wiki is a collaboration of useful and unique information about the website [http://hackforums.net HackForums.net]. It details user biographies, award information, the history of the website, and much more. The Wiki is a place where members new and old can find out more about a certain user, an in-depth analysis on one of the popular tools or people on the forum, or even just have some clarification of a specific hacking term that they may not have heard before. The Wiki is constantly being updated, checked, and scrutinized to make sure that members have the most accurate information on a particular topic.&lt;br /&gt;
&lt;br /&gt;
It is currently maintained by the [[Wiki Team]].&lt;br /&gt;
&lt;br /&gt;
==How to Contribute==&lt;br /&gt;
&lt;br /&gt;
Unlike other public wikis, the Hack Forums Wiki is carefully moderated. Because of this, the ability to freely edit articles is restricted, in order to preserve the integrity and accuracy of the site&#039;s articles. If you wish to make a suggestion or contribution, please contact [http://www.hackforums.net/private.php?action=send&amp;amp;uid=458069 Ethereal] via the Hack Forums Instant Message or Private Message systems.&lt;br /&gt;
&lt;br /&gt;
Alternatively, you can [http://wiki.hackforums.net/index.php?title=Special:UserLogin&amp;amp;returnto=Main+Page&amp;amp;type=signup register] for the Wiki, or contribute to the public [http://www.hackforums.net/forumdisplay.php?fid=336 Wiki forum].&lt;br /&gt;
&lt;br /&gt;
==Hack Forums Twitter==&lt;br /&gt;
&amp;lt;wikitwidget class=&amp;quot;twitter-timeline&amp;quot; href=&amp;quot;https://twitter.com/hackforumsnet&amp;quot; data-widget-id=&amp;quot;619582438273085440&amp;quot; /&amp;gt;&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Widget_Test&amp;diff=2904</id>
		<title>Widget Test</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Widget_Test&amp;diff=2904"/>
		<updated>2015-07-10T19:04:44Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Blanked the page&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Widget_Test&amp;diff=2903</id>
		<title>Widget Test</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Widget_Test&amp;diff=2903"/>
		<updated>2015-07-10T19:03:50Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: Created page with &amp;quot;&amp;lt;wikitwidget class=&amp;quot;twitter-timeline&amp;quot; href=&amp;quot;https://twitter.com/hackforumsnet&amp;quot; data-widget-id=&amp;quot;619582438273085440&amp;quot; /&amp;gt;&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;wikitwidget class=&amp;quot;twitter-timeline&amp;quot; href=&amp;quot;https://twitter.com/hackforumsnet&amp;quot; data-widget-id=&amp;quot;619582438273085440&amp;quot; /&amp;gt;&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Main_Page&amp;diff=2536</id>
		<title>Main Page</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Main_Page&amp;diff=2536"/>
		<updated>2015-07-10T17:03:31Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Welcome to the Hack Forums Official Wiki!&lt;br /&gt;
&lt;br /&gt;
The [[Hack Forums]] Wiki is a collaboration of useful and unique information about the website [http://hackforums.net HackForums.net]. It details user biographies, award information, the history of the website, and much more. The Wiki is a place where members new and old can find out more about a certain user, an in-depth analysis on one of the popular tools or people on the forum, or even just have some clarification of a specific hacking term that they may not have heard before. The Wiki is constantly being updated, checked, and scrutinized to make sure that members have the most accurate information on a particular topic.&lt;br /&gt;
&lt;br /&gt;
It is currently maintained by the [[Wiki Team]].&lt;br /&gt;
&lt;br /&gt;
==How to Contribute==&lt;br /&gt;
&lt;br /&gt;
Unlike other public wikis, the Hack Forums Wiki is carefully moderated. Because of this, the ability to freely edit articles is restricted, in order to preserve the integrity and accuracy of the site&#039;s articles. If you wish to make a suggestion or contribution, please contact [http://www.hackforums.net/private.php?action=send&amp;amp;uid=458069 Ethereal] via the Hack Forums Instant Message or Private Message systems.&lt;br /&gt;
&lt;br /&gt;
Alternatively, you can [http://wiki.hackforums.net/index.php?title=Special:UserLogin&amp;amp;returnto=Main+Page&amp;amp;type=signup register] for the Wiki, or contribute to the public [http://www.hackforums.net/forumdisplay.php?fid=336 Wiki forum].&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Main_Page&amp;diff=2535</id>
		<title>Main Page</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Main_Page&amp;diff=2535"/>
		<updated>2015-07-10T17:03:15Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Welcome to the Hack Forums Official Wiki!&lt;br /&gt;
&lt;br /&gt;
The [[Hack Forums]] Wiki is a collaboration of useful and unique information about the website [http://hackforums.net HackForums.net]. It details user biographies, award information, the history of the website, and much more. The Wiki is a place where members new and old can find out more about a certain user, an in-depth analysis on one of the popular tools or people on the forum, or even just have some clarification of a specific hacking term that they may not have heard before. The Wiki is constantly being updated, checked, and scrutinized to make sure that members have the most accurate information on a particular topic.&lt;br /&gt;
&lt;br /&gt;
It is currently maintained by [[Viral Dragon]] and [[Ethereal]] and has been a work in progress for several years now.&lt;br /&gt;
&lt;br /&gt;
==How to Contribute==&lt;br /&gt;
&lt;br /&gt;
Unlike other public wikis, the Hack Forums Wiki is carefully moderated. Because of this, the ability to freely edit articles is restricted, in order to preserve the integrity and accuracy of the site&#039;s articles. If you wish to make a suggestion or contribution, please contact [http://www.hackforums.net/private.php?action=send&amp;amp;uid=458069 Ethereal] via the Hack Forums Instant Message or Private Message systems.&lt;br /&gt;
&lt;br /&gt;
Alternatively, you can [http://wiki.hackforums.net/index.php?title=Special:UserLogin&amp;amp;returnto=Main+Page&amp;amp;type=signup register] for the Wiki, or contribute to the public [http://www.hackforums.net/forumdisplay.php?fid=336 Wiki forum].&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Yesno&amp;diff=2434</id>
		<title>Module:Yesno</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Yesno&amp;diff=2434"/>
		<updated>2015-07-09T17:07:26Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- Function allowing for consistent treatment of boolean-like wikitext input.&lt;br /&gt;
-- It works similarly to the template {{yesno}}.&lt;br /&gt;
&lt;br /&gt;
return function (val, default)&lt;br /&gt;
	-- If your wiki uses non-ascii characters for any of &amp;quot;yes&amp;quot;, &amp;quot;no&amp;quot;, etc., you&lt;br /&gt;
	-- should replace &amp;quot;val:lower()&amp;quot; with &amp;quot;mw.ustring.lower(val)&amp;quot; in the&lt;br /&gt;
	-- following line.&lt;br /&gt;
	val = type(val) == &#039;string&#039; and val:lower() or val&lt;br /&gt;
	if val == nil then&lt;br /&gt;
		return nil&lt;br /&gt;
	elseif val == true &lt;br /&gt;
		or val == &#039;yes&#039;&lt;br /&gt;
		or val == &#039;y&#039;&lt;br /&gt;
		or val == &#039;true&#039;&lt;br /&gt;
		or val == &#039;t&#039;&lt;br /&gt;
		or tonumber(val) == 1&lt;br /&gt;
	then&lt;br /&gt;
		return true&lt;br /&gt;
	elseif val == false&lt;br /&gt;
		or val == &#039;no&#039;&lt;br /&gt;
		or val == &#039;n&#039;&lt;br /&gt;
		or val == &#039;false&#039;&lt;br /&gt;
		or val == &#039;f&#039;&lt;br /&gt;
		or tonumber(val) == 0&lt;br /&gt;
	then&lt;br /&gt;
		return false&lt;br /&gt;
	else&lt;br /&gt;
		return default&lt;br /&gt;
	end&lt;br /&gt;
end&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:TableTools&amp;diff=2432</id>
		<title>Module:TableTools</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:TableTools&amp;diff=2432"/>
		<updated>2015-07-09T17:07:25Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--                               TableTools                                       --&lt;br /&gt;
--                                                                                --&lt;br /&gt;
-- This module includes a number of functions for dealing with Lua tables.        --&lt;br /&gt;
-- It is a meta-module, meant to be called from other Lua modules, and should     --&lt;br /&gt;
-- not be called directly from #invoke.                                           --&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
local libraryUtil = require(&#039;libraryUtil&#039;)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-- Define often-used variables and functions.&lt;br /&gt;
local floor = math.floor&lt;br /&gt;
local infinity = math.huge&lt;br /&gt;
local checkType = libraryUtil.checkType&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- isPositiveInteger&lt;br /&gt;
--&lt;br /&gt;
-- This function returns true if the given value is a positive integer, and false&lt;br /&gt;
-- if not. Although it doesn&#039;t operate on tables, it is included here as it is&lt;br /&gt;
-- useful for determining whether a given table key is in the array part or the&lt;br /&gt;
-- hash part of a table.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.isPositiveInteger(v)&lt;br /&gt;
	if type(v) == &#039;number&#039; and v &amp;gt;= 1 and floor(v) == v and v &amp;lt; infinity then&lt;br /&gt;
		return true&lt;br /&gt;
	else&lt;br /&gt;
		return false&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- isNan&lt;br /&gt;
--&lt;br /&gt;
-- This function returns true if the given number is a NaN value, and false&lt;br /&gt;
-- if not. Although it doesn&#039;t operate on tables, it is included here as it is&lt;br /&gt;
-- useful for determining whether a value can be a valid table key. Lua will&lt;br /&gt;
-- generate an error if a NaN is used as a table key.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.isNan(v)&lt;br /&gt;
	if type(v) == &#039;number&#039; and tostring(v) == &#039;-nan&#039; then&lt;br /&gt;
		return true&lt;br /&gt;
	else&lt;br /&gt;
		return false&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- shallowClone&lt;br /&gt;
--&lt;br /&gt;
-- This returns a clone of a table. The value returned is a new table, but all&lt;br /&gt;
-- subtables and functions are shared. Metamethods are respected, but the returned&lt;br /&gt;
-- table will have no metatable of its own.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.shallowClone(t)&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for k, v in pairs(t) do&lt;br /&gt;
		ret[k] = v&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- removeDuplicates&lt;br /&gt;
--&lt;br /&gt;
-- This removes duplicate values from an array. Non-positive-integer keys are&lt;br /&gt;
-- ignored. The earliest value is kept, and all subsequent duplicate values are&lt;br /&gt;
-- removed, but otherwise the array order is unchanged.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.removeDuplicates(t)&lt;br /&gt;
	checkType(&#039;removeDuplicates&#039;, 1, t, &#039;table&#039;)&lt;br /&gt;
	local isNan = p.isNan&lt;br /&gt;
	local ret, exists = {}, {}&lt;br /&gt;
	for i, v in ipairs(t) do&lt;br /&gt;
		if isNan(v) then&lt;br /&gt;
			-- NaNs can&#039;t be table keys, and they are also unique, so we don&#039;t need to check existence.&lt;br /&gt;
			ret[#ret + 1] = v&lt;br /&gt;
		else&lt;br /&gt;
			if not exists[v] then&lt;br /&gt;
				ret[#ret + 1] = v&lt;br /&gt;
				exists[v] = true&lt;br /&gt;
			end&lt;br /&gt;
		end	&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end			&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- numKeys&lt;br /&gt;
--&lt;br /&gt;
-- This takes a table and returns an array containing the numbers of any numerical&lt;br /&gt;
-- keys that have non-nil values, sorted in numerical order.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.numKeys(t)&lt;br /&gt;
	checkType(&#039;numKeys&#039;, 1, t, &#039;table&#039;)&lt;br /&gt;
	local isPositiveInteger = p.isPositiveInteger&lt;br /&gt;
	local nums = {}&lt;br /&gt;
	for k, v in pairs(t) do&lt;br /&gt;
		if isPositiveInteger(k) then&lt;br /&gt;
			nums[#nums + 1] = k&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	table.sort(nums)&lt;br /&gt;
	return nums&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- affixNums&lt;br /&gt;
--&lt;br /&gt;
-- This takes a table and returns an array containing the numbers of keys with the&lt;br /&gt;
-- specified prefix and suffix. For example, for the table&lt;br /&gt;
-- {a1 = &#039;foo&#039;, a3 = &#039;bar&#039;, a6 = &#039;baz&#039;} and the prefix &amp;quot;a&amp;quot;, affixNums will&lt;br /&gt;
-- return {1, 3, 6}.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.affixNums(t, prefix, suffix)&lt;br /&gt;
	checkType(&#039;affixNums&#039;, 1, t, &#039;table&#039;)&lt;br /&gt;
	checkType(&#039;affixNums&#039;, 2, prefix, &#039;string&#039;, true)&lt;br /&gt;
	checkType(&#039;affixNums&#039;, 3, suffix, &#039;string&#039;, true)&lt;br /&gt;
&lt;br /&gt;
	local function cleanPattern(s)&lt;br /&gt;
		-- Cleans a pattern so that the magic characters ()%.[]*+-?^$ are interpreted literally.&lt;br /&gt;
		s = s:gsub(&#039;([%(%)%%%.%[%]%*%+%-%?%^%$])&#039;, &#039;%%%1&#039;)&lt;br /&gt;
		return s&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	prefix = prefix or &#039;&#039;&lt;br /&gt;
	suffix = suffix or &#039;&#039;&lt;br /&gt;
	prefix = cleanPattern(prefix)&lt;br /&gt;
	suffix = cleanPattern(suffix)&lt;br /&gt;
	local pattern = &#039;^&#039; .. prefix .. &#039;([1-9]%d*)&#039; .. suffix .. &#039;$&#039;&lt;br /&gt;
&lt;br /&gt;
	local nums = {}&lt;br /&gt;
	for k, v in pairs(t) do&lt;br /&gt;
		if type(k) == &#039;string&#039; then			&lt;br /&gt;
			local num = mw.ustring.match(k, pattern)&lt;br /&gt;
			if num then&lt;br /&gt;
				nums[#nums + 1] = tonumber(num)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	table.sort(nums)&lt;br /&gt;
	return nums&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- numData&lt;br /&gt;
--&lt;br /&gt;
-- Given a table with keys like (&amp;quot;foo1&amp;quot;, &amp;quot;bar1&amp;quot;, &amp;quot;foo2&amp;quot;, &amp;quot;baz2&amp;quot;), returns a table&lt;br /&gt;
-- of subtables in the format &lt;br /&gt;
-- { [1] = {foo = &#039;text&#039;, bar = &#039;text&#039;}, [2] = {foo = &#039;text&#039;, baz = &#039;text&#039;} }&lt;br /&gt;
-- Keys that don&#039;t end with an integer are stored in a subtable named &amp;quot;other&amp;quot;.&lt;br /&gt;
-- The compress option compresses the table so that it can be iterated over with&lt;br /&gt;
-- ipairs.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.numData(t, compress)&lt;br /&gt;
	checkType(&#039;numData&#039;, 1, t, &#039;table&#039;)&lt;br /&gt;
	checkType(&#039;numData&#039;, 2, compress, &#039;boolean&#039;, true)&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for k, v in pairs(t) do&lt;br /&gt;
		local prefix, num = mw.ustring.match(tostring(k), &#039;^([^0-9]*)([1-9][0-9]*)$&#039;)&lt;br /&gt;
		if num then&lt;br /&gt;
			num = tonumber(num)&lt;br /&gt;
			local subtable = ret[num] or {}&lt;br /&gt;
			if prefix == &#039;&#039; then&lt;br /&gt;
				-- Positional parameters match the blank string; put them at the start of the subtable instead.&lt;br /&gt;
				prefix = 1&lt;br /&gt;
			end&lt;br /&gt;
			subtable[prefix] = v&lt;br /&gt;
			ret[num] = subtable&lt;br /&gt;
		else&lt;br /&gt;
			local subtable = ret.other or {}&lt;br /&gt;
			subtable[k] = v&lt;br /&gt;
			ret.other = subtable&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if compress then&lt;br /&gt;
		local other = ret.other&lt;br /&gt;
		ret = p.compressSparseArray(ret)&lt;br /&gt;
		ret.other = other&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- compressSparseArray&lt;br /&gt;
--&lt;br /&gt;
-- This takes an array with one or more nil values, and removes the nil values&lt;br /&gt;
-- while preserving the order, so that the array can be safely traversed with&lt;br /&gt;
-- ipairs.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.compressSparseArray(t)&lt;br /&gt;
	checkType(&#039;compressSparseArray&#039;, 1, t, &#039;table&#039;)&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	local nums = p.numKeys(t)&lt;br /&gt;
	for _, num in ipairs(nums) do&lt;br /&gt;
		ret[#ret + 1] = t[num]&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- sparseIpairs&lt;br /&gt;
--&lt;br /&gt;
-- This is an iterator for sparse arrays. It can be used like ipairs, but can&lt;br /&gt;
-- handle nil values.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.sparseIpairs(t)&lt;br /&gt;
	checkType(&#039;sparseIpairs&#039;, 1, t, &#039;table&#039;)&lt;br /&gt;
	local nums = p.numKeys(t)&lt;br /&gt;
	local i = 0&lt;br /&gt;
	local lim = #nums&lt;br /&gt;
	return function ()&lt;br /&gt;
		i = i + 1&lt;br /&gt;
		if i &amp;lt;= lim then&lt;br /&gt;
			local key = nums[i]&lt;br /&gt;
			return key, t[key]&lt;br /&gt;
		else&lt;br /&gt;
			return nil, nil&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
-- size&lt;br /&gt;
--&lt;br /&gt;
-- This returns the size of a key/value pair table. It will also work on arrays,&lt;br /&gt;
-- but for arrays it is more efficient to use the # operator.&lt;br /&gt;
------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
function p.size(t)&lt;br /&gt;
	checkType(&#039;size&#039;, 1, t, &#039;table&#039;)&lt;br /&gt;
	local i = 0&lt;br /&gt;
	for k in pairs(t) do&lt;br /&gt;
		i = i + 1&lt;br /&gt;
	end&lt;br /&gt;
	return i&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:String&amp;diff=2430</id>
		<title>Module:String</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:String&amp;diff=2430"/>
		<updated>2015-07-09T17:07:25Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[  &lt;br /&gt;
&lt;br /&gt;
This module is intended to provide access to basic string functions.&lt;br /&gt;
&lt;br /&gt;
Most of the functions provided here can be invoked with named parameters, &lt;br /&gt;
unnamed parameters, or a mixture.  If named parameters are used, Mediawiki will &lt;br /&gt;
automatically remove any leading or trailing whitespace from the parameter.  &lt;br /&gt;
Depending on the intended use, it may be advantageous to either preserve or&lt;br /&gt;
remove such whitespace.&lt;br /&gt;
&lt;br /&gt;
Global options&lt;br /&gt;
    ignore_errors: If set to &#039;true&#039; or 1, any error condition will result in &lt;br /&gt;
        an empty string being returned rather than an error message.  &lt;br /&gt;
        &lt;br /&gt;
    error_category: If an error occurs, specifies the name of a category to &lt;br /&gt;
        include with the error message.  The default category is  &lt;br /&gt;
        [Category:Errors reported by Module String].&lt;br /&gt;
        &lt;br /&gt;
    no_category: If set to &#039;true&#039; or 1, no category will be added if an error&lt;br /&gt;
        is generated.&lt;br /&gt;
        &lt;br /&gt;
Unit tests for this module are available at Module:String/tests.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local str = {}&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
len&lt;br /&gt;
&lt;br /&gt;
This function returns the length of the target string.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:String|len|target_string|}}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:String|len|s=target_string}}&lt;br /&gt;
&lt;br /&gt;
Parameters&lt;br /&gt;
    s: The string whose length to report&lt;br /&gt;
&lt;br /&gt;
If invoked using named parameters, Mediawiki will automatically remove any leading or&lt;br /&gt;
trailing whitespace from the target string.  &lt;br /&gt;
]]&lt;br /&gt;
function str.len( frame )&lt;br /&gt;
    local new_args = str._getParameters( frame.args, {&#039;s&#039;} );&lt;br /&gt;
    local s = new_args[&#039;s&#039;] or &#039;&#039;;&lt;br /&gt;
    return mw.ustring.len( s )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
sub&lt;br /&gt;
&lt;br /&gt;
This function returns a substring of the target string at specified indices.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:String|sub|target_string|start_index|end_index}}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:String|sub|s=target_string|i=start_index|j=end_index}}&lt;br /&gt;
&lt;br /&gt;
Parameters&lt;br /&gt;
    s: The string to return a subset of&lt;br /&gt;
    i: The fist index of the substring to return, defaults to 1.&lt;br /&gt;
    j: The last index of the string to return, defaults to the last character.&lt;br /&gt;
    &lt;br /&gt;
The first character of the string is assigned an index of 1.  If either i or j&lt;br /&gt;
is a negative value, it is interpreted the same as selecting a character by &lt;br /&gt;
counting from the end of the string.  Hence, a value of -1 is the same as &lt;br /&gt;
selecting the last character of the string.&lt;br /&gt;
&lt;br /&gt;
If the requested indices are out of range for the given string, an error is &lt;br /&gt;
reported.&lt;br /&gt;
]]&lt;br /&gt;
function str.sub( frame )&lt;br /&gt;
    local new_args = str._getParameters( frame.args, { &#039;s&#039;, &#039;i&#039;, &#039;j&#039; } );&lt;br /&gt;
    local s = new_args[&#039;s&#039;] or &#039;&#039;;&lt;br /&gt;
    local i = tonumber( new_args[&#039;i&#039;] ) or 1;&lt;br /&gt;
    local j = tonumber( new_args[&#039;j&#039;] ) or -1;&lt;br /&gt;
    &lt;br /&gt;
    local len = mw.ustring.len( s );&lt;br /&gt;
&lt;br /&gt;
    -- Convert negatives for range checking&lt;br /&gt;
    if i &amp;lt; 0 then&lt;br /&gt;
        i = len + i + 1;&lt;br /&gt;
    end&lt;br /&gt;
    if j &amp;lt; 0 then&lt;br /&gt;
        j = len + j + 1;&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    if i &amp;gt; len or j &amp;gt; len or i &amp;lt; 1 or j &amp;lt; 1 then&lt;br /&gt;
        return str._error( &#039;String subset index out of range&#039; );&lt;br /&gt;
    end&lt;br /&gt;
    if j &amp;lt; i then&lt;br /&gt;
        return str._error( &#039;String subset indices out of order&#039; );&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return mw.ustring.sub( s, i, j )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
This function implements that features of {{str sub old}} and is kept in order&lt;br /&gt;
to maintain these older templates.&lt;br /&gt;
]]&lt;br /&gt;
function str.sublength( frame )&lt;br /&gt;
    local i = tonumber( frame.args.i ) or 0&lt;br /&gt;
    local len = tonumber( frame.args.len )&lt;br /&gt;
    return mw.ustring.sub( frame.args.s, i + 1, len and ( i + len ) )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
match&lt;br /&gt;
&lt;br /&gt;
This function returns a substring from the source string that matches a &lt;br /&gt;
specified pattern.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:String|match|source_string|pattern_string|start_index|match_number|plain_flag|nomatch_output}}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:String|pos|s=source_string|pattern=pattern_string|start=start_index&lt;br /&gt;
    |match=match_number|plain=plain_flag|nomatch=nomatch_output}}&lt;br /&gt;
&lt;br /&gt;
Parameters&lt;br /&gt;
    s: The string to search&lt;br /&gt;
    pattern: The pattern or string to find within the string&lt;br /&gt;
    start: The index within the source string to start the search.  The first&lt;br /&gt;
        character of the string has index 1.  Defaults to 1.&lt;br /&gt;
    match: In some cases it may be possible to make multiple matches on a single &lt;br /&gt;
        string.  This specifies which match to return, where the first match is &lt;br /&gt;
        match= 1.  If a negative number is specified then a match is returned &lt;br /&gt;
        counting from the last match.  Hence match = -1 is the same as requesting&lt;br /&gt;
        the last match.  Defaults to 1.&lt;br /&gt;
    plain: A flag indicating that the pattern should be understood as plain&lt;br /&gt;
        text.  Defaults to false.&lt;br /&gt;
    nomatch: If no match is found, output the &amp;quot;nomatch&amp;quot; value rather than an error.&lt;br /&gt;
&lt;br /&gt;
If invoked using named parameters, Mediawiki will automatically remove any leading or&lt;br /&gt;
trailing whitespace from each string.  In some circumstances this is desirable, in &lt;br /&gt;
other cases one may want to preserve the whitespace.&lt;br /&gt;
&lt;br /&gt;
If the match_number or start_index are out of range for the string being queried, then&lt;br /&gt;
this function generates an error.  An error is also generated if no match is found.&lt;br /&gt;
If one adds the parameter ignore_errors=true, then the error will be suppressed and &lt;br /&gt;
an empty string will be returned on any failure.&lt;br /&gt;
&lt;br /&gt;
For information on constructing Lua patterns, a form of [regular expression], see:&lt;br /&gt;
&lt;br /&gt;
* http://www.lua.org/manual/5.1/manual.html#5.4.1&lt;br /&gt;
* http://www.mediawiki.org/wiki/Extension:Scribunto/Lua_reference_manual#Patterns&lt;br /&gt;
* http://www.mediawiki.org/wiki/Extension:Scribunto/Lua_reference_manual#Ustring_patterns&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
function str.match( frame )&lt;br /&gt;
    local new_args = str._getParameters( frame.args, {&#039;s&#039;, &#039;pattern&#039;, &#039;start&#039;, &#039;match&#039;, &#039;plain&#039;, &#039;nomatch&#039;} );&lt;br /&gt;
    local s = new_args[&#039;s&#039;] or &#039;&#039;;&lt;br /&gt;
    local start = tonumber( new_args[&#039;start&#039;] ) or 1;&lt;br /&gt;
    local plain_flag = str._getBoolean( new_args[&#039;plain&#039;] or false );&lt;br /&gt;
    local pattern = new_args[&#039;pattern&#039;] or &#039;&#039;;&lt;br /&gt;
    local match_index = math.floor( tonumber(new_args[&#039;match&#039;]) or 1 );&lt;br /&gt;
    local nomatch = new_args[&#039;nomatch&#039;];&lt;br /&gt;
    &lt;br /&gt;
    if s == &#039;&#039; then&lt;br /&gt;
        return str._error( &#039;Target string is empty&#039; );&lt;br /&gt;
    end&lt;br /&gt;
    if pattern == &#039;&#039; then&lt;br /&gt;
        return str._error( &#039;Pattern string is empty&#039; );&lt;br /&gt;
    end&lt;br /&gt;
    if math.abs(start) &amp;lt; 1 or math.abs(start) &amp;gt; mw.ustring.len( s ) then&lt;br /&gt;
        return str._error( &#039;Requested start is out of range&#039; );&lt;br /&gt;
    end&lt;br /&gt;
    if match_index == 0 then&lt;br /&gt;
        return str._error( &#039;Match index is out of range&#039; );&lt;br /&gt;
    end&lt;br /&gt;
    if plain_flag then&lt;br /&gt;
        pattern = str._escapePattern( pattern );&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    local result&lt;br /&gt;
    if match_index == 1 then&lt;br /&gt;
        -- Find first match is simple case&lt;br /&gt;
        result = mw.ustring.match( s, pattern, start )&lt;br /&gt;
    else&lt;br /&gt;
        if start &amp;gt; 1 then&lt;br /&gt;
            s = mw.ustring.sub( s, start );&lt;br /&gt;
        end&lt;br /&gt;
        &lt;br /&gt;
        local iterator = mw.ustring.gmatch(s, pattern);&lt;br /&gt;
        if match_index &amp;gt; 0 then&lt;br /&gt;
            -- Forward search&lt;br /&gt;
            for w in iterator do&lt;br /&gt;
                match_index = match_index - 1;&lt;br /&gt;
                if match_index == 0 then&lt;br /&gt;
                    result = w;&lt;br /&gt;
                    break;&lt;br /&gt;
                end&lt;br /&gt;
            end    &lt;br /&gt;
        else&lt;br /&gt;
            -- Reverse search&lt;br /&gt;
            local result_table = {};&lt;br /&gt;
            local count = 1;&lt;br /&gt;
            for w in iterator do&lt;br /&gt;
                result_table[count] = w;&lt;br /&gt;
                count = count + 1;&lt;br /&gt;
            end&lt;br /&gt;
            &lt;br /&gt;
            result = result_table[ count + match_index ];            &lt;br /&gt;
        end&lt;br /&gt;
    end        &lt;br /&gt;
    &lt;br /&gt;
    if result == nil then&lt;br /&gt;
        if nomatch == nil then&lt;br /&gt;
            return str._error( &#039;Match not found&#039; );&lt;br /&gt;
        else&lt;br /&gt;
            return nomatch;&lt;br /&gt;
        end&lt;br /&gt;
    else&lt;br /&gt;
        return result;&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
pos&lt;br /&gt;
&lt;br /&gt;
This function returns a single character from the target string at position pos.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:String|pos|target_string|index_value}}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:String|pos|target=target_string|pos=index_value}}&lt;br /&gt;
&lt;br /&gt;
Parameters&lt;br /&gt;
    target: The string to search&lt;br /&gt;
    pos: The index for the character to return&lt;br /&gt;
&lt;br /&gt;
If invoked using named parameters, Mediawiki will automatically remove any leading or&lt;br /&gt;
trailing whitespace from the target string.  In some circumstances this is desirable, in &lt;br /&gt;
other cases one may want to preserve the whitespace.&lt;br /&gt;
&lt;br /&gt;
The first character has an index value of 1.&lt;br /&gt;
&lt;br /&gt;
If one requests a negative value, this function will select a character by counting backwards &lt;br /&gt;
from the end of the string.  In other words pos = -1 is the same as asking for the last character.&lt;br /&gt;
&lt;br /&gt;
A requested value of zero, or a value greater than the length of the string returns an error.&lt;br /&gt;
]]&lt;br /&gt;
function str.pos( frame )&lt;br /&gt;
    local new_args = str._getParameters( frame.args, {&#039;target&#039;, &#039;pos&#039;} );&lt;br /&gt;
    local target_str = new_args[&#039;target&#039;] or &#039;&#039;;&lt;br /&gt;
    local pos = tonumber( new_args[&#039;pos&#039;] ) or 0;&lt;br /&gt;
&lt;br /&gt;
    if pos == 0 or math.abs(pos) &amp;gt; mw.ustring.len( target_str ) then&lt;br /&gt;
        return str._error( &#039;String index out of range&#039; );&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    return mw.ustring.sub( target_str, pos, pos );&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
str_find&lt;br /&gt;
&lt;br /&gt;
This function duplicates the behavior of {{str_find}}, including all of its quirks.&lt;br /&gt;
This is provided in order to support existing templates, but is NOT RECOMMENDED for &lt;br /&gt;
new code and templates.  New code is recommended to use the &amp;quot;find&amp;quot; function instead.&lt;br /&gt;
&lt;br /&gt;
Returns the first index in &amp;quot;source&amp;quot; that is a match to &amp;quot;target&amp;quot;.  Indexing is 1-based,&lt;br /&gt;
and the function returns -1 if the &amp;quot;target&amp;quot; string is not present in &amp;quot;source&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
Important Note: If the &amp;quot;target&amp;quot; string is empty / missing, this function returns a&lt;br /&gt;
value of &amp;quot;1&amp;quot;, which is generally unexpected behavior, and must be accounted for&lt;br /&gt;
separatetly.&lt;br /&gt;
]]&lt;br /&gt;
function str.str_find( frame )&lt;br /&gt;
    local new_args = str._getParameters( frame.args, {&#039;source&#039;, &#039;target&#039;} );&lt;br /&gt;
    local source_str = new_args[&#039;source&#039;] or &#039;&#039;;&lt;br /&gt;
    local target_str = new_args[&#039;target&#039;] or &#039;&#039;;&lt;br /&gt;
&lt;br /&gt;
    if target_str == &#039;&#039; then&lt;br /&gt;
        return 1;&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    local start = mw.ustring.find( source_str, target_str, 1, true )&lt;br /&gt;
    if start == nil then&lt;br /&gt;
        start = -1&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return start&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
find&lt;br /&gt;
&lt;br /&gt;
This function allows one to search for a target string or pattern within another&lt;br /&gt;
string.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:String|find|source_str|target_string|start_index|plain_flag}}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:String|find|source=source_str|target=target_str|start=start_index|plain=plain_flag}}&lt;br /&gt;
&lt;br /&gt;
Parameters&lt;br /&gt;
    source: The string to search&lt;br /&gt;
    target: The string or pattern to find within source&lt;br /&gt;
    start: The index within the source string to start the search, defaults to 1&lt;br /&gt;
    plain: Boolean flag indicating that target should be understood as plain&lt;br /&gt;
        text and not as a Lua style regular expression, defaults to true&lt;br /&gt;
&lt;br /&gt;
If invoked using named parameters, Mediawiki will automatically remove any leading or&lt;br /&gt;
trailing whitespace from the parameter.  In some circumstances this is desirable, in &lt;br /&gt;
other cases one may want to preserve the whitespace.&lt;br /&gt;
&lt;br /&gt;
This function returns the first index &amp;gt;= &amp;quot;start&amp;quot; where &amp;quot;target&amp;quot; can be found &lt;br /&gt;
within &amp;quot;source&amp;quot;.  Indices are 1-based.  If &amp;quot;target&amp;quot; is not found, then this &lt;br /&gt;
function returns 0.  If either &amp;quot;source&amp;quot; or &amp;quot;target&amp;quot; are missing / empty, this&lt;br /&gt;
function also returns 0.&lt;br /&gt;
&lt;br /&gt;
This function should be safe for UTF-8 strings.&lt;br /&gt;
]]&lt;br /&gt;
function str.find( frame )&lt;br /&gt;
    local new_args = str._getParameters( frame.args, {&#039;source&#039;, &#039;target&#039;, &#039;start&#039;, &#039;plain&#039; } ); &lt;br /&gt;
    local source_str = new_args[&#039;source&#039;] or &#039;&#039;;&lt;br /&gt;
    local pattern = new_args[&#039;target&#039;] or &#039;&#039;;&lt;br /&gt;
    local start_pos = tonumber(new_args[&#039;start&#039;]) or 1;&lt;br /&gt;
    local plain = new_args[&#039;plain&#039;] or true;&lt;br /&gt;
        &lt;br /&gt;
    if source_str == &#039;&#039; or pattern == &#039;&#039; then&lt;br /&gt;
        return 0;&lt;br /&gt;
    end    &lt;br /&gt;
    &lt;br /&gt;
    plain = str._getBoolean( plain );&lt;br /&gt;
&lt;br /&gt;
    local start = mw.ustring.find( source_str, pattern, start_pos, plain )&lt;br /&gt;
    if start == nil then&lt;br /&gt;
        start = 0&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return start&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
replace&lt;br /&gt;
&lt;br /&gt;
This function allows one to replace a target string or pattern within another&lt;br /&gt;
string.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:String|replace|source_str|pattern_string|replace_string|replacement_count|plain_flag}}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:String|replace|source=source_string|pattern=pattern_string|replace=replace_string|&lt;br /&gt;
   count=replacement_count|plain=plain_flag}}&lt;br /&gt;
&lt;br /&gt;
Parameters&lt;br /&gt;
    source: The string to search&lt;br /&gt;
    pattern: The string or pattern to find within source&lt;br /&gt;
    replace: The replacement text&lt;br /&gt;
    count: The number of occurences to replace, defaults to all.&lt;br /&gt;
    plain: Boolean flag indicating that pattern should be understood as plain&lt;br /&gt;
        text and not as a Lua style regular expression, defaults to true &lt;br /&gt;
]]&lt;br /&gt;
function str.replace( frame )&lt;br /&gt;
    local new_args = str._getParameters( frame.args, {&#039;source&#039;, &#039;pattern&#039;, &#039;replace&#039;, &#039;count&#039;, &#039;plain&#039; } ); &lt;br /&gt;
    local source_str = new_args[&#039;source&#039;] or &#039;&#039;;&lt;br /&gt;
    local pattern = new_args[&#039;pattern&#039;] or &#039;&#039;;&lt;br /&gt;
    local replace = new_args[&#039;replace&#039;] or &#039;&#039;;&lt;br /&gt;
    local count = tonumber( new_args[&#039;count&#039;] );&lt;br /&gt;
    local plain = new_args[&#039;plain&#039;] or true;&lt;br /&gt;
        &lt;br /&gt;
    if source_str == &#039;&#039; or pattern == &#039;&#039; then&lt;br /&gt;
        return source_str;&lt;br /&gt;
    end    &lt;br /&gt;
    plain = str._getBoolean( plain );&lt;br /&gt;
&lt;br /&gt;
    if plain then&lt;br /&gt;
        pattern = str._escapePattern( pattern );&lt;br /&gt;
        replace = mw.ustring.gsub( replace, &amp;quot;%%&amp;quot;, &amp;quot;%%%%&amp;quot; ); --Only need to escape replacement sequences.&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    local result;&lt;br /&gt;
&lt;br /&gt;
    if count ~= nil then&lt;br /&gt;
        result = mw.ustring.gsub( source_str, pattern, replace, count );&lt;br /&gt;
    else&lt;br /&gt;
        result = mw.ustring.gsub( source_str, pattern, replace );&lt;br /&gt;
    end        &lt;br /&gt;
&lt;br /&gt;
    return result;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[ &lt;br /&gt;
    simple function to pipe string.rep to templates.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function str.rep( frame )&lt;br /&gt;
    local repetitions = tonumber( frame.args[2] )&lt;br /&gt;
    if not repetitions then &lt;br /&gt;
        return str._error( &#039;function rep expects a number as second parameter, received &amp;quot;&#039; .. ( frame.args[2] or &#039;&#039; ) .. &#039;&amp;quot;&#039; )&lt;br /&gt;
    end&lt;br /&gt;
    return string.rep( frame.args[1] or &#039;&#039;, repetitions )&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper function that populates the argument list given that user may need to use a mix of&lt;br /&gt;
named and unnamed parameters.  This is relevant because named parameters are not&lt;br /&gt;
identical to unnamed parameters due to string trimming, and when dealing with strings&lt;br /&gt;
we sometimes want to either preserve or remove that whitespace depending on the application.&lt;br /&gt;
]]&lt;br /&gt;
function str._getParameters( frame_args, arg_list )&lt;br /&gt;
    local new_args = {};&lt;br /&gt;
    local index = 1;&lt;br /&gt;
    local value;&lt;br /&gt;
    &lt;br /&gt;
    for i,arg in ipairs( arg_list ) do&lt;br /&gt;
        value = frame_args[arg]&lt;br /&gt;
        if value == nil then&lt;br /&gt;
            value = frame_args[index];&lt;br /&gt;
            index = index + 1;&lt;br /&gt;
        end&lt;br /&gt;
        new_args[arg] = value;&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    return new_args;&lt;br /&gt;
end        &lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper function to handle error messages.&lt;br /&gt;
]]&lt;br /&gt;
function str._error( error_str )&lt;br /&gt;
    local frame = mw.getCurrentFrame();&lt;br /&gt;
    local error_category = frame.args.error_category or &#039;Errors reported by Module String&#039;;&lt;br /&gt;
    local ignore_errors = frame.args.ignore_errors or false;&lt;br /&gt;
    local no_category = frame.args.no_category or false;&lt;br /&gt;
    &lt;br /&gt;
    if str._getBoolean(ignore_errors) then&lt;br /&gt;
        return &#039;&#039;;&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    local error_str = &#039;&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;String Module Error: &#039; .. error_str .. &#039;&amp;lt;/strong&amp;gt;&#039;;&lt;br /&gt;
    if error_category ~= &#039;&#039; and not str._getBoolean( no_category ) then&lt;br /&gt;
        error_str = &#039;[[Category:&#039; .. error_category .. &#039;]]&#039; .. error_str;&lt;br /&gt;
    end        &lt;br /&gt;
    &lt;br /&gt;
    return error_str;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper Function to interpret boolean strings&lt;br /&gt;
]]&lt;br /&gt;
function str._getBoolean( boolean_str )&lt;br /&gt;
    local boolean_value;&lt;br /&gt;
    &lt;br /&gt;
    if type( boolean_str ) == &#039;string&#039; then&lt;br /&gt;
        boolean_str = boolean_str:lower();&lt;br /&gt;
        if boolean_str == &#039;false&#039; or boolean_str == &#039;no&#039; or boolean_str == &#039;0&#039; &lt;br /&gt;
                or boolean_str == &#039;&#039; then&lt;br /&gt;
            boolean_value = false;&lt;br /&gt;
        else&lt;br /&gt;
            boolean_value = true;&lt;br /&gt;
        end    &lt;br /&gt;
    elseif type( boolean_str ) == &#039;boolean&#039; then&lt;br /&gt;
        boolean_value = boolean_str;&lt;br /&gt;
    else&lt;br /&gt;
        error( &#039;No boolean value found&#039; );&lt;br /&gt;
    end    &lt;br /&gt;
    return boolean_value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper function that escapes all pattern characters so that they will be treated &lt;br /&gt;
as plain text.&lt;br /&gt;
]]&lt;br /&gt;
function str._escapePattern( pattern_str )&lt;br /&gt;
    return mw.ustring.gsub( pattern_str, &amp;quot;([%(%)%.%%%+%-%*%?%[%^%$%]])&amp;quot;, &amp;quot;%%%1&amp;quot; );&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return str&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Sidebar&amp;diff=2428</id>
		<title>Module:Sidebar</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Sidebar&amp;diff=2428"/>
		<updated>2015-07-09T17:07:25Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--&lt;br /&gt;
-- This module implements {{Sidebar}}&lt;br /&gt;
--&lt;br /&gt;
require(&#039;Module:No globals&#039;)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
local navbar = require(&#039;Module:Navbar&#039;)._navbar&lt;br /&gt;
&lt;br /&gt;
local function trimAndAddAutomaticNewline(s)&lt;br /&gt;
	-- For compatibility with the original {{sidebar with collapsible lists}}&lt;br /&gt;
	-- implementation, which passed some parameters through {{#if}} to trim&lt;br /&gt;
	-- their whitespace. This also triggered the automatic newline behavior.&lt;br /&gt;
	-- ([[meta:Help:Newlines and spaces#Automatic newline]])&lt;br /&gt;
	s = mw.ustring.gsub(s, &amp;quot;^%s*(.-)%s*$&amp;quot;, &amp;quot;%1&amp;quot;)&lt;br /&gt;
	if mw.ustring.find(s, &#039;^[#*:;]&#039;) or mw.ustring.find(s, &#039;^{|&#039;) then&lt;br /&gt;
		return &#039;\n&#039; .. s&lt;br /&gt;
	else&lt;br /&gt;
		return s&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.sidebar(frame, args)&lt;br /&gt;
	if not args then&lt;br /&gt;
		args = getArgs(frame)&lt;br /&gt;
	end&lt;br /&gt;
	local root = mw.html.create()&lt;br /&gt;
	local child = args.child and mw.text.trim(args.child) == &#039;yes&#039;&lt;br /&gt;
&lt;br /&gt;
	if not child then&lt;br /&gt;
		root = root&lt;br /&gt;
			:tag(&#039;table&#039;)&lt;br /&gt;
			:addClass(&#039;vertical-navbox&#039;)&lt;br /&gt;
			:addClass(args.wraplinks ~= &#039;true&#039; and &#039;nowraplinks&#039; or nil)&lt;br /&gt;
			:addClass(args.bodyclass or args.class)&lt;br /&gt;
			:css(&#039;float&#039;, args.float or &#039;right&#039;)&lt;br /&gt;
			:css(&#039;clear&#039;, (args.float == &#039;none&#039; and &#039;both&#039;) or args.float or &#039;right&#039;)&lt;br /&gt;
			:css(&#039;width&#039;, args.width or &#039;22.0em&#039;)&lt;br /&gt;
			:css(&#039;margin&#039;, args.float == &#039;left&#039; and &#039;0 1.0em 1.0em 0&#039; or &#039;0 0 1.0em 1.0em&#039;)&lt;br /&gt;
			:css(&#039;background&#039;, &#039;#f9f9f9&#039;)&lt;br /&gt;
			:css(&#039;border&#039;, &#039;1px solid #aaa&#039;)&lt;br /&gt;
			:css(&#039;padding&#039;, &#039;0.2em&#039;)&lt;br /&gt;
			:css(&#039;border-spacing&#039;, &#039;0.4em 0&#039;)&lt;br /&gt;
			:css(&#039;text-align&#039;, &#039;center&#039;)&lt;br /&gt;
			:css(&#039;line-height&#039;, &#039;1.4em&#039;)&lt;br /&gt;
			:css(&#039;font-size&#039;, &#039;88%&#039;)&lt;br /&gt;
			:cssText(args.bodystyle or args.style)&lt;br /&gt;
&lt;br /&gt;
		if args.outertitle then&lt;br /&gt;
			root&lt;br /&gt;
				:tag(&#039;caption&#039;)&lt;br /&gt;
					:addClass(args.outertitleclass)&lt;br /&gt;
					:css(&#039;padding-bottom&#039;, &#039;0.2em&#039;)&lt;br /&gt;
					:css(&#039;font-size&#039;, &#039;125%&#039;)&lt;br /&gt;
					:css(&#039;line-height&#039;, &#039;1.2em&#039;)&lt;br /&gt;
					:css(&#039;font-weight&#039;, &#039;bold&#039;)&lt;br /&gt;
					:cssText(args.outertitlestyle)&lt;br /&gt;
					:wikitext(args.outertitle)&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		if args.topimage then&lt;br /&gt;
			local imageCell = root:tag(&#039;tr&#039;):tag(&#039;td&#039;)&lt;br /&gt;
&lt;br /&gt;
			imageCell&lt;br /&gt;
				:addClass(args.topimageclass)&lt;br /&gt;
				:css(&#039;padding&#039;, &#039;0.4em 0&#039;)&lt;br /&gt;
				:cssText(args.topimagestyle)&lt;br /&gt;
				:wikitext(args.topimage)&lt;br /&gt;
&lt;br /&gt;
			if args.topcaption then&lt;br /&gt;
				imageCell&lt;br /&gt;
					:tag(&#039;div&#039;)&lt;br /&gt;
						:css(&#039;padding-top&#039;, &#039;0.2em&#039;)&lt;br /&gt;
						:css(&#039;line-height&#039;, &#039;1.2em&#039;)&lt;br /&gt;
						:cssText(args.topcaptionstyle)&lt;br /&gt;
						:wikitext(args.topcaption)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		if args.pretitle then&lt;br /&gt;
			root&lt;br /&gt;
				:tag(&#039;tr&#039;)&lt;br /&gt;
					:tag(&#039;td&#039;)&lt;br /&gt;
						:addClass(args.pretitleclass)&lt;br /&gt;
						:cssText(args.basestyle)&lt;br /&gt;
						:css(&#039;padding-top&#039;, args.topimage and &#039;0.2em&#039; or &#039;0.4em&#039;)&lt;br /&gt;
						:css(&#039;line-height&#039;, &#039;1.2em&#039;)&lt;br /&gt;
						:cssText(args.pretitlestyle)&lt;br /&gt;
						:wikitext(args.pretitle)&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if args.title then&lt;br /&gt;
		if child then&lt;br /&gt;
			root&lt;br /&gt;
				:wikitext(args.title)&lt;br /&gt;
				:wikitext(&#039;&amp;lt;/th&amp;gt;&amp;lt;/tr&amp;gt;&#039;) -- @todo replace this with unclosed again once mw.html gets it&lt;br /&gt;
		else&lt;br /&gt;
			root&lt;br /&gt;
				:tag(&#039;tr&#039;)&lt;br /&gt;
					:tag(&#039;th&#039;)&lt;br /&gt;
						:addClass(args.titleclass)&lt;br /&gt;
						:cssText(args.basestyle)&lt;br /&gt;
						:css(&#039;padding&#039;, &#039;0.2em 0.4em 0.2em&#039;)&lt;br /&gt;
						:css(&#039;padding-top&#039;, args.pretitle and 0)&lt;br /&gt;
						:css(&#039;font-size&#039;, &#039;145%&#039;)&lt;br /&gt;
						:css(&#039;line-height&#039;, &#039;1.2em&#039;)&lt;br /&gt;
						:cssText(args.titlestyle)&lt;br /&gt;
						:wikitext(args.title)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if args.image then&lt;br /&gt;
		local imageCell = root:tag(&#039;tr&#039;):tag(&#039;td&#039;)&lt;br /&gt;
&lt;br /&gt;
		imageCell&lt;br /&gt;
			:addClass(args.imageclass)&lt;br /&gt;
			:css(&#039;padding&#039;, &#039;0.2em 0 0.4em&#039;)&lt;br /&gt;
			:cssText(args.imagestyle)&lt;br /&gt;
			:wikitext(args.image)&lt;br /&gt;
&lt;br /&gt;
		if args.caption then&lt;br /&gt;
			imageCell&lt;br /&gt;
				:tag(&#039;div&#039;)&lt;br /&gt;
					:css(&#039;padding-top&#039;, &#039;0.2em&#039;)&lt;br /&gt;
					:css(&#039;line-height&#039;, &#039;1.2em&#039;)&lt;br /&gt;
					:cssText(args.captionstyle)&lt;br /&gt;
					:wikitext(args.caption)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if args.above then&lt;br /&gt;
		root&lt;br /&gt;
			:tag(&#039;tr&#039;)&lt;br /&gt;
				:tag(&#039;td&#039;)&lt;br /&gt;
					:addClass(args.aboveclass)&lt;br /&gt;
					:css(&#039;padding&#039;, &#039;0.3em 0.4em 0.3em&#039;)&lt;br /&gt;
					:css(&#039;font-weight&#039;, &#039;bold&#039;)&lt;br /&gt;
					:cssText(args.abovestyle)&lt;br /&gt;
					:newline() -- newline required for bullet-points to work&lt;br /&gt;
					:wikitext(args.above)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local rowNums = {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		k = &#039;&#039; .. k&lt;br /&gt;
		local num = k:match(&#039;^heading(%d+)$&#039;) or k:match(&#039;^content(%d+)$&#039;)&lt;br /&gt;
		if num then table.insert(rowNums, tonumber(num)) end&lt;br /&gt;
	end&lt;br /&gt;
	table.sort(rowNums)&lt;br /&gt;
	-- remove duplicates from the list (e.g. 3 will be duplicated if both heading3 and content3 are specified)&lt;br /&gt;
	for i = #rowNums, 1, -1 do&lt;br /&gt;
		if rowNums[i] == rowNums[i - 1] then&lt;br /&gt;
			table.remove(rowNums, i)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	for i, num in ipairs(rowNums) do&lt;br /&gt;
		local heading = args[&#039;heading&#039; .. num]&lt;br /&gt;
		if heading then&lt;br /&gt;
			root&lt;br /&gt;
				:tag(&#039;tr&#039;)&lt;br /&gt;
					:tag(&#039;th&#039;)&lt;br /&gt;
						:addClass(args.headingclass)&lt;br /&gt;
						:css(&#039;padding&#039;, &#039;0.1em&#039;)&lt;br /&gt;
						:cssText(args.basestyle)&lt;br /&gt;
						:cssText(args.headingstyle)&lt;br /&gt;
						:cssText(args[&#039;heading&#039; .. num .. &#039;style&#039;])&lt;br /&gt;
						:newline()&lt;br /&gt;
						:wikitext(heading)&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		local content = args[&#039;content&#039; .. num]&lt;br /&gt;
		if content then&lt;br /&gt;
			root&lt;br /&gt;
				:tag(&#039;tr&#039;)&lt;br /&gt;
					:tag(&#039;td&#039;)&lt;br /&gt;
						:addClass(args.contentclass)&lt;br /&gt;
						:css(&#039;padding&#039;, &#039;0 0.1em 0.4em&#039;)&lt;br /&gt;
						:cssText(args.contentstyle)&lt;br /&gt;
						:cssText(args[&#039;content&#039; .. num .. &#039;style&#039;])&lt;br /&gt;
						:newline()&lt;br /&gt;
						:wikitext(content)&lt;br /&gt;
						:done()&lt;br /&gt;
					:newline() -- Without a linebreak after the &amp;lt;/td&amp;gt;, a nested list like &amp;quot;* {{hlist| ...}}&amp;quot; doesn&#039;t parse correctly.&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if args.below then&lt;br /&gt;
		root&lt;br /&gt;
			:tag(&#039;tr&#039;)&lt;br /&gt;
				:tag(&#039;td&#039;)&lt;br /&gt;
					:addClass(args.belowclass)&lt;br /&gt;
					:css(&#039;padding&#039;, &#039;0.3em 0.4em 0.3em&#039;)&lt;br /&gt;
					:css(&#039;font-weight&#039;, &#039;bold&#039;)&lt;br /&gt;
					:cssText(args.belowstyle)&lt;br /&gt;
					:newline()&lt;br /&gt;
					:wikitext(args.below)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if not child then&lt;br /&gt;
		local navbarArg = args.navbar or args.tnavbar&lt;br /&gt;
		if navbarArg ~= &#039;none&#039; and navbarArg ~= &#039;off&#039; and (args.name or frame:getParent():getTitle():gsub(&#039;/sandbox$&#039;, &#039;&#039;) ~= &#039;Template:Sidebar&#039;) then&lt;br /&gt;
			root&lt;br /&gt;
				:tag(&#039;tr&#039;)&lt;br /&gt;
					:tag(&#039;td&#039;)&lt;br /&gt;
						:css(&#039;text-align&#039;, &#039;right&#039;)&lt;br /&gt;
						:css(&#039;font-size&#039;, &#039;115%&#039;)&lt;br /&gt;
						:cssText(args.navbarstyle or args.tnavbarstyle)&lt;br /&gt;
						:wikitext(navbar{&lt;br /&gt;
							args.name,&lt;br /&gt;
							mini = 1,&lt;br /&gt;
							fontstyle = args.navbarfontstyle or args.tnavbarfontstyle&lt;br /&gt;
						})&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return tostring(root)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.collapsible(frame)&lt;br /&gt;
	local args = getArgs(frame)&lt;br /&gt;
&lt;br /&gt;
	args.abovestyle = &#039;border-top: 1px solid #aaa; border-bottom: 1px solid #aaa;&#039; .. (args.abovestyle or &#039;&#039;)&lt;br /&gt;
	args.belowstyle = &#039;border-top: 1px solid #aaa; border-bottom: 1px solid #aaa;&#039; .. (args.belowstyle or &#039;&#039;)&lt;br /&gt;
	args.navbarstyle = &#039;padding-top: 0.6em;&#039; .. (args.navbarstyle or args.tnavbarstyle or &#039;&#039;)&lt;br /&gt;
	if not args.name and frame:getParent():getTitle():gsub(&#039;/sandbox$&#039;, &#039;&#039;) == &#039;Template:Sidebar with collapsible lists&#039; then&lt;br /&gt;
		args.navbar = &#039;none&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local contentArgs = {}&lt;br /&gt;
&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		local num = string.match(k, &#039;^list(%d+)$&#039;)&lt;br /&gt;
		if num then&lt;br /&gt;
			local expand = args.expanded and (args.expanded == &#039;all&#039; or args.expanded == args[&#039;list&#039; .. num .. &#039;name&#039;])&lt;br /&gt;
&lt;br /&gt;
			local row = mw.html.create(&#039;div&#039;)&lt;br /&gt;
			row&lt;br /&gt;
				:addClass(&#039;NavFrame&#039;)&lt;br /&gt;
				:addClass((not expand) and &#039;collapsed&#039; or nil)&lt;br /&gt;
				:css(&#039;border&#039;, &#039;none&#039;)&lt;br /&gt;
				:css(&#039;padding&#039;, 0)&lt;br /&gt;
				:cssText(args.listframestyle)&lt;br /&gt;
				:cssText(args[&#039;list&#039; .. num .. &#039;framestyle&#039;])&lt;br /&gt;
				:tag(&#039;div&#039;)&lt;br /&gt;
					:addClass(&#039;NavHead&#039;)&lt;br /&gt;
					:addClass(args.listtitleclass)&lt;br /&gt;
					:css(&#039;font-size&#039;, &#039;105%&#039;)&lt;br /&gt;
					:css(&#039;background&#039;, &#039;transparent&#039;)&lt;br /&gt;
					:css(&#039;text-align&#039;, &#039;left&#039;)&lt;br /&gt;
					:cssText(args.basestyle)&lt;br /&gt;
					:cssText(args.listtitlestyle)&lt;br /&gt;
					:cssText(args[&#039;list&#039; .. num .. &#039;titlestyle&#039;])&lt;br /&gt;
					:wikitext(trimAndAddAutomaticNewline(args[&#039;list&#039; .. num .. &#039;title&#039;] or &#039;List&#039;))&lt;br /&gt;
					:done()&lt;br /&gt;
				:tag(&#039;div&#039;)&lt;br /&gt;
					:addClass(&#039;NavContent&#039;)&lt;br /&gt;
					:addClass(args.listclass)&lt;br /&gt;
					:addClass(args[&#039;list&#039; .. num .. &#039;class&#039;])&lt;br /&gt;
					:css(&#039;font-size&#039;, &#039;105%&#039;)&lt;br /&gt;
					:css(&#039;padding&#039;, &#039;0.2em 0 0.4em&#039;)&lt;br /&gt;
					:css(&#039;text-align&#039;, &#039;center&#039;)&lt;br /&gt;
					:cssText(args.liststyle)&lt;br /&gt;
					:cssText(args[&#039;list&#039; .. num .. &#039;style&#039;])&lt;br /&gt;
					:wikitext(trimAndAddAutomaticNewline(args[&#039;list&#039; .. num]))&lt;br /&gt;
&lt;br /&gt;
			contentArgs[&#039;content&#039; .. num] = tostring(row)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	for k, v in pairs(contentArgs) do&lt;br /&gt;
		args[k] = v&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return p.sidebar(frame, args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Protection_banner/config&amp;diff=2426</id>
		<title>Module:Protection banner/config</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Protection_banner/config&amp;diff=2426"/>
		<updated>2015-07-09T17:07:25Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module provides configuration data for [[Module:Protection banner]].&lt;br /&gt;
&lt;br /&gt;
return {&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
--&lt;br /&gt;
--                                BANNER DATA&lt;br /&gt;
--&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- Banner data consists of six fields:&lt;br /&gt;
-- * text - the main protection text that appears at the top of protection&lt;br /&gt;
--   banners.&lt;br /&gt;
-- * explanation - the text that appears below the main protection text, used&lt;br /&gt;
--   to explain the details of the protection.&lt;br /&gt;
-- * tooltip - the tooltip text you see when you move the mouse over a small&lt;br /&gt;
--   padlock icon.&lt;br /&gt;
-- * link - the page that the small padlock icon links to.&lt;br /&gt;
-- * alt - the alt text for the small padlock icon. This is also used as tooltip&lt;br /&gt;
--   text for the large protection banners.&lt;br /&gt;
-- * image - the padlock image used in both protection banners and small padlock&lt;br /&gt;
--   icons.&lt;br /&gt;
--&lt;br /&gt;
-- The module checks in three separate tables to find a value for each field.&lt;br /&gt;
-- First it checks the banners table, which has values specific to the reason&lt;br /&gt;
-- for the page being protected. Then the module checks the defaultBanners&lt;br /&gt;
-- table, which has values specific to each protection level. Finally, the&lt;br /&gt;
-- module checks the masterBanner table, which holds data for protection&lt;br /&gt;
-- templates to use if no data has been found in the previous two tables.&lt;br /&gt;
--&lt;br /&gt;
-- The values in the banner data can take parameters. These are specified&lt;br /&gt;
-- using ${TEXTLIKETHIS} (a dollar sign preceding a parameter name&lt;br /&gt;
-- enclosed in curly braces).&lt;br /&gt;
--&lt;br /&gt;
--                          Available parameters:&lt;br /&gt;
--&lt;br /&gt;
-- ${CURRENTVERSION} - a link to the page history or the move log, with the&lt;br /&gt;
-- display message &amp;quot;current-version-edit-display&amp;quot; or&lt;br /&gt;
-- &amp;quot;current-version-move-display&amp;quot;.&lt;br /&gt;
--&lt;br /&gt;
-- ${EDITREQUEST} - a link to create an edit request for the current page.&lt;br /&gt;
--&lt;br /&gt;
-- ${EXPIRY} - the protection expiry date in the format DD Month YYYY. If&lt;br /&gt;
-- protection is indefinite or is not set, this is the blank string.&lt;br /&gt;
--&lt;br /&gt;
-- ${EXPLANATIONBLURB} - an explanation blurb, e.g. &amp;quot;Please discuss any changes&lt;br /&gt;
-- on the talk page; you may submit a request to ask an administrator to make&lt;br /&gt;
-- an edit if it is minor or supported by consensus.&amp;quot;&lt;br /&gt;
--&lt;br /&gt;
-- ${IMAGELINK} - a link to set the image to, depending on the protection&lt;br /&gt;
-- action and protection level.&lt;br /&gt;
--&lt;br /&gt;
-- ${INTROBLURB} - the PROTECTIONBLURB parameter, plus the expiry if an expiry&lt;br /&gt;
-- is set. E.g. &amp;quot;Editing of this page by new or unregistered users is currently &lt;br /&gt;
-- disabled until dd Month YYYY.&amp;quot;&lt;br /&gt;
--&lt;br /&gt;
-- ${INTROFRAGMENT} - the same as ${INTROBLURB}, but without final punctuation&lt;br /&gt;
-- so that it can be used in run-on sentences.&lt;br /&gt;
--&lt;br /&gt;
-- ${PAGETYPE} - the type of the page, e.g. &amp;quot;article&amp;quot; or &amp;quot;template&amp;quot;.&lt;br /&gt;
-- Defined in the cfg.pagetypes table.&lt;br /&gt;
--&lt;br /&gt;
-- ${PROTECTIONBLURB} - a blurb explaining the protection level of the page, e.g.&lt;br /&gt;
-- &amp;quot;Editing of this page by new or unregistered users is currently disabled&amp;quot;&lt;br /&gt;
--&lt;br /&gt;
-- ${PROTECTIONDATE} - the protection date, if it has been supplied to the&lt;br /&gt;
-- template.&lt;br /&gt;
--&lt;br /&gt;
-- ${PROTECTIONLEVEL} - the protection level, e.g. &amp;quot;fully protected&amp;quot; or&lt;br /&gt;
-- &amp;quot;semi-protected&amp;quot;.&lt;br /&gt;
--&lt;br /&gt;
-- ${PROTECTIONLOG} - a link to the protection log or the pending changes log,&lt;br /&gt;
-- depending on the protection action.&lt;br /&gt;
--&lt;br /&gt;
-- ${TALKPAGE} - a link to the talk page. If a section is specified, links&lt;br /&gt;
-- straight to that talk page section.&lt;br /&gt;
--&lt;br /&gt;
-- ${TOOLTIPBLURB} - uses the PAGETYPE, PROTECTIONTYPE and EXPIRY parameters to&lt;br /&gt;
-- create a blurb like &amp;quot;This template is semi-protected&amp;quot;, or &amp;quot;This article is&lt;br /&gt;
-- move-protected until DD Month YYYY&amp;quot;.&lt;br /&gt;
--&lt;br /&gt;
-- ${VANDAL} - links for the specified username (or the root page name)&lt;br /&gt;
-- using Module:Vandal-m.&lt;br /&gt;
--&lt;br /&gt;
--                                 Functions&lt;br /&gt;
--&lt;br /&gt;
-- For advanced users, it is possible to use Lua functions instead of strings&lt;br /&gt;
-- in the banner config tables. Using functions gives flexibility that is not&lt;br /&gt;
-- possible just by using parameters. Functions take two arguments, the&lt;br /&gt;
-- protection object and the template arguments, and they must output a string.&lt;br /&gt;
--&lt;br /&gt;
-- For example:&lt;br /&gt;
--&lt;br /&gt;
-- text = function (protectionObj, args)&lt;br /&gt;
--     if protectionObj.level == &#039;autoconfirmed&#039; then&lt;br /&gt;
--         return &#039;foo&#039;&lt;br /&gt;
--     else&lt;br /&gt;
--         return &#039;bar&#039;&lt;br /&gt;
--     end&lt;br /&gt;
-- end&lt;br /&gt;
--&lt;br /&gt;
-- Some protection object properties and methods that may be useful:&lt;br /&gt;
-- protectionObj.action - the protection action&lt;br /&gt;
-- protectionObj.level - the protection level&lt;br /&gt;
-- protectionObj.reason - the protection reason&lt;br /&gt;
-- protectionObj.expiry - the expiry. Nil if unset, the string &amp;quot;indef&amp;quot; if set&lt;br /&gt;
--     to indefinite, and the protection time in unix time if temporary.&lt;br /&gt;
-- protectionObj.protectionDate - the protection date in unix time, or nil if&lt;br /&gt;
--     unspecified.&lt;br /&gt;
-- protectionObj.bannerConfig - the banner config found by the module. Beware&lt;br /&gt;
--     of editing the config field used by the function, as it could create an&lt;br /&gt;
--     infinite loop.&lt;br /&gt;
-- protectionObj:isProtected - returns a boolean showing whether the page is&lt;br /&gt;
--     protected.&lt;br /&gt;
-- protectionObj:isTemporary - returns a boolean showing whether the expiry is&lt;br /&gt;
--     temporary.&lt;br /&gt;
-- protectionObj:isIncorrect - returns a boolean showing whether the protection&lt;br /&gt;
--     template is incorrect.&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
-- The master banner data, used if no values have been found in banners or&lt;br /&gt;
-- defaultBanners.&lt;br /&gt;
masterBanner = {&lt;br /&gt;
	text = &#039;${INTROBLURB}&#039;,&lt;br /&gt;
	explanation = &#039;${EXPLANATIONBLURB}&#039;,&lt;br /&gt;
	tooltip = &#039;${TOOLTIPBLURB}&#039;,&lt;br /&gt;
	link = &#039;${IMAGELINK}&#039;,&lt;br /&gt;
	alt = &#039;Page ${PROTECTIONLEVEL}&#039;&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
-- The default banner data. This holds banner data for different protection&lt;br /&gt;
-- levels.&lt;br /&gt;
-- *required* - this table needs edit, move, and autoreview subtables.&lt;br /&gt;
defaultBanners = {&lt;br /&gt;
	edit = {},&lt;br /&gt;
	move = {},&lt;br /&gt;
	autoreview = {&lt;br /&gt;
		autoconfirmed = {&lt;br /&gt;
			alt = &#039;Page protected with pending changes level 1&#039;,&lt;br /&gt;
			tooltip = &#039;All edits by unregistered and new users are subject to review&#039;,&lt;br /&gt;
			image = &#039;Padlock-silver-light.svg&#039;&lt;br /&gt;
		},&lt;br /&gt;
		default = {&lt;br /&gt;
			alt = &#039;Page protected with pending changes level 2&#039;,&lt;br /&gt;
			tooltip = &#039;All edits by users who are not reviewers or administrators are&#039;&lt;br /&gt;
				.. &#039; subject to review&#039;,&lt;br /&gt;
		}&lt;br /&gt;
	}&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
-- The banner data. This holds banner data for different protection reasons.&lt;br /&gt;
-- In fact, the reasons specified in this table control which reasons are&lt;br /&gt;
-- valid inputs to the first positional parameter.&lt;br /&gt;
--&lt;br /&gt;
-- There is also a non-standard &amp;quot;description&amp;quot; field that can be used for items&lt;br /&gt;
-- in this table. This is a description of the protection reason for use in the&lt;br /&gt;
-- module documentation.&lt;br /&gt;
--&lt;br /&gt;
-- *required* - this table needs edit, move, and autoreview subtables.&lt;br /&gt;
banners = {&lt;br /&gt;
	edit = {&lt;br /&gt;
		blp = {&lt;br /&gt;
			description = &#039;For pages protected to promote compliance with the&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Biographies of living persons&#039;&lt;br /&gt;
				.. &#039;|biographies of living persons]] policy.&#039;,&lt;br /&gt;
			text = &#039;${INTROFRAGMENT} to promote compliance with&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Biographies of living persons&#039;&lt;br /&gt;
				.. &amp;quot;|Wikipedia&#039;s&amp;amp;nbsp;policy on&amp;amp;nbsp;the&amp;amp;nbsp;biographies&amp;quot;&lt;br /&gt;
				.. &#039; of&amp;amp;nbsp;living&amp;amp;nbsp;people]].&#039;,&lt;br /&gt;
			tooltip = &#039;${TOOLTIPFRAGMENT} to promote compliance with the policy on&#039;&lt;br /&gt;
				.. &#039; biographies of living people&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		dmca = {&lt;br /&gt;
			description = &#039;For pages protected by the Wikimedia Foundation&#039;&lt;br /&gt;
				.. &#039; due to Digital Millennium Copyright Act takedown requests.&#039;,&lt;br /&gt;
			explanation = function (protectionObj, args)&lt;br /&gt;
				local ret = &#039;Pursuant to a rights owner notice under the Digital&#039;&lt;br /&gt;
					.. &#039; Millennium Copyright Act (DMCA) regarding some content&#039;&lt;br /&gt;
					.. &#039; in this article, the Wikimedia Foundation acted under&#039;&lt;br /&gt;
					.. &#039; applicable law and took down and restricted the content&#039;&lt;br /&gt;
					.. &#039; in question.&#039;&lt;br /&gt;
				if args.notice then&lt;br /&gt;
					ret = ret .. &#039; A copy of the received notice can be found here: &#039;&lt;br /&gt;
						.. args.notice .. &#039;.&#039;&lt;br /&gt;
				end&lt;br /&gt;
				ret = ret .. &#039; For more information, including websites discussing&#039;&lt;br /&gt;
					.. &#039; how to file a counter-notice, please see&#039;&lt;br /&gt;
					.. &amp;quot; [[Wikipedia:Office actions]] and the article&#039;s ${TALKPAGE}.&amp;quot;&lt;br /&gt;
					.. &amp;quot;&#039;&#039;&#039;Do not remove this template from the article until the&amp;quot;&lt;br /&gt;
					.. &amp;quot; restrictions are withdrawn&#039;&#039;&#039;.&amp;quot;&lt;br /&gt;
				return ret&lt;br /&gt;
			end,&lt;br /&gt;
			image = &#039;Padlock-black.svg&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		dispute = {&lt;br /&gt;
			description = &#039;For pages protected due to editing disputes.&#039;,&lt;br /&gt;
			text = function (protectionObj, args)&lt;br /&gt;
				-- Find the value of &amp;quot;disputes&amp;quot;.&lt;br /&gt;
				local display = &#039;disputes&#039;&lt;br /&gt;
				local disputes&lt;br /&gt;
				if args.section then&lt;br /&gt;
					disputes = string.format(&lt;br /&gt;
						&#039;[[%s:%s#%s|%s]]&#039;,&lt;br /&gt;
						mw.site.namespaces[protectionObj.title.namespace].talk.name,&lt;br /&gt;
						protectionObj.title.text,&lt;br /&gt;
						args.section,&lt;br /&gt;
						display&lt;br /&gt;
					)&lt;br /&gt;
				else&lt;br /&gt;
					disputes = display&lt;br /&gt;
				end&lt;br /&gt;
&lt;br /&gt;
				-- Make the blurb, depending on the expiry.&lt;br /&gt;
				local msg&lt;br /&gt;
				if type(protectionObj.expiry) == &#039;number&#039; then&lt;br /&gt;
					msg = &#039;${INTROFRAGMENT} or until editing %s have been resolved.&#039;&lt;br /&gt;
				else&lt;br /&gt;
					msg = &#039;${INTROFRAGMENT} until editing %s have been resolved.&#039;&lt;br /&gt;
				end&lt;br /&gt;
				return string.format(msg, disputes)&lt;br /&gt;
			end,&lt;br /&gt;
			explanation = &amp;quot;This protection is &#039;&#039;&#039;not&#039;&#039;&#039; an endorsement of the&amp;quot;&lt;br /&gt;
				.. &#039; ${CURRENTVERSION}. ${EXPLANATIONBLURB}&#039;,&lt;br /&gt;
			tooltip = &#039;${TOOLTIPFRAGMENT} due to editing disputes&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		mainpage = {&lt;br /&gt;
			description = &#039;For pages protected for being displayed on the [[Main Page]].&#039;,&lt;br /&gt;
			text = &#039;This file is currently&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:This page is protected|protected]] from&#039;&lt;br /&gt;
				.. &#039; editing because it is currently or will soon be displayed&#039;&lt;br /&gt;
				.. &#039; on the [[Main Page]].&#039;,&lt;br /&gt;
			explanation = &#039;Images on the Main Page are protected due to their high&#039;&lt;br /&gt;
				.. &#039; visibility. Please discuss any necessary changes on the ${TALKPAGE}.&#039;&lt;br /&gt;
				.. &#039;&amp;lt;br /&amp;gt;&amp;lt;span style=&amp;quot;font-size:90%;&amp;quot;&amp;gt;&#039;&lt;br /&gt;
				.. &amp;quot;&#039;&#039;&#039;Administrators:&#039;&#039;&#039; Once this image is definitely off the Main Page,&amp;quot;&lt;br /&gt;
				.. &#039; please unprotect this file, or reduce to semi-protection,&#039;&lt;br /&gt;
				.. &#039; as appropriate.&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		office = {&lt;br /&gt;
			description = &#039;For pages protected by the Wikimedia Foundation.&#039;,&lt;br /&gt;
			text = function (protectionObj, args)&lt;br /&gt;
				local ret = &#039;This ${PAGETYPE} is currently under the&#039;&lt;br /&gt;
					.. &#039; scrutiny of the&#039;&lt;br /&gt;
					.. &#039; [[Wikipedia:Office actions|Wikimedia Foundation Office]]&#039;&lt;br /&gt;
					.. &#039; and is protected.&#039;&lt;br /&gt;
				if protectionObj.protectionDate then&lt;br /&gt;
					ret = ret .. &#039; It has been protected since ${PROTECTIONDATE}.&#039;&lt;br /&gt;
				end&lt;br /&gt;
				return ret&lt;br /&gt;
			end,&lt;br /&gt;
			explanation = &amp;quot;If you can edit this page, please discuss all changes and&amp;quot;&lt;br /&gt;
				.. &amp;quot; additions on the ${TALKPAGE} first. &#039;&#039;&#039;Do not remove protection from this&amp;quot;&lt;br /&gt;
				.. &amp;quot; page unless you are authorized by the Wikimedia Foundation to do&amp;quot;&lt;br /&gt;
				.. &amp;quot; so.&#039;&#039;&#039;&amp;quot;,&lt;br /&gt;
			image = &#039;Padlock-black.svg&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		reset = {&lt;br /&gt;
			description = &#039;For pages protected by the Wikimedia Foundation and&#039;&lt;br /&gt;
				.. &#039; &amp;quot;reset&amp;quot; to a bare-bones version.&#039;,&lt;br /&gt;
 			text = &#039;This ${PAGETYPE} is currently under the&#039;&lt;br /&gt;
					.. &#039; scrutiny of the&#039;&lt;br /&gt;
					.. &#039; [[Wikipedia:Office actions|Wikimedia Foundation Office]]&#039;&lt;br /&gt;
					.. &#039; and is protected.&#039;,&lt;br /&gt;
			explanation = function (protectionObj, args)&lt;br /&gt;
				local ret = &#039;&#039;&lt;br /&gt;
				if protectionObj.protectionDate then&lt;br /&gt;
					ret = ret .. &#039;On ${PROTECTIONDATE} this ${PAGETYPE} was&#039;&lt;br /&gt;
				else&lt;br /&gt;
					ret = ret .. &#039;This ${PAGETYPE} has been&#039;&lt;br /&gt;
				end&lt;br /&gt;
				ret = ret .. &#039; reduced to a&#039;&lt;br /&gt;
				.. &#039; simplified, &amp;quot;bare bones&amp;quot; version so that it may be completely&#039;&lt;br /&gt;
				.. &#039; rewritten to ensure it meets the policies of&#039;&lt;br /&gt;
				.. &#039; [[WP:NPOV|Neutral Point of View]] and [[WP:V|Verifiability]].&#039;&lt;br /&gt;
				.. &#039; Standard Wikipedia policies will apply to its rewriting—which&#039;&lt;br /&gt;
				.. &#039; will eventually be open to all editors—and will be strictly&#039;&lt;br /&gt;
				.. &#039; enforced. The ${PAGETYPE} has been ${PROTECTIONLEVEL} while&#039;&lt;br /&gt;
				.. &#039; it is being rebuilt.\n\n&#039;&lt;br /&gt;
				.. &#039;Any insertion of material directly from&#039;&lt;br /&gt;
				.. &#039; pre-protection revisions of the ${PAGETYPE} will be removed, as&#039;&lt;br /&gt;
				.. &#039; will any material added to the ${PAGETYPE} that is not properly&#039;&lt;br /&gt;
				.. &#039; sourced. The associated talk page(s) were also cleared on the&#039;&lt;br /&gt;
				.. &amp;quot; same date.\n\n&amp;quot;&lt;br /&gt;
				.. &amp;quot;If you can edit this page, please discuss all changes and&amp;quot;&lt;br /&gt;
				.. &amp;quot; additions on the ${TALKPAGE} first. &#039;&#039;&#039;Do not override&amp;quot;&lt;br /&gt;
				.. &amp;quot; this action, and do not remove protection from this page,&amp;quot;&lt;br /&gt;
				.. &amp;quot; unless you are authorized by the Wikimedia Foundation&amp;quot;&lt;br /&gt;
				.. &amp;quot; to do so. No editor may remove this notice.&#039;&#039;&#039;&amp;quot;&lt;br /&gt;
&lt;br /&gt;
				return ret&lt;br /&gt;
			end,&lt;br /&gt;
			image = &#039;Padlock-black.svg&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		sock = {&lt;br /&gt;
			description = &#039;For pages protected due to&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Sock puppetry|sock puppetry]].&#039;,&lt;br /&gt;
			text = &#039;${INTROFRAGMENT} to prevent [[Wikipedia:Sock puppetry|sock puppets]] of&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Blocking policy|blocked]] or&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Banning policy|banned users]]&#039;&lt;br /&gt;
				.. &#039; from editing it.&#039;,&lt;br /&gt;
			tooltip = &#039;${TOOLTIPFRAGMENT} to prevent sock puppets of blocked or banned users from&#039;&lt;br /&gt;
				.. &#039; editing it&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		template = {&lt;br /&gt;
			description = &#039;For [[Wikipedia:High-risk templates|high-risk]]&#039;&lt;br /&gt;
				.. &#039; templates and Lua modules.&#039;,&lt;br /&gt;
			text = &#039;This is a permanently [[Help:Protection|protected]] ${PAGETYPE},&#039;&lt;br /&gt;
				.. &#039; as it is [[Wikipedia:High-risk templates|high-risk]].&#039;,&lt;br /&gt;
			explanation = &#039;Please discuss any changes on the ${TALKPAGE}; you may&#039;&lt;br /&gt;
				.. &#039; ${EDITREQUEST} to ask an&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Administrators|administrator]] or&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Template editor|template editor]] to make an edit if&#039;&lt;br /&gt;
				.. &#039; it is [[Help:Minor edit#When to mark an edit as a minor edit&#039;&lt;br /&gt;
				.. &#039;|uncontroversial]] or supported by&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Consensus|consensus]]. You can also&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requests for page protection|request]] that the page be&#039;&lt;br /&gt;
				.. &#039; unprotected.&#039;,&lt;br /&gt;
			tooltip = &#039;This high-risk ${PAGETYPE} is permanently ${PROTECTIONLEVEL}&#039;&lt;br /&gt;
				.. &#039; to prevent vandalism&#039;,&lt;br /&gt;
			alt = &#039;Permanently protected ${PAGETYPE}&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		usertalk = {&lt;br /&gt;
			description = &#039;For pages protected against disruptive edits by a&#039;&lt;br /&gt;
				.. &#039; particular user.&#039;,&lt;br /&gt;
			text = &#039;${INTROFRAGMENT} to prevent ${VANDAL} from using it to make disruptive edits,&#039;&lt;br /&gt;
				.. &#039; such as abusing the&#039;&lt;br /&gt;
				.. &#039; &amp;amp;#123;&amp;amp;#123;[[Template:unblock|unblock]]&amp;amp;#125;&amp;amp;#125; template.&#039;,&lt;br /&gt;
			explanation = &#039;If you cannot edit this user talk page and you need to&#039;&lt;br /&gt;
				.. &#039; make a change or leave a message, you can&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requests for page protection&#039;&lt;br /&gt;
				.. &#039;#Current requests for edits to a protected page&#039;&lt;br /&gt;
				.. &#039;|request an edit]],&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requests for page protection&#039;&lt;br /&gt;
				.. &#039;#Current requests for reduction in protection level&#039;&lt;br /&gt;
				.. &#039;|request unprotection]],&#039;&lt;br /&gt;
				.. &#039; [[Special:Userlogin|log in]],&#039;&lt;br /&gt;
				.. &#039; or [[Special:UserLogin/signup|create an account]].&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		vandalism = {&lt;br /&gt;
			description = &#039;For pages protected against&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Vandalism|vandalism]].&#039;,&lt;br /&gt;
			text = &#039;${INTROFRAGMENT} due to [[Wikipedia:Vandalism|vandalism]].&#039;,&lt;br /&gt;
			explanation = function (protectionObj, args)&lt;br /&gt;
				local ret = &#039;&#039;&lt;br /&gt;
				if protectionObj.level == &#039;sysop&#039; then&lt;br /&gt;
					ret = ret .. &amp;quot;This protection is &#039;&#039;&#039;not&#039;&#039;&#039; an endorsement of the&amp;quot;&lt;br /&gt;
						.. &#039; ${CURRENTVERSION}. &#039;&lt;br /&gt;
				end&lt;br /&gt;
				return ret .. &#039;${EXPLANATIONBLURB}&#039;&lt;br /&gt;
			end,&lt;br /&gt;
			tooltip = &#039;${TOOLTIPFRAGMENT} due to vandalism&#039;,&lt;br /&gt;
		}&lt;br /&gt;
	},&lt;br /&gt;
	move = {&lt;br /&gt;
		dispute = {&lt;br /&gt;
			description = &#039;For pages protected against page moves due to&#039;&lt;br /&gt;
				.. &#039; disputes over the page title.&#039;,&lt;br /&gt;
			explanation = &amp;quot;This protection is &#039;&#039;&#039;not&#039;&#039;&#039; an endorsement of the&amp;quot;&lt;br /&gt;
				.. &#039; ${CURRENTVERSION}. ${EXPLANATIONBLURB}&#039;,&lt;br /&gt;
			image = &#039;Padlock-olive.svg&#039;&lt;br /&gt;
		},&lt;br /&gt;
		vandalism = {&lt;br /&gt;
			description = &#039;For pages protected against&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Vandalism#Page-move vandalism&#039;&lt;br /&gt;
				.. &#039; |page-move vandalism]].&#039;&lt;br /&gt;
		}&lt;br /&gt;
	},&lt;br /&gt;
	autoreview = {}&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
--&lt;br /&gt;
--                            GENERAL DATA TABLES&lt;br /&gt;
--&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Protection blurbs&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table produces the protection blurbs available with the&lt;br /&gt;
-- ${PROTECTIONBLURB} parameter. It is sorted by protection action and&lt;br /&gt;
-- protection level, and is checked by the module in the following order:&lt;br /&gt;
-- 1. page&#039;s protection action, page&#039;s protection level&lt;br /&gt;
-- 2. page&#039;s protection action, default protection level&lt;br /&gt;
-- 3. &amp;quot;edit&amp;quot; protection action, default protection level&lt;br /&gt;
--&lt;br /&gt;
-- It is possible to use banner parameters inside this table.&lt;br /&gt;
-- *required* - this table needs edit, move, and autoreview subtables.&lt;br /&gt;
protectionBlurbs = {&lt;br /&gt;
	edit = {&lt;br /&gt;
		default = &#039;This ${PAGETYPE} is currently [[Help:Protection|&#039;&lt;br /&gt;
			.. &#039;protected]] from editing&#039;,&lt;br /&gt;
		autoconfirmed = &#039;Editing of this ${PAGETYPE} by [[Wikipedia:User access&#039;&lt;br /&gt;
			.. &#039; levels#New users|new]] or [[Wikipedia:User access levels#Unregistered&#039;&lt;br /&gt;
			.. &#039; users|unregistered]] users is currently [[Help:Protection|disabled]]&#039;&lt;br /&gt;
	},&lt;br /&gt;
	move = {&lt;br /&gt;
		default = &#039;This ${PAGETYPE} is currently [[Help:Protection|protected]]&#039;&lt;br /&gt;
			.. &#039; from [[Help:Moving a page|page moves]]&#039;&lt;br /&gt;
	},&lt;br /&gt;
	autoreview = {&lt;br /&gt;
		autoconfirmed = &#039;All edits made to this ${PAGETYPE} by&#039;&lt;br /&gt;
			.. &#039; [[Wikipedia:User access levels#New users|new]] or&#039;&lt;br /&gt;
			.. &#039; [[Wikipedia:User access levels#Unregistered users|unregistered]]&#039;&lt;br /&gt;
			.. &#039; users are currently&#039;&lt;br /&gt;
			.. &#039; [[Wikipedia:Pending changes|subject to review]]&#039;,&lt;br /&gt;
		default = &#039;All edits made to this ${PAGETYPE} by users who are not&#039;&lt;br /&gt;
			.. &#039; [[Wikipedia:Reviewing|reviewers]] or&#039;&lt;br /&gt;
			.. &#039; [[Wikipedia:Administrators|administrators]] are currently&#039;&lt;br /&gt;
			.. &#039; [[Wikipedia:Pending changes|subject to review]]&#039;&lt;br /&gt;
	}&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Explanation blurbs&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table produces the explanation blurbs available with the&lt;br /&gt;
-- ${EXPLANATIONBLURB} parameter. It is sorted by protection action,&lt;br /&gt;
-- protection level, and whether the page is a talk page or not. If the page is&lt;br /&gt;
-- a talk page it will have a talk key of &amp;quot;talk&amp;quot;; otherwise it will have a talk&lt;br /&gt;
-- key of &amp;quot;subject&amp;quot;. The table is checked in the following order:&lt;br /&gt;
-- 1. page&#039;s protection action, page&#039;s protection level, page&#039;s talk key&lt;br /&gt;
-- 2. page&#039;s protection action, page&#039;s protection level, default talk key&lt;br /&gt;
-- 3. page&#039;s protection action, default protection level, page&#039;s talk key&lt;br /&gt;
-- 4. page&#039;s protection action, default protection level, default talk key&lt;br /&gt;
--&lt;br /&gt;
-- It is possible to use banner parameters inside this table.&lt;br /&gt;
-- *required* - this table needs edit, move, and autoreview subtables.&lt;br /&gt;
explanationBlurbs = {&lt;br /&gt;
	edit = {&lt;br /&gt;
		autoconfirmed = {&lt;br /&gt;
			subject = &#039;See the [[Wikipedia:Protection policy|&#039;&lt;br /&gt;
				.. &#039;protection policy]] and ${PROTECTIONLOG} for more details. If you&#039;&lt;br /&gt;
				.. &#039; cannot edit this ${PAGETYPE} and you wish to make a change, you can&#039;&lt;br /&gt;
				.. &#039; ${EDITREQUEST}, discuss changes on the ${TALKPAGE},&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requests for page protection&#039;&lt;br /&gt;
				.. &#039;#Current requests for reduction in protection level&#039;&lt;br /&gt;
				.. &#039;|request unprotection]], [[Special:Userlogin|log in]], or&#039;&lt;br /&gt;
				.. &#039; [[Special:UserLogin/signup|create an account]].&#039;,&lt;br /&gt;
			default = &#039;See the [[Wikipedia:Protection policy|&#039;&lt;br /&gt;
				.. &#039;protection policy]] and ${PROTECTIONLOG} for more details. If you&#039;&lt;br /&gt;
				.. &#039; cannot edit this ${PAGETYPE} and you wish to make a change, you can&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requests for page protection&#039;&lt;br /&gt;
				.. &#039;#Current requests for reduction in protection level&#039;&lt;br /&gt;
				.. &#039;|request unprotection]], [[Special:Userlogin|log in]], or&#039;&lt;br /&gt;
				.. &#039; [[Special:UserLogin/signup|create an account]].&#039;,&lt;br /&gt;
		},&lt;br /&gt;
		default = {&lt;br /&gt;
			subject = &#039;See the [[Wikipedia:Protection policy|&#039;&lt;br /&gt;
				.. &#039;protection policy]] and ${PROTECTIONLOG} for more details.&#039;&lt;br /&gt;
				.. &#039; Please discuss any changes on the ${TALKPAGE}; you&#039;&lt;br /&gt;
				.. &#039; may ${EDITREQUEST} to ask an&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Administrators|administrator]] to make an edit if it&#039;&lt;br /&gt;
				.. &#039; is [[Help:Minor edit#When to mark an edit as a minor edit&#039;&lt;br /&gt;
				.. &#039;|uncontroversial]] or supported by [[Wikipedia:Consensus&#039;&lt;br /&gt;
				.. &#039;|consensus]]. You may also [[Wikipedia:Requests for&#039;&lt;br /&gt;
				.. &#039; page protection#Current requests for reduction in protection level&#039;&lt;br /&gt;
				.. &#039;|request]] that this page be unprotected.&#039;,&lt;br /&gt;
			default = &#039;See the [[Wikipedia:Protection policy|&#039;&lt;br /&gt;
				.. &#039;protection policy]] and ${PROTECTIONLOG} for more details.&#039;&lt;br /&gt;
				.. &#039; You may [[Wikipedia:Requests for page&#039;&lt;br /&gt;
				.. &#039; protection#Current requests for edits to a protected page|request an&#039;&lt;br /&gt;
				.. &#039; edit]] to this page, or [[Wikipedia:Requests for&#039;&lt;br /&gt;
				.. &#039; page protection#Current requests for reduction in protection level&#039;&lt;br /&gt;
				.. &#039;|ask]] for it to be unprotected.&#039;&lt;br /&gt;
		}&lt;br /&gt;
	},&lt;br /&gt;
	move = {&lt;br /&gt;
		default = {&lt;br /&gt;
			subject = &#039;See the [[Wikipedia:Protection policy|&#039;&lt;br /&gt;
				.. &#039;protection policy]] and ${PROTECTIONLOG} for more details.&#039;&lt;br /&gt;
				.. &#039; The page may still be edited but cannot be moved&#039;&lt;br /&gt;
				.. &#039; until unprotected. Please discuss any suggested moves on the&#039;&lt;br /&gt;
				.. &#039; ${TALKPAGE} or at [[Wikipedia:Requested moves]]. You can also&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requests for page protection|request]] that the page be&#039;&lt;br /&gt;
				.. &#039; unprotected.&#039;,&lt;br /&gt;
			default = &#039;See the [[Wikipedia:Protection policy|&#039;&lt;br /&gt;
				.. &#039;protection policy]] and ${PROTECTIONLOG} for more details.&#039;&lt;br /&gt;
				.. &#039; The page may still be edited but cannot be moved&#039;&lt;br /&gt;
				.. &#039; until unprotected. Please discuss any suggested moves at&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requested moves]]. You can also&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requests for page protection|request]] that the page be&#039;&lt;br /&gt;
				.. &#039; unprotected.&#039;&lt;br /&gt;
		}&lt;br /&gt;
	},&lt;br /&gt;
	autoreview = {&lt;br /&gt;
		default = {&lt;br /&gt;
			reviewer = &#039;See the [[Wikipedia:Protection policy|&#039;&lt;br /&gt;
				.. &#039;protection policy]] and ${PROTECTIONLOG} for more details.&#039;&lt;br /&gt;
				.. &#039; Edits to this ${PAGETYPE} will not be visible to readers&#039;&lt;br /&gt;
				.. &#039; until they are accepted by a reviewer or an administrator.&#039;&lt;br /&gt;
				.. &#039; To avoid the need for your edits to be reviewed, you may&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requests for page protection&#039;&lt;br /&gt;
				.. &#039;#Current requests for reduction in protection level&#039;&lt;br /&gt;
				.. &#039;|request unprotection]]. Experienced editors may also&#039;&lt;br /&gt;
				.. &#039; request the [[Wikipedia:Reviewing|reviewer user right]].&#039;,&lt;br /&gt;
			default = &#039;See the [[Wikipedia:Protection policy|&#039;&lt;br /&gt;
				.. &#039;protection policy]] and ${PROTECTIONLOG} for more details.&#039;&lt;br /&gt;
				.. &#039; Edits to this ${PAGETYPE} by new and unregistered users&#039;&lt;br /&gt;
				.. &#039; will not be visible to readers until they are accepted by&#039;&lt;br /&gt;
				.. &#039; a reviewer. To avoid the need for your edits to be&#039;&lt;br /&gt;
				.. &#039; reviewed, you may&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Requests for page protection&#039;&lt;br /&gt;
				.. &#039;#Current requests for reduction in protection level&#039;&lt;br /&gt;
				.. &#039;|request unprotection]], [[Special:Userlogin|log in]], or&#039;&lt;br /&gt;
				.. &#039; [[Special:UserLogin/signup|create an account]].&#039;&lt;br /&gt;
		},&lt;br /&gt;
	}&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Protection levels&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table provides the data for the ${PROTECTIONLEVEL} parameter, which&lt;br /&gt;
-- produces a short label for different protection levels. It is sorted by&lt;br /&gt;
-- protection action and proteciton level, and is checked in the following&lt;br /&gt;
-- order:&lt;br /&gt;
-- 1. page&#039;s protection action, page&#039;s protection level&lt;br /&gt;
-- 2. page&#039;s protection action, default protection level&lt;br /&gt;
-- 3. &amp;quot;edit&amp;quot; protection action, default protection level&lt;br /&gt;
--&lt;br /&gt;
-- It is possible to use banner parameters inside this table.&lt;br /&gt;
-- *required* - this table needs edit, move, and autoreview subtables.&lt;br /&gt;
protectionLevels = {&lt;br /&gt;
	edit = {&lt;br /&gt;
		default = &#039;protected&#039;,&lt;br /&gt;
		templateeditor = &#039;template-protected&#039;,&lt;br /&gt;
		autoconfirmed = &#039;semi-protected&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	move = {&lt;br /&gt;
		default = &#039;move-protected&#039;&lt;br /&gt;
	},&lt;br /&gt;
	autoreview = {&lt;br /&gt;
	}&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Images&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table lists different padlock images for each protection action and&lt;br /&gt;
-- protection level. It is used if an image is not specified in any of the&lt;br /&gt;
-- banner data tables, and if the page does not satisfy the conditions for using&lt;br /&gt;
-- the [&#039;image-filename-indef&#039;] image. It is checked in the following order:&lt;br /&gt;
-- 1. page&#039;s protection action, page&#039;s protection level&lt;br /&gt;
-- 2. page&#039;s protection action, default protection level&lt;br /&gt;
images = {&lt;br /&gt;
	edit = {&lt;br /&gt;
		default = &#039;Padlock.svg&#039;,&lt;br /&gt;
		templateeditor = &#039;Padlock-pink.svg&#039;,&lt;br /&gt;
		autoconfirmed = &#039;Padlock-silver.svg&#039;&lt;br /&gt;
	},&lt;br /&gt;
	move = {&lt;br /&gt;
		default = &#039;Padlock-olive.svg&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	autoreview = {&lt;br /&gt;
		autoconfirmed = &#039;Padlock-silver-light.svg&#039;,&lt;br /&gt;
		default = &#039;Padlock-orange.svg&#039;&lt;br /&gt;
	}&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
-- Pages with a reason specified in this table will show the special &amp;quot;indef&amp;quot;&lt;br /&gt;
-- padlock, defined in the &#039;image-filename-indef&#039; message, if no expiry is set.&lt;br /&gt;
indefImageReasons = {&lt;br /&gt;
	template = true&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Image links&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table provides the data for the ${IMAGELINK} parameter, which gets&lt;br /&gt;
-- the image link for small padlock icons based on the page&#039;s protection action&lt;br /&gt;
-- and protection level. It is checked in the following order:&lt;br /&gt;
-- 1. page&#039;s protection action, page&#039;s protection level&lt;br /&gt;
-- 2. page&#039;s protection action, default protection level&lt;br /&gt;
-- 3. &amp;quot;edit&amp;quot; protection action, default protection level&lt;br /&gt;
--&lt;br /&gt;
-- It is possible to use banner parameters inside this table.&lt;br /&gt;
-- *required* - this table needs edit, move, and autoreview subtables.&lt;br /&gt;
imageLinks = {&lt;br /&gt;
	edit = {&lt;br /&gt;
		default = &#039;Wikipedia:Protection policy#full&#039;,&lt;br /&gt;
		templateeditor = &#039;Wikipedia:Protection policy#template&#039;,&lt;br /&gt;
		autoconfirmed = &#039;Wikipedia:Protection policy#semi&#039;&lt;br /&gt;
	},&lt;br /&gt;
	move = {&lt;br /&gt;
		default = &#039;Wikipedia:Protection policy#move&#039;&lt;br /&gt;
	},&lt;br /&gt;
	autoreview = {&lt;br /&gt;
		autoconfirmed = &#039;Wikipedia:Protection policy#pc1&#039;,&lt;br /&gt;
		reviewer = &#039;Wikipedia:Protection policy#pc2&#039;&lt;br /&gt;
	}&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Padlock indicator names&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table provides the &amp;quot;name&amp;quot; attribute for the &amp;lt;indicator&amp;gt; extension tag&lt;br /&gt;
-- with which small padlock icons are generated. All indicator tags on a page&lt;br /&gt;
-- are displayed in alphabetical order based on this attribute, and with&lt;br /&gt;
-- indicator tags with duplicate names, the last tag on the page wins.&lt;br /&gt;
-- The attribute is chosen based on the protection action; table keys must be a&lt;br /&gt;
-- protection action name or the string &amp;quot;default&amp;quot;.&lt;br /&gt;
padlockIndicatorNames = {&lt;br /&gt;
	autoreview = &#039;pp-autoreview&#039;,&lt;br /&gt;
	default = &#039;pp-default&#039;&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Protection categories&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- The protection categories are stored in the protectionCategories table.&lt;br /&gt;
-- Keys to this table are made up of the following strings:&lt;br /&gt;
--&lt;br /&gt;
-- 1. the expiry date&lt;br /&gt;
-- 2. the namespace&lt;br /&gt;
-- 3. the protection reason (e.g. &amp;quot;dispute&amp;quot; or &amp;quot;vandalism&amp;quot;)&lt;br /&gt;
-- 4. the protection level (e.g. &amp;quot;sysop&amp;quot; or &amp;quot;autoconfirmed&amp;quot;)&lt;br /&gt;
-- 5. the action (e.g. &amp;quot;edit&amp;quot; or &amp;quot;move&amp;quot;)&lt;br /&gt;
-- &lt;br /&gt;
-- When the module looks up a category in the table, first it will will check to&lt;br /&gt;
-- see a key exists that corresponds to all five parameters. For example, a&lt;br /&gt;
-- user page semi-protected from vandalism for two weeks would have the key&lt;br /&gt;
-- &amp;quot;temp-user-vandalism-autoconfirmed-edit&amp;quot;. If no match is found, the module&lt;br /&gt;
-- changes the first part of the key to &amp;quot;all&amp;quot; and checks the table again. It&lt;br /&gt;
-- keeps checking increasingly generic key combinations until it finds the&lt;br /&gt;
-- field, or until it reaches the key &amp;quot;all-all-all-all-all&amp;quot;.&lt;br /&gt;
--&lt;br /&gt;
-- The module uses a binary matrix to determine the order in which to search.&lt;br /&gt;
-- This is best demonstrated by a table. In this table, the &amp;quot;0&amp;quot; values&lt;br /&gt;
-- represent &amp;quot;all&amp;quot;, and the &amp;quot;1&amp;quot; values represent the original data (e.g.&lt;br /&gt;
-- &amp;quot;indef&amp;quot; or &amp;quot;file&amp;quot; or &amp;quot;vandalism&amp;quot;).&lt;br /&gt;
--&lt;br /&gt;
--        expiry    namespace reason   level     action&lt;br /&gt;
-- order&lt;br /&gt;
-- 1      1         1         1        1         1&lt;br /&gt;
-- 2      0         1         1        1         1&lt;br /&gt;
-- 3      1         0         1        1         1&lt;br /&gt;
-- 4      0         0         1        1         1&lt;br /&gt;
-- 5      1         1         0        1         1&lt;br /&gt;
-- 6      0         1         0        1         1&lt;br /&gt;
-- 7      1         0         0        1         1&lt;br /&gt;
-- 8      0         0         0        1         1&lt;br /&gt;
-- 9      1         1         1        0         1&lt;br /&gt;
-- 10     0         1         1        0         1&lt;br /&gt;
-- 11     1         0         1        0         1&lt;br /&gt;
-- 12     0         0         1        0         1&lt;br /&gt;
-- 13     1         1         0        0         1&lt;br /&gt;
-- 14     0         1         0        0         1&lt;br /&gt;
-- 15     1         0         0        0         1&lt;br /&gt;
-- 16     0         0         0        0         1&lt;br /&gt;
-- 17     1         1         1        1         0&lt;br /&gt;
-- 18     0         1         1        1         0&lt;br /&gt;
-- 19     1         0         1        1         0&lt;br /&gt;
-- 20     0         0         1        1         0&lt;br /&gt;
-- 21     1         1         0        1         0&lt;br /&gt;
-- 22     0         1         0        1         0&lt;br /&gt;
-- 23     1         0         0        1         0&lt;br /&gt;
-- 24     0         0         0        1         0&lt;br /&gt;
-- 25     1         1         1        0         0&lt;br /&gt;
-- 26     0         1         1        0         0&lt;br /&gt;
-- 27     1         0         1        0         0&lt;br /&gt;
-- 28     0         0         1        0         0&lt;br /&gt;
-- 29     1         1         0        0         0&lt;br /&gt;
-- 30     0         1         0        0         0&lt;br /&gt;
-- 31     1         0         0        0         0&lt;br /&gt;
-- 32     0         0         0        0         0&lt;br /&gt;
--&lt;br /&gt;
-- In this scheme the action has the highest priority, as it is the last&lt;br /&gt;
-- to change, and the expiry has the least priority, as it changes the most.&lt;br /&gt;
-- The priorities of the expiry, the protection level and the action are&lt;br /&gt;
-- fixed, but the priorities of the reason and the namespace can be swapped&lt;br /&gt;
-- through the use of the cfg.bannerDataNamespaceHasPriority table.&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
-- If the reason specified to the template is listed in this table,&lt;br /&gt;
-- namespace data will take priority over reason data in the protectionCategories&lt;br /&gt;
-- table.&lt;br /&gt;
reasonsWithNamespacePriority = {&lt;br /&gt;
	vandalism = true,&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
-- The string to use as a namespace key for the protectionCategories table for each&lt;br /&gt;
-- namespace number.&lt;br /&gt;
categoryNamespaceKeys = {&lt;br /&gt;
	[  2] = &#039;user&#039;,&lt;br /&gt;
	[  3] = &#039;user&#039;,&lt;br /&gt;
	[  4] = &#039;project&#039;,&lt;br /&gt;
	[  6] = &#039;file&#039;,&lt;br /&gt;
	[  8] = &#039;mediawiki&#039;,&lt;br /&gt;
	[ 10] = &#039;template&#039;,&lt;br /&gt;
	[ 12] = &#039;project&#039;,&lt;br /&gt;
	[ 14] = &#039;category&#039;,&lt;br /&gt;
	[100] = &#039;portal&#039;,&lt;br /&gt;
	[828] = &#039;module&#039;,&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
protectionCategories = {&lt;br /&gt;
	[&#039;all|all|all|all|all&#039;]                  = &#039;Wikipedia protected pages&#039;,&lt;br /&gt;
	[&#039;all|all|office|all|all&#039;]               = &#039;Wikipedia Office-protected pages&#039;,&lt;br /&gt;
	[&#039;all|all|reset|all|all&#039;]                = &#039;Wikipedia Office-protected pages&#039;,&lt;br /&gt;
	[&#039;all|all|dmca|all|all&#039;]                 = &#039;Wikipedia Office-protected pages&#039;,&lt;br /&gt;
	[&#039;all|all|mainpage|all|all&#039;]             = &#039;Protected main page images&#039;,&lt;br /&gt;
	[&#039;all|template|all|all|edit&#039;]            = &#039;Wikipedia protected templates&#039;,&lt;br /&gt;
	[&#039;all|all|all|autoconfirmed|edit&#039;]       = &#039;Wikipedia semi-protected pages&#039;,&lt;br /&gt;
	[&#039;indef|all|all|autoconfirmed|edit&#039;]     = &#039;Wikipedia indefinitely semi-protected pages&#039;,&lt;br /&gt;
	[&#039;all|all|blp|autoconfirmed|edit&#039;]       = &#039;Wikipedia indefinitely semi-protected biographies of living people&#039;,&lt;br /&gt;
	[&#039;temp|all|blp|autoconfirmed|edit&#039;]      = &#039;Wikipedia temporarily semi-protected biographies of living people&#039;,&lt;br /&gt;
	[&#039;all|all|dispute|autoconfirmed|edit&#039;]   = &#039;Wikipedia pages semi-protected due to dispute&#039;,&lt;br /&gt;
	[&#039;all|all|sock|autoconfirmed|edit&#039;]      = &#039;Wikipedia pages semi-protected from banned users&#039;,&lt;br /&gt;
	[&#039;all|all|vandalism|autoconfirmed|edit&#039;] = &#039;Wikipedia pages semi-protected against vandalism&#039;,&lt;br /&gt;
	[&#039;all|category|all|autoconfirmed|edit&#039;]  = &#039;Wikipedia semi-protected categories&#039;,&lt;br /&gt;
	[&#039;all|file|all|autoconfirmed|edit&#039;]      = &#039;Semi-protected images&#039;,&lt;br /&gt;
	[&#039;all|portal|all|autoconfirmed|edit&#039;]    = &#039;Semi-protected portals&#039;,&lt;br /&gt;
	[&#039;all|project|all|autoconfirmed|edit&#039;]   = &#039;Semi-protected project pages&#039;,&lt;br /&gt;
	[&#039;all|talk|all|autoconfirmed|edit&#039;]      = &#039;Semi-protected talk pages&#039;,&lt;br /&gt;
	[&#039;all|template|all|autoconfirmed|edit&#039;]  = &#039;Wikipedia semi-protected templates&#039;,&lt;br /&gt;
	[&#039;all|user|all|autoconfirmed|edit&#039;]      = &#039;Wikipedia semi-protected user and user talk pages&#039;,&lt;br /&gt;
	[&#039;all|all|blp|sysop|edit&#039;]               = &#039;Wikipedia indefinitely protected biographies of living people&#039;,&lt;br /&gt;
	[&#039;temp|all|blp|sysop|edit&#039;]              = &#039;Wikipedia temporarily protected biographies of living people&#039;,&lt;br /&gt;
	[&#039;all|all|dispute|sysop|edit&#039;]           = &#039;Wikipedia pages protected due to dispute&#039;,&lt;br /&gt;
	[&#039;all|all|sock|sysop|edit&#039;]              = &#039;Wikipedia pages protected from banned users&#039;,&lt;br /&gt;
	[&#039;all|all|vandalism|sysop|edit&#039;]         = &#039;Wikipedia pages protected against vandalism&#039;,&lt;br /&gt;
	[&#039;all|category|all|sysop|edit&#039;]          = &#039;Wikipedia protected categories&#039;,&lt;br /&gt;
	[&#039;all|file|all|sysop|edit&#039;]              = &#039;Protected images&#039;,&lt;br /&gt;
	[&#039;all|project|all|sysop|edit&#039;]           = &#039;Protected project pages&#039;,&lt;br /&gt;
	[&#039;all|talk|all|sysop|edit&#039;]              = &#039;Protected talk pages&#039;,&lt;br /&gt;
	[&#039;all|template|all|sysop|edit&#039;]          = &#039;Wikipedia protected templates&#039;,&lt;br /&gt;
	[&#039;all|user|all|sysop|edit&#039;]              = &#039;Wikipedia protected user and user talk pages&#039;,&lt;br /&gt;
	[&#039;all|module|all|all|edit&#039;]              = &#039;Wikipedia protected modules&#039;,&lt;br /&gt;
	[&#039;all|module|all|autoconfirmed|edit&#039;]    = &#039;Wikipedia semi-protected modules&#039;,&lt;br /&gt;
	[&#039;all|all|all|sysop|move&#039;]               = &#039;Wikipedia move-protected pages&#039;,&lt;br /&gt;
	[&#039;indef|all|all|sysop|move&#039;]             = &#039;Wikipedia indefinitely move-protected pages&#039;,&lt;br /&gt;
	[&#039;all|all|dispute|sysop|move&#039;]           = &#039;Wikipedia pages move-protected due to dispute&#039;,&lt;br /&gt;
	[&#039;all|all|vandalism|sysop|move&#039;]         = &#039;Wikipedia pages move-protected due to vandalism&#039;,&lt;br /&gt;
	[&#039;all|portal|all|sysop|move&#039;]            = &#039;Wikipedia move-protected portals&#039;,&lt;br /&gt;
	[&#039;all|portal|all|sysop|move&#039;]            = &#039;Wikipedia move-protected portals&#039;,&lt;br /&gt;
	[&#039;all|project|all|sysop|move&#039;]           = &#039;Wikipedia move-protected project pages&#039;,&lt;br /&gt;
	[&#039;all|talk|all|sysop|move&#039;]              = &#039;Wikipedia move-protected talk pages&#039;,&lt;br /&gt;
	[&#039;all|template|all|sysop|move&#039;]          = &#039;Wikipedia move-protected templates&#039;,&lt;br /&gt;
	[&#039;all|user|all|sysop|move&#039;]              = &#039;Wikipedia move-protected user and user talk pages&#039;,&lt;br /&gt;
	[&#039;all|all|all|autoconfirmed|autoreview&#039;] = &#039;Wikipedia pending changes protected pages (level 1)&#039;,&lt;br /&gt;
	[&#039;all|all|all|reviewer|autoreview&#039;]      = &#039;Wikipedia pending changes protected pages (level 2)&#039;,&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Expiry category config&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table configures the expiry category behaviour for each protection&lt;br /&gt;
-- action.&lt;br /&gt;
-- * If set to true, setting that action will always categorise the page if&lt;br /&gt;
--   an expiry parameter is not set.&lt;br /&gt;
-- * If set to false, setting that action will never categorise the page.&lt;br /&gt;
-- * If set to nil, the module will categorise the page if:&lt;br /&gt;
--   1) an expiry parameter is not set, and&lt;br /&gt;
--   2) a reason is provided, and&lt;br /&gt;
--   3) the specified reason is not blacklisted in the reasonsWithoutExpiryCheck&lt;br /&gt;
--      table.&lt;br /&gt;
&lt;br /&gt;
expiryCheckActions = {&lt;br /&gt;
	edit = nil,&lt;br /&gt;
	move = false,&lt;br /&gt;
	autoreview = true&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
reasonsWithoutExpiryCheck = {&lt;br /&gt;
	blp = true,&lt;br /&gt;
	template = true,&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Pagetypes&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table produces the page types available with the ${PAGETYPE} parameter.&lt;br /&gt;
-- Keys are namespace numbers, or the string &amp;quot;default&amp;quot; for the default value.&lt;br /&gt;
pagetypes = {&lt;br /&gt;
	[0] = &#039;article&#039;,&lt;br /&gt;
	[6] = &#039;file&#039;,&lt;br /&gt;
	[10] = &#039;template&#039;,&lt;br /&gt;
	[14] = &#039;category&#039;,&lt;br /&gt;
	[828] = &#039;module&#039;,&lt;br /&gt;
	default = &#039;page&#039;&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Strings marking indefinite protection&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table contains values passed to the expiry parameter that mean the page&lt;br /&gt;
-- is protected indefinitely.&lt;br /&gt;
indefStrings = {&lt;br /&gt;
	[&#039;indef&#039;] = true,&lt;br /&gt;
	[&#039;indefinite&#039;] = true,&lt;br /&gt;
	[&#039;indefinitely&#039;] = true,&lt;br /&gt;
	[&#039;infinite&#039;] = true,&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Group hierarchy&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table maps each group to all groups that have a superset of the original&lt;br /&gt;
-- group&#039;s page editing permissions.&lt;br /&gt;
hierarchy = {&lt;br /&gt;
	sysop = {},&lt;br /&gt;
	reviewer = {&#039;sysop&#039;},&lt;br /&gt;
	filemover = {&#039;sysop&#039;},&lt;br /&gt;
	templateeditor = {&#039;sysop&#039;},&lt;br /&gt;
	autoconfirmed = {&#039;reviewer&#039;, &#039;filemover&#039;, &#039;templateeditor&#039;},&lt;br /&gt;
	user = {&#039;autoconfirmed&#039;},&lt;br /&gt;
	[&#039;*&#039;] = {&#039;user&#039;}&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Wrapper templates and their default arguments&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This table contains wrapper templates used with the module, and their&lt;br /&gt;
-- default arguments. Templates specified in this table should contain the&lt;br /&gt;
-- following invocation, and no other template content:&lt;br /&gt;
--&lt;br /&gt;
-- {{#invoke:Protection banner|main}}&lt;br /&gt;
--&lt;br /&gt;
-- If other content is desired, it can be added between&lt;br /&gt;
-- &amp;lt;noinclude&amp;gt;...&amp;lt;/noinclude&amp;gt; tags.&lt;br /&gt;
--&lt;br /&gt;
-- When a user calls one of these wrapper templates, they will use the&lt;br /&gt;
-- default arguments automatically. The arguments cannot be overwritten by the&lt;br /&gt;
-- user.&lt;br /&gt;
wrappers = {&lt;br /&gt;
	[&#039;Template:Pp&#039;]                         = {},&lt;br /&gt;
	[&#039;Template:Pp-blp&#039;]                     = {&#039;blp&#039;},&lt;br /&gt;
	-- we don&#039;t need Template:Pp-create&lt;br /&gt;
	[&#039;Template:Pp-dispute&#039;]                 = {&#039;dispute&#039;},&lt;br /&gt;
	[&#039;Template:Pp-main-page&#039;]                = {&#039;mainpage&#039;},&lt;br /&gt;
	[&#039;Template:Pp-move&#039;]                    = {action = &#039;move&#039;},&lt;br /&gt;
	[&#039;Template:Pp-move-dispute&#039;]            = {&#039;dispute&#039;, action = &#039;move&#039;},&lt;br /&gt;
	-- we don&#039;t need Template:Pp-move-indef&lt;br /&gt;
	[&#039;Template:Pp-move-vandalism&#039;]          = {&#039;vandalism&#039;, action = &#039;move&#039;},&lt;br /&gt;
	[&#039;Template:Pp-office&#039;]                  = {&#039;office&#039;},&lt;br /&gt;
	[&#039;Template:Pp-office-dmca&#039;]             = {&#039;dmca&#039;},&lt;br /&gt;
	[&#039;Template:Pp-pc1&#039;]                     = {action = &#039;autoreview&#039;, small = true},&lt;br /&gt;
	[&#039;Template:Pp-pc2&#039;]                     = {action = &#039;autoreview&#039;, small = true},&lt;br /&gt;
	[&#039;Template:Pp-reset&#039;]                   = {&#039;reset&#039;},&lt;br /&gt;
	[&#039;Template:Pp-semi-indef&#039;]              = {expiry = &#039;indef&#039;, small = true},&lt;br /&gt;
	[&#039;Template:Pp-sock&#039;]                    = {&#039;sock&#039;},&lt;br /&gt;
	[&#039;Template:Pp-template&#039;]                = {&#039;template&#039;, small = true},&lt;br /&gt;
	[&#039;Template:Pp-usertalk&#039;]                = {&#039;usertalk&#039;},&lt;br /&gt;
	[&#039;Template:Pp-vandalism&#039;]               = {&#039;vandalism&#039;},&lt;br /&gt;
},&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- &lt;br /&gt;
--                                 MESSAGES&lt;br /&gt;
-- &lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
msg = {&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Intro blurb and intro fragment&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- These messages specify what is produced by the ${INTROBLURB} and&lt;br /&gt;
-- ${INTROFRAGMENT} parameters. If the protection is temporary they use the&lt;br /&gt;
-- intro-blurb-expiry or intro-fragment-expiry, and if not they use&lt;br /&gt;
-- intro-blurb-noexpiry or intro-fragment-noexpiry.&lt;br /&gt;
-- It is possible to use banner parameters in these messages.&lt;br /&gt;
[&#039;intro-blurb-expiry&#039;] = &#039;${PROTECTIONBLURB} until ${EXPIRY}.&#039;,&lt;br /&gt;
[&#039;intro-blurb-noexpiry&#039;] = &#039;${PROTECTIONBLURB}.&#039;,&lt;br /&gt;
[&#039;intro-fragment-expiry&#039;] = &#039;${PROTECTIONBLURB} until ${EXPIRY},&#039;,&lt;br /&gt;
[&#039;intro-fragment-noexpiry&#039;] = &#039;${PROTECTIONBLURB}&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Tooltip blurb&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- These messages specify what is produced by the ${TOOLTIPBLURB} parameter.&lt;br /&gt;
-- If the protection is temporary the tooltip-blurb-expiry message is used, and&lt;br /&gt;
-- if not the tooltip-blurb-noexpiry message is used.&lt;br /&gt;
-- It is possible to use banner parameters in these messages.&lt;br /&gt;
[&#039;tooltip-blurb-expiry&#039;] = &#039;This ${PAGETYPE} is ${PROTECTIONLEVEL} until ${EXPIRY}.&#039;,&lt;br /&gt;
[&#039;tooltip-blurb-noexpiry&#039;] = &#039;This ${PAGETYPE} is ${PROTECTIONLEVEL}.&#039;,&lt;br /&gt;
[&#039;tooltip-fragment-expiry&#039;] = &#039;This ${PAGETYPE} is ${PROTECTIONLEVEL} until ${EXPIRY},&#039;,&lt;br /&gt;
[&#039;tooltip-fragment-noexpiry&#039;] = &#039;This ${PAGETYPE} is ${PROTECTIONLEVEL}&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Special explanation blurb&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- An explanation blurb for pages that cannot be unprotected, e.g. for pages&lt;br /&gt;
-- in the MediaWiki namespace.&lt;br /&gt;
-- It is possible to use banner parameters in this message.&lt;br /&gt;
[&#039;explanation-blurb-nounprotect&#039;] = &#039;See the [[Wikipedia:Protection policy|&#039;&lt;br /&gt;
	.. &#039;protection policy]] and ${PROTECTIONLOG} for more details.&#039;&lt;br /&gt;
	.. &#039; Please discuss any changes on the ${TALKPAGE}; you&#039;&lt;br /&gt;
	.. &#039; may ${EDITREQUEST} to ask an&#039;&lt;br /&gt;
	.. &#039; [[Wikipedia:Administrators|administrator]] to make an edit if it&#039;&lt;br /&gt;
	.. &#039; is [[Help:Minor edit#When to mark an edit as a minor edit&#039;&lt;br /&gt;
	.. &#039;|uncontroversial]] or supported by [[Wikipedia:Consensus&#039;&lt;br /&gt;
	.. &#039;|consensus]].&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Protection log display values&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- These messages determine the display values for the protection log link&lt;br /&gt;
-- or the pending changes log link produced by the ${PROTECTIONLOG} parameter.&lt;br /&gt;
-- It is possible to use banner parameters in these messages.&lt;br /&gt;
[&#039;protection-log-display&#039;] = &#039;protection log&#039;,&lt;br /&gt;
[&#039;pc-log-display&#039;] = &#039;pending changes log&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Current version display values&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- These messages determine the display values for the page history link&lt;br /&gt;
-- or the move log link produced by the ${CURRENTVERSION} parameter.&lt;br /&gt;
-- It is possible to use banner parameters in these messages.&lt;br /&gt;
[&#039;current-version-move-display&#039;] = &#039;current title&#039;,&lt;br /&gt;
[&#039;current-version-edit-display&#039;] = &#039;current version&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Talk page&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This message determines the display value of the talk page link produced&lt;br /&gt;
-- with the ${TALKPAGE} parameter.&lt;br /&gt;
-- It is possible to use banner parameters in this message.&lt;br /&gt;
[&#039;talk-page-link-display&#039;] = &#039;talk page&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Edit requests&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This message determines the display value of the edit request link produced&lt;br /&gt;
-- with the ${EDITREQUEST} parameter.&lt;br /&gt;
-- It is possible to use banner parameters in this message.&lt;br /&gt;
[&#039;edit-request-display&#039;] = &#039;submit an edit request&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Expiry date format&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- This is the format for the blurb expiry date. It should be valid input for&lt;br /&gt;
-- the first parameter of the #time parser function.&lt;br /&gt;
[&#039;expiry-date-format&#039;] = &#039;F j, Y&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Tracking categories&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- These messages determine which tracking categories the module outputs.&lt;br /&gt;
[&#039;tracking-category-incorrect&#039;] = &#039;Wikipedia pages with incorrect protection templates&#039;,&lt;br /&gt;
[&#039;tracking-category-expiry&#039;] = &#039;Wikipedia protected pages without expiry&#039;,&lt;br /&gt;
[&#039;tracking-category-template&#039;] = &#039;Wikipedia template-protected pages other than templates and modules&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Images&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- These are images that are not defined by their protection action and protection level.&lt;br /&gt;
[&#039;image-filename-indef&#039;] = &#039;Padlock-red.svg&#039;,&lt;br /&gt;
[&#039;image-filename-default&#039;] = &#039;Transparent.gif&#039;,&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- End messages&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- End configuration&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Protection_banner&amp;diff=2424</id>
		<title>Module:Protection banner</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Protection_banner&amp;diff=2424"/>
		<updated>2015-07-09T17:07:25Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module implements {{pp-meta}} and its daughter templates such as&lt;br /&gt;
-- {{pp-dispute}}, {{pp-vandalism}} and {{pp-sock}}.&lt;br /&gt;
&lt;br /&gt;
-- Initialise necessary modules.&lt;br /&gt;
require(&#039;Module:No globals&#039;)&lt;br /&gt;
local makeFileLink = require(&#039;Module:File link&#039;)._main&lt;br /&gt;
local effectiveProtectionLevel = require(&#039;Module:Effective protection level&#039;)._main&lt;br /&gt;
local yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
&lt;br /&gt;
-- Lazily initialise modules and objects we don&#039;t always need.&lt;br /&gt;
local getArgs, makeMessageBox, lang&lt;br /&gt;
&lt;br /&gt;
-- Set constants.&lt;br /&gt;
local CONFIG_MODULE = &#039;Module:Protection banner/config&#039;&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Helper functions&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local function makeCategoryLink(cat, sort)&lt;br /&gt;
	local nsText = mw.site.namespaces[14].name&lt;br /&gt;
	if cat and sort then&lt;br /&gt;
		return string.format(&lt;br /&gt;
			&#039;[[%s:%s|%s]]&#039;,&lt;br /&gt;
			nsText,&lt;br /&gt;
			cat,&lt;br /&gt;
			sort&lt;br /&gt;
		)&lt;br /&gt;
	elseif cat then&lt;br /&gt;
		return string.format(&lt;br /&gt;
			&#039;[[%s:%s]]&#039;,&lt;br /&gt;
			nsText,&lt;br /&gt;
			cat&lt;br /&gt;
		)&lt;br /&gt;
	else&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Validation function for the expiry and the protection date&lt;br /&gt;
local function validateDate(dateString, dateType)&lt;br /&gt;
	lang = lang or mw.language.getContentLanguage()&lt;br /&gt;
	local success, result = pcall(lang.formatDate, lang, &#039;U&#039;, dateString)&lt;br /&gt;
	if success then&lt;br /&gt;
		result = tonumber(result)&lt;br /&gt;
		if result then&lt;br /&gt;
			return result&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	error(string.format(&lt;br /&gt;
		&#039;invalid %s (&amp;quot;%s&amp;quot;)&#039;,&lt;br /&gt;
		dateType,&lt;br /&gt;
		tostring(dateString)&lt;br /&gt;
	), 4)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function makeFullUrl(page, query, display)&lt;br /&gt;
	return string.format(&lt;br /&gt;
		&#039;[%s %s]&#039;,&lt;br /&gt;
		tostring(mw.uri.fullUrl(page, query)),&lt;br /&gt;
		display&lt;br /&gt;
	)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function toTableEnd(t, pos)&lt;br /&gt;
	-- Sends the value at position pos to the end of array t, and shifts the&lt;br /&gt;
	-- other items down accordingly.&lt;br /&gt;
	return table.insert(t, table.remove(t, pos))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function walkHierarchy(hierarchy, start)&lt;br /&gt;
	local toWalk, retval = {[start] = true}, {}&lt;br /&gt;
	while true do&lt;br /&gt;
		-- Can&#039;t use pairs() since we&#039;re adding and removing things as we&#039;re iterating&lt;br /&gt;
		local k = next(toWalk)&lt;br /&gt;
		if k == nil then break end&lt;br /&gt;
		toWalk[k] = nil&lt;br /&gt;
		retval[k] = true&lt;br /&gt;
		for _,v in ipairs(hierarchy[k]) do&lt;br /&gt;
			if not retval[v] then&lt;br /&gt;
				toWalk[v] = true&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return retval&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Protection class&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local Protection = {}&lt;br /&gt;
Protection.__index = Protection&lt;br /&gt;
&lt;br /&gt;
Protection.supportedActions = {&lt;br /&gt;
	edit = true,&lt;br /&gt;
	move = true,&lt;br /&gt;
	autoreview = true&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
Protection.bannerConfigFields = {&lt;br /&gt;
	&#039;text&#039;,&lt;br /&gt;
	&#039;explanation&#039;,&lt;br /&gt;
	&#039;tooltip&#039;,&lt;br /&gt;
	&#039;alt&#039;,&lt;br /&gt;
	&#039;link&#039;,&lt;br /&gt;
	&#039;image&#039;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
function Protection.new(args, cfg, title)&lt;br /&gt;
	local obj = {}&lt;br /&gt;
	obj._cfg = cfg&lt;br /&gt;
	obj.title = title or mw.title.getCurrentTitle()&lt;br /&gt;
&lt;br /&gt;
	-- Set action&lt;br /&gt;
	if not args.action then&lt;br /&gt;
		obj.action = &#039;edit&#039;&lt;br /&gt;
	elseif Protection.supportedActions[args.action] then&lt;br /&gt;
		obj.action = args.action&lt;br /&gt;
	else&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&#039;invalid action (&amp;quot;%s&amp;quot;)&#039;,&lt;br /&gt;
			tostring(args.action)&lt;br /&gt;
		), 3)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Set level&lt;br /&gt;
	obj.level = args.demolevel or effectiveProtectionLevel(obj.action, obj.title)&lt;br /&gt;
	if not obj.level or (obj.action == &#039;move&#039; and obj.level == &#039;autoconfirmed&#039;) then&lt;br /&gt;
		-- Users need to be autoconfirmed to move pages anyway, so treat&lt;br /&gt;
		-- semi-move-protected pages as unprotected.&lt;br /&gt;
		obj.level = &#039;*&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Set expiry&lt;br /&gt;
	if args.expiry then&lt;br /&gt;
		if cfg.indefStrings[args.expiry] then&lt;br /&gt;
			obj.expiry = &#039;indef&#039;&lt;br /&gt;
		elseif type(args.expiry) == &#039;number&#039; then&lt;br /&gt;
			obj.expiry = args.expiry&lt;br /&gt;
		else&lt;br /&gt;
			obj.expiry = validateDate(args.expiry, &#039;expiry date&#039;)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Set reason&lt;br /&gt;
	if args[1] then&lt;br /&gt;
		obj.reason = mw.ustring.lower(args[1])&lt;br /&gt;
		if obj.reason:find(&#039;|&#039;) then&lt;br /&gt;
			error(&#039;reasons cannot contain the pipe character (&amp;quot;|&amp;quot;)&#039;, 3)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Set protection date&lt;br /&gt;
	if args.date then&lt;br /&gt;
		obj.protectionDate = validateDate(args.date, &#039;protection date&#039;)&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Set banner config&lt;br /&gt;
	do&lt;br /&gt;
		obj.bannerConfig = {}&lt;br /&gt;
		local configTables = {}&lt;br /&gt;
		if cfg.banners[obj.action] then&lt;br /&gt;
			configTables[#configTables + 1] = cfg.banners[obj.action][obj.reason]&lt;br /&gt;
		end&lt;br /&gt;
		if cfg.defaultBanners[obj.action] then&lt;br /&gt;
			configTables[#configTables + 1] = cfg.defaultBanners[obj.action][obj.level]&lt;br /&gt;
			configTables[#configTables + 1] = cfg.defaultBanners[obj.action].default&lt;br /&gt;
		end&lt;br /&gt;
		configTables[#configTables + 1] = cfg.masterBanner&lt;br /&gt;
		for i, field in ipairs(Protection.bannerConfigFields) do&lt;br /&gt;
			for j, t in ipairs(configTables) do&lt;br /&gt;
				if t[field] then&lt;br /&gt;
					obj.bannerConfig[field] = t[field]&lt;br /&gt;
					break&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return setmetatable(obj, Protection)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Protection:isProtected()&lt;br /&gt;
	return self.level ~= &#039;*&#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Protection:isTemporary()&lt;br /&gt;
	return type(self.expiry) == &#039;number&#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Protection:makeProtectionCategory()&lt;br /&gt;
	local cfg = self._cfg&lt;br /&gt;
	local title = self.title&lt;br /&gt;
	&lt;br /&gt;
	-- Exit if the page is not protected.&lt;br /&gt;
	if not self:isProtected() then&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Get the expiry key fragment.&lt;br /&gt;
	local expiryFragment&lt;br /&gt;
	if self.expiry == &#039;indef&#039; then&lt;br /&gt;
		expiryFragment = self.expiry&lt;br /&gt;
	elseif type(self.expiry) == &#039;number&#039; then&lt;br /&gt;
		expiryFragment = &#039;temp&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Get the namespace key fragment.&lt;br /&gt;
	local namespaceFragment&lt;br /&gt;
	do&lt;br /&gt;
		namespaceFragment = cfg.categoryNamespaceKeys[title.namespace]&lt;br /&gt;
		if not namespaceFragment and title.namespace % 2 == 1 then&lt;br /&gt;
				namespaceFragment = &#039;talk&#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
 &lt;br /&gt;
	-- Define the order that key fragments are tested in. This is done with an&lt;br /&gt;
	-- array of tables containing the value to be tested, along with its&lt;br /&gt;
	-- position in the cfg.protectionCategories table.&lt;br /&gt;
	local order = {&lt;br /&gt;
		{val = expiryFragment,    keypos = 1},&lt;br /&gt;
		{val = namespaceFragment, keypos = 2},&lt;br /&gt;
		{val = self.reason,       keypos = 3},&lt;br /&gt;
		{val = self.level,        keypos = 4},&lt;br /&gt;
		{val = self.action,       keypos = 5}&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
	--[[&lt;br /&gt;
	-- The old protection templates used an ad-hoc protection category system,&lt;br /&gt;
	-- with some templates prioritising namespaces in their categories, and&lt;br /&gt;
	-- others prioritising the protection reason. To emulate this in this module&lt;br /&gt;
	-- we use the config table cfg.reasonsWithNamespacePriority to set the&lt;br /&gt;
	-- reasons for which namespaces have priority over protection reason.&lt;br /&gt;
	-- If we are dealing with one of those reasons, move the namespace table to&lt;br /&gt;
	-- the end of the order table, i.e. give it highest priority. If not, the&lt;br /&gt;
	-- reason should have highest priority, so move that to the end of the table&lt;br /&gt;
	-- instead.&lt;br /&gt;
	--]]&lt;br /&gt;
	if self.reason and cfg.reasonsWithNamespacePriority[self.reason] then&lt;br /&gt;
		-- table.insert(order, 3, table.remove(order, 2))&lt;br /&gt;
		toTableEnd(order, 2)&lt;br /&gt;
	else&lt;br /&gt;
		toTableEnd(order, 3)&lt;br /&gt;
	end&lt;br /&gt;
 &lt;br /&gt;
	--[[&lt;br /&gt;
	-- Define the attempt order. Inactive subtables (subtables with nil &amp;quot;value&amp;quot;&lt;br /&gt;
	-- fields) are moved to the end, where they will later be given the key&lt;br /&gt;
	-- &amp;quot;all&amp;quot;. This is to cut down on the number of table lookups in&lt;br /&gt;
	-- cfg.protectionCategories, which grows exponentially with the number of&lt;br /&gt;
	-- non-nil keys. We keep track of the number of active subtables with the&lt;br /&gt;
	-- noActive parameter.&lt;br /&gt;
	--]]&lt;br /&gt;
	local noActive, attemptOrder&lt;br /&gt;
	do&lt;br /&gt;
		local active, inactive = {}, {}&lt;br /&gt;
		for i, t in ipairs(order) do&lt;br /&gt;
			if t.val then&lt;br /&gt;
				active[#active + 1] = t&lt;br /&gt;
			else&lt;br /&gt;
				inactive[#inactive + 1] = t&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		noActive = #active&lt;br /&gt;
		attemptOrder = active&lt;br /&gt;
		for i, t in ipairs(inactive) do&lt;br /&gt;
			attemptOrder[#attemptOrder + 1] = t&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
 &lt;br /&gt;
	--[[&lt;br /&gt;
	-- Check increasingly generic key combinations until we find a match. If a&lt;br /&gt;
	-- specific category exists for the combination of key fragments we are&lt;br /&gt;
	-- given, that match will be found first. If not, we keep trying different&lt;br /&gt;
	-- key fragment combinations until we match using the key&lt;br /&gt;
	-- &amp;quot;all-all-all-all-all&amp;quot;.&lt;br /&gt;
	--&lt;br /&gt;
	-- To generate the keys, we index the key subtables using a binary matrix&lt;br /&gt;
	-- with indexes i and j. j is only calculated up to the number of active&lt;br /&gt;
	-- subtables. For example, if there were three active subtables, the matrix&lt;br /&gt;
	-- would look like this, with 0 corresponding to the key fragment &amp;quot;all&amp;quot;, and&lt;br /&gt;
	-- 1 corresponding to other key fragments.&lt;br /&gt;
	-- &lt;br /&gt;
	--   j 1  2  3&lt;br /&gt;
	-- i  &lt;br /&gt;
	-- 1   1  1  1&lt;br /&gt;
	-- 2   0  1  1&lt;br /&gt;
	-- 3   1  0  1&lt;br /&gt;
	-- 4   0  0  1&lt;br /&gt;
	-- 5   1  1  0&lt;br /&gt;
	-- 6   0  1  0&lt;br /&gt;
	-- 7   1  0  0&lt;br /&gt;
	-- 8   0  0  0&lt;br /&gt;
	-- &lt;br /&gt;
	-- Values of j higher than the number of active subtables are set&lt;br /&gt;
	-- to the string &amp;quot;all&amp;quot;.&lt;br /&gt;
	--&lt;br /&gt;
	-- A key for cfg.protectionCategories is constructed for each value of i.&lt;br /&gt;
	-- The position of the value in the key is determined by the keypos field in&lt;br /&gt;
	-- each subtable.&lt;br /&gt;
	--]]&lt;br /&gt;
	local cats = cfg.protectionCategories&lt;br /&gt;
	for i = 1, 2^noActive do&lt;br /&gt;
		local key = {}&lt;br /&gt;
		for j, t in ipairs(attemptOrder) do&lt;br /&gt;
			if j &amp;gt; noActive then&lt;br /&gt;
				key[t.keypos] = &#039;all&#039;&lt;br /&gt;
			else&lt;br /&gt;
				local quotient = i / 2 ^ (j - 1)&lt;br /&gt;
				quotient = math.ceil(quotient)&lt;br /&gt;
				if quotient % 2 == 1 then&lt;br /&gt;
					key[t.keypos] = t.val&lt;br /&gt;
				else&lt;br /&gt;
					key[t.keypos] = &#039;all&#039;&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		key = table.concat(key, &#039;|&#039;)&lt;br /&gt;
		local attempt = cats[key]&lt;br /&gt;
		if attempt then&lt;br /&gt;
			return makeCategoryLink(attempt, title.text)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return &#039;&#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Protection:needsExpiry()&lt;br /&gt;
	local cfg = self._cfg&lt;br /&gt;
	local actionNeedsCheck = cfg.expiryCheckActions[self.action]&lt;br /&gt;
	return not self.expiry and (&lt;br /&gt;
		actionNeedsCheck or (&lt;br /&gt;
			actionNeedsCheck == nil&lt;br /&gt;
			and self.reason -- the old {{pp-protected}} didn&#039;t check for expiry&lt;br /&gt;
			and not cfg.reasonsWithoutExpiryCheck[self.reason]&lt;br /&gt;
		)&lt;br /&gt;
	)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Protection:isIncorrect()&lt;br /&gt;
	local expiry = self.expiry&lt;br /&gt;
	return not self:isProtected()&lt;br /&gt;
		or type(expiry) == &#039;number&#039; and expiry &amp;lt; os.time()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Protection:isTemplateProtectedNonTemplate()&lt;br /&gt;
	local action, namespace = self.action, self.title.namespace&lt;br /&gt;
	return self.level == &#039;templateeditor&#039;&lt;br /&gt;
		and (&lt;br /&gt;
			(action ~= &#039;edit&#039; and action ~= &#039;move&#039;)&lt;br /&gt;
			or (namespace ~= 10 and namespace ~= 828)&lt;br /&gt;
		)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Protection:makeCategoryLinks()&lt;br /&gt;
	local msg = self._cfg.msg&lt;br /&gt;
	local ret = { self:makeProtectionCategory() }&lt;br /&gt;
	if self:needsExpiry() then&lt;br /&gt;
		ret[#ret + 1] = makeCategoryLink(&lt;br /&gt;
			msg[&#039;tracking-category-expiry&#039;],&lt;br /&gt;
			self.title.text&lt;br /&gt;
		)&lt;br /&gt;
	end&lt;br /&gt;
	if self:isIncorrect() then&lt;br /&gt;
		ret[#ret + 1] = makeCategoryLink(&lt;br /&gt;
			msg[&#039;tracking-category-incorrect&#039;],&lt;br /&gt;
			self.title.text&lt;br /&gt;
		)&lt;br /&gt;
	end&lt;br /&gt;
	if self:isTemplateProtectedNonTemplate() then&lt;br /&gt;
		ret[#ret + 1] = makeCategoryLink(&lt;br /&gt;
			msg[&#039;tracking-category-template&#039;],&lt;br /&gt;
			self.title.text&lt;br /&gt;
		)&lt;br /&gt;
	end&lt;br /&gt;
	return table.concat(ret)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Blurb class&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local Blurb = {}&lt;br /&gt;
Blurb.__index = Blurb&lt;br /&gt;
&lt;br /&gt;
Blurb.bannerTextFields = {&lt;br /&gt;
	text = true,&lt;br /&gt;
	explanation = true,&lt;br /&gt;
	tooltip = true,&lt;br /&gt;
	alt = true,&lt;br /&gt;
	link = true&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
function Blurb.new(protectionObj, args, cfg)&lt;br /&gt;
	return setmetatable({&lt;br /&gt;
		_cfg = cfg,&lt;br /&gt;
		_protectionObj = protectionObj,&lt;br /&gt;
		_args = args&lt;br /&gt;
	}, Blurb)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Private methods --&lt;br /&gt;
&lt;br /&gt;
function Blurb:_formatDate(num)&lt;br /&gt;
	-- Formats a Unix timestamp into dd Month, YYYY format.&lt;br /&gt;
	lang = lang or mw.language.getContentLanguage()&lt;br /&gt;
	local success, date = pcall(&lt;br /&gt;
		lang.formatDate,&lt;br /&gt;
		lang,&lt;br /&gt;
		self._cfg.msg[&#039;expiry-date-format&#039;] or &#039;j F Y&#039;,&lt;br /&gt;
		&#039;@&#039; .. tostring(num)&lt;br /&gt;
	)&lt;br /&gt;
	if success then&lt;br /&gt;
		return date&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_getExpandedMessage(msgKey)&lt;br /&gt;
	return self:_substituteParameters(self._cfg.msg[msgKey])&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_substituteParameters(msg)&lt;br /&gt;
	if not self._params then&lt;br /&gt;
		local parameterFuncs = {}&lt;br /&gt;
&lt;br /&gt;
		parameterFuncs.CURRENTVERSION     = self._makeCurrentVersionParameter&lt;br /&gt;
		parameterFuncs.EDITREQUEST        = self._makeEditRequestParameter&lt;br /&gt;
		parameterFuncs.EXPIRY             = self._makeExpiryParameter&lt;br /&gt;
		parameterFuncs.EXPLANATIONBLURB   = self._makeExplanationBlurbParameter&lt;br /&gt;
		parameterFuncs.IMAGELINK          = self._makeImageLinkParameter&lt;br /&gt;
		parameterFuncs.INTROBLURB         = self._makeIntroBlurbParameter&lt;br /&gt;
		parameterFuncs.INTROFRAGMENT      = self._makeIntroFragmentParameter&lt;br /&gt;
		parameterFuncs.PAGETYPE           = self._makePagetypeParameter&lt;br /&gt;
		parameterFuncs.PROTECTIONBLURB    = self._makeProtectionBlurbParameter&lt;br /&gt;
		parameterFuncs.PROTECTIONDATE     = self._makeProtectionDateParameter&lt;br /&gt;
		parameterFuncs.PROTECTIONLEVEL    = self._makeProtectionLevelParameter&lt;br /&gt;
		parameterFuncs.PROTECTIONLOG      = self._makeProtectionLogParameter&lt;br /&gt;
		parameterFuncs.TALKPAGE           = self._makeTalkPageParameter&lt;br /&gt;
		parameterFuncs.TOOLTIPBLURB       = self._makeTooltipBlurbParameter&lt;br /&gt;
		parameterFuncs.TOOLTIPFRAGMENT    = self._makeTooltipFragmentParameter&lt;br /&gt;
		parameterFuncs.VANDAL             = self._makeVandalTemplateParameter&lt;br /&gt;
		&lt;br /&gt;
		self._params = setmetatable({}, {&lt;br /&gt;
			__index = function (t, k)&lt;br /&gt;
				local param&lt;br /&gt;
				if parameterFuncs[k] then&lt;br /&gt;
					param = parameterFuncs[k](self)&lt;br /&gt;
				end&lt;br /&gt;
				param = param or &#039;&#039;&lt;br /&gt;
				t[k] = param&lt;br /&gt;
				return param&lt;br /&gt;
			end&lt;br /&gt;
		})&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	msg = msg:gsub(&#039;${(%u+)}&#039;, self._params)&lt;br /&gt;
	return msg&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeCurrentVersionParameter()&lt;br /&gt;
	-- A link to the page history or the move log, depending on the kind of&lt;br /&gt;
	-- protection.&lt;br /&gt;
	local pagename = self._protectionObj.title.prefixedText&lt;br /&gt;
	if self._protectionObj.action == &#039;move&#039; then&lt;br /&gt;
		-- We need the move log link.&lt;br /&gt;
		return makeFullUrl(&lt;br /&gt;
			&#039;Special:Log&#039;,&lt;br /&gt;
			{type = &#039;move&#039;, page = pagename},&lt;br /&gt;
			self:_getExpandedMessage(&#039;current-version-move-display&#039;)&lt;br /&gt;
		)&lt;br /&gt;
	else&lt;br /&gt;
		-- We need the history link.&lt;br /&gt;
		return makeFullUrl(&lt;br /&gt;
			pagename,&lt;br /&gt;
			{action = &#039;history&#039;},&lt;br /&gt;
			self:_getExpandedMessage(&#039;current-version-edit-display&#039;)&lt;br /&gt;
		)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeEditRequestParameter()&lt;br /&gt;
	local mEditRequest = require(&#039;Module:Submit an edit request&#039;)&lt;br /&gt;
	local action = self._protectionObj.action&lt;br /&gt;
	local level = self._protectionObj.level&lt;br /&gt;
	&lt;br /&gt;
	-- Get the edit request type.&lt;br /&gt;
	local requestType&lt;br /&gt;
	if action == &#039;edit&#039; then&lt;br /&gt;
		if level == &#039;autoconfirmed&#039; then&lt;br /&gt;
			requestType = &#039;semi&#039;&lt;br /&gt;
		elseif level == &#039;templateeditor&#039; then&lt;br /&gt;
			requestType = &#039;template&#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	requestType = requestType or &#039;full&#039;&lt;br /&gt;
	&lt;br /&gt;
	-- Get the display value.&lt;br /&gt;
	local display = self:_getExpandedMessage(&#039;edit-request-display&#039;)&lt;br /&gt;
&lt;br /&gt;
	return mEditRequest._link{type = requestType, display = display}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeExpiryParameter()&lt;br /&gt;
	local expiry = self._protectionObj.expiry&lt;br /&gt;
	if type(expiry) == &#039;number&#039; then&lt;br /&gt;
		return self:_formatDate(expiry)&lt;br /&gt;
	else&lt;br /&gt;
		return expiry&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeExplanationBlurbParameter()&lt;br /&gt;
	-- Cover special cases first.&lt;br /&gt;
	if self._protectionObj.title.namespace == 8 then&lt;br /&gt;
		-- MediaWiki namespace&lt;br /&gt;
		return self:_getExpandedMessage(&#039;explanation-blurb-nounprotect&#039;)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Get explanation blurb table keys&lt;br /&gt;
	local action = self._protectionObj.action&lt;br /&gt;
	local level = self._protectionObj.level&lt;br /&gt;
	local talkKey = self._protectionObj.title.isTalkPage and &#039;talk&#039; or &#039;subject&#039;&lt;br /&gt;
&lt;br /&gt;
	-- Find the message in the explanation blurb table and substitute any&lt;br /&gt;
	-- parameters.&lt;br /&gt;
	local explanations = self._cfg.explanationBlurbs&lt;br /&gt;
	local msg&lt;br /&gt;
	if explanations[action][level] and explanations[action][level][talkKey] then&lt;br /&gt;
		msg = explanations[action][level][talkKey]&lt;br /&gt;
	elseif explanations[action][level] and explanations[action][level].default then&lt;br /&gt;
		msg = explanations[action][level].default&lt;br /&gt;
	elseif explanations[action].default and explanations[action].default[talkKey] then&lt;br /&gt;
		msg = explanations[action].default[talkKey]&lt;br /&gt;
	elseif explanations[action].default and explanations[action].default.default then&lt;br /&gt;
		msg = explanations[action].default.default&lt;br /&gt;
	else&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&#039;could not find explanation blurb for action &amp;quot;%s&amp;quot;, level &amp;quot;%s&amp;quot; and talk key &amp;quot;%s&amp;quot;&#039;,&lt;br /&gt;
			action,&lt;br /&gt;
			level,&lt;br /&gt;
			talkKey&lt;br /&gt;
		), 8)&lt;br /&gt;
	end&lt;br /&gt;
	return self:_substituteParameters(msg)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeImageLinkParameter()&lt;br /&gt;
	local imageLinks = self._cfg.imageLinks&lt;br /&gt;
	local action = self._protectionObj.action&lt;br /&gt;
	local level = self._protectionObj.level&lt;br /&gt;
	local msg&lt;br /&gt;
	if imageLinks[action][level] then&lt;br /&gt;
		msg = imageLinks[action][level]&lt;br /&gt;
	elseif imageLinks[action].default then&lt;br /&gt;
		msg = imageLinks[action].default&lt;br /&gt;
	else&lt;br /&gt;
		msg = imageLinks.edit.default&lt;br /&gt;
	end&lt;br /&gt;
	return self:_substituteParameters(msg)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeIntroBlurbParameter()&lt;br /&gt;
	if self._protectionObj:isTemporary() then&lt;br /&gt;
		return self:_getExpandedMessage(&#039;intro-blurb-expiry&#039;)&lt;br /&gt;
	else&lt;br /&gt;
		return self:_getExpandedMessage(&#039;intro-blurb-noexpiry&#039;)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeIntroFragmentParameter()&lt;br /&gt;
	if self._protectionObj:isTemporary() then&lt;br /&gt;
		return self:_getExpandedMessage(&#039;intro-fragment-expiry&#039;)&lt;br /&gt;
	else&lt;br /&gt;
		return self:_getExpandedMessage(&#039;intro-fragment-noexpiry&#039;)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makePagetypeParameter()&lt;br /&gt;
	local pagetypes = self._cfg.pagetypes&lt;br /&gt;
	return pagetypes[self._protectionObj.title.namespace]&lt;br /&gt;
		or pagetypes.default&lt;br /&gt;
		or error(&#039;no default pagetype defined&#039;, 8)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeProtectionBlurbParameter()&lt;br /&gt;
	local protectionBlurbs = self._cfg.protectionBlurbs&lt;br /&gt;
	local action = self._protectionObj.action&lt;br /&gt;
	local level = self._protectionObj.level&lt;br /&gt;
	local msg&lt;br /&gt;
	if protectionBlurbs[action][level] then&lt;br /&gt;
		msg = protectionBlurbs[action][level]&lt;br /&gt;
	elseif protectionBlurbs[action].default then&lt;br /&gt;
		msg = protectionBlurbs[action].default&lt;br /&gt;
	elseif protectionBlurbs.edit.default then&lt;br /&gt;
		msg = protectionBlurbs.edit.default&lt;br /&gt;
	else&lt;br /&gt;
		error(&#039;no protection blurb defined for protectionBlurbs.edit.default&#039;, 8)&lt;br /&gt;
	end&lt;br /&gt;
	return self:_substituteParameters(msg)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeProtectionDateParameter()&lt;br /&gt;
	local protectionDate = self._protectionObj.protectionDate&lt;br /&gt;
	if type(protectionDate) == &#039;number&#039; then&lt;br /&gt;
		return self:_formatDate(protectionDate)&lt;br /&gt;
	else&lt;br /&gt;
		return protectionDate&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeProtectionLevelParameter()&lt;br /&gt;
	local protectionLevels = self._cfg.protectionLevels&lt;br /&gt;
	local action = self._protectionObj.action&lt;br /&gt;
	local level = self._protectionObj.level&lt;br /&gt;
	local msg&lt;br /&gt;
	if protectionLevels[action][level] then&lt;br /&gt;
		msg = protectionLevels[action][level]&lt;br /&gt;
	elseif protectionLevels[action].default then&lt;br /&gt;
		msg = protectionLevels[action].default&lt;br /&gt;
	elseif protectionLevels.edit.default then&lt;br /&gt;
		msg = protectionLevels.edit.default&lt;br /&gt;
	else&lt;br /&gt;
		error(&#039;no protection level defined for protectionLevels.edit.default&#039;, 8)&lt;br /&gt;
	end&lt;br /&gt;
	return self:_substituteParameters(msg)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeProtectionLogParameter()&lt;br /&gt;
	local pagename = self._protectionObj.title.prefixedText&lt;br /&gt;
	if self._protectionObj.action == &#039;autoreview&#039; then&lt;br /&gt;
		-- We need the pending changes log.&lt;br /&gt;
		return makeFullUrl(&lt;br /&gt;
			&#039;Special:Log&#039;,&lt;br /&gt;
			{type = &#039;stable&#039;, page = pagename},&lt;br /&gt;
			self:_getExpandedMessage(&#039;pc-log-display&#039;)&lt;br /&gt;
		)&lt;br /&gt;
	else&lt;br /&gt;
		-- We need the protection log.&lt;br /&gt;
		return makeFullUrl(&lt;br /&gt;
			&#039;Special:Log&#039;,&lt;br /&gt;
			{type = &#039;protect&#039;, page = pagename},&lt;br /&gt;
			self:_getExpandedMessage(&#039;protection-log-display&#039;)&lt;br /&gt;
		)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeTalkPageParameter()&lt;br /&gt;
	return string.format(&lt;br /&gt;
		&#039;[[%s:%s#%s|%s]]&#039;,&lt;br /&gt;
		mw.site.namespaces[self._protectionObj.title.namespace].talk.name,&lt;br /&gt;
		self._protectionObj.title.text,&lt;br /&gt;
		self._args.section or &#039;top&#039;,&lt;br /&gt;
		self:_getExpandedMessage(&#039;talk-page-link-display&#039;)&lt;br /&gt;
	)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeTooltipBlurbParameter()&lt;br /&gt;
	if self._protectionObj:isTemporary() then&lt;br /&gt;
		return self:_getExpandedMessage(&#039;tooltip-blurb-expiry&#039;)&lt;br /&gt;
	else&lt;br /&gt;
		return self:_getExpandedMessage(&#039;tooltip-blurb-noexpiry&#039;)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeTooltipFragmentParameter()&lt;br /&gt;
	if self._protectionObj:isTemporary() then&lt;br /&gt;
		return self:_getExpandedMessage(&#039;tooltip-fragment-expiry&#039;)&lt;br /&gt;
	else&lt;br /&gt;
		return self:_getExpandedMessage(&#039;tooltip-fragment-noexpiry&#039;)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Blurb:_makeVandalTemplateParameter()&lt;br /&gt;
	return require(&#039;Module:Vandal-m&#039;)._main{&lt;br /&gt;
		self._args.user or self._protectionObj.title.baseText&lt;br /&gt;
	}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Public methods --&lt;br /&gt;
&lt;br /&gt;
function Blurb:makeBannerText(key)&lt;br /&gt;
	-- Validate input.&lt;br /&gt;
	if not key or not Blurb.bannerTextFields[key] then&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&#039;&amp;quot;%s&amp;quot; is not a valid banner config field&#039;,&lt;br /&gt;
			tostring(key)&lt;br /&gt;
		), 2)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Generate the text.&lt;br /&gt;
	local msg = self._protectionObj.bannerConfig[key]&lt;br /&gt;
	if type(msg) == &#039;string&#039; then&lt;br /&gt;
		return self:_substituteParameters(msg)&lt;br /&gt;
	elseif type(msg) == &#039;function&#039; then&lt;br /&gt;
		msg = msg(self._protectionObj, self._args)&lt;br /&gt;
		if type(msg) ~= &#039;string&#039; then&lt;br /&gt;
			error(string.format(&lt;br /&gt;
				&#039;bad output from banner config function with key &amp;quot;%s&amp;quot;&#039;&lt;br /&gt;
					.. &#039; (expected string, got %s)&#039;,&lt;br /&gt;
				tostring(key),&lt;br /&gt;
				type(msg)&lt;br /&gt;
			), 4)&lt;br /&gt;
		end&lt;br /&gt;
		return self:_substituteParameters(msg)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- BannerTemplate class&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local BannerTemplate = {}&lt;br /&gt;
BannerTemplate.__index = BannerTemplate&lt;br /&gt;
&lt;br /&gt;
function BannerTemplate.new(protectionObj, cfg)&lt;br /&gt;
	local obj = {}&lt;br /&gt;
	obj._cfg = cfg&lt;br /&gt;
&lt;br /&gt;
	-- Set the image filename.&lt;br /&gt;
	local imageFilename = protectionObj.bannerConfig.image&lt;br /&gt;
	if imageFilename then&lt;br /&gt;
		obj._imageFilename = imageFilename&lt;br /&gt;
	else&lt;br /&gt;
		-- If an image filename isn&#039;t specified explicitly in the banner config,&lt;br /&gt;
		-- generate it from the protection status and the namespace.&lt;br /&gt;
		local action = protectionObj.action&lt;br /&gt;
		local level = protectionObj.level&lt;br /&gt;
		local namespace = protectionObj.title.namespace&lt;br /&gt;
		local reason = protectionObj.reason&lt;br /&gt;
		&lt;br /&gt;
		-- Deal with special cases first.&lt;br /&gt;
		if (&lt;br /&gt;
			namespace == 10&lt;br /&gt;
			or namespace == 828&lt;br /&gt;
			or reason and obj._cfg.indefImageReasons[reason]&lt;br /&gt;
			)&lt;br /&gt;
			and action == &#039;edit&#039;&lt;br /&gt;
			and level == &#039;sysop&#039;&lt;br /&gt;
			and not protectionObj:isTemporary()&lt;br /&gt;
		then&lt;br /&gt;
			-- Fully protected modules and templates get the special red &amp;quot;indef&amp;quot;&lt;br /&gt;
			-- padlock.&lt;br /&gt;
			obj._imageFilename = obj._cfg.msg[&#039;image-filename-indef&#039;]&lt;br /&gt;
		else&lt;br /&gt;
			-- Deal with regular protection types.&lt;br /&gt;
			local images = obj._cfg.images&lt;br /&gt;
			if images[action] then&lt;br /&gt;
				if images[action][level] then&lt;br /&gt;
					obj._imageFilename = images[action][level]&lt;br /&gt;
				elseif images[action].default then&lt;br /&gt;
					obj._imageFilename = images[action].default&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return setmetatable(obj, BannerTemplate)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function BannerTemplate:setImageWidth(width)&lt;br /&gt;
	self._imageWidth = width&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function BannerTemplate:setImageTooltip(tooltip)&lt;br /&gt;
	self._imageCaption = tooltip&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function BannerTemplate:renderImage()&lt;br /&gt;
	local filename = self._imageFilename&lt;br /&gt;
		or self._cfg.msg[&#039;image-filename-default&#039;]&lt;br /&gt;
		or &#039;Transparent.gif&#039;&lt;br /&gt;
	return makeFileLink{&lt;br /&gt;
		file = filename,&lt;br /&gt;
		size = (self._imageWidth or 20) .. &#039;px&#039;,&lt;br /&gt;
		alt = self._imageAlt,&lt;br /&gt;
		link = self._imageLink,&lt;br /&gt;
		caption = self._imageCaption&lt;br /&gt;
	}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Banner class&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local Banner = setmetatable({}, BannerTemplate)&lt;br /&gt;
Banner.__index = Banner&lt;br /&gt;
&lt;br /&gt;
function Banner.new(protectionObj, blurbObj, cfg)&lt;br /&gt;
	local obj = BannerTemplate.new(protectionObj, cfg) -- This doesn&#039;t need the blurb.&lt;br /&gt;
	obj:setImageWidth(40)&lt;br /&gt;
	obj:setImageTooltip(blurbObj:makeBannerText(&#039;alt&#039;)) -- Large banners use the alt text for the tooltip.&lt;br /&gt;
	obj._reasonText = blurbObj:makeBannerText(&#039;text&#039;)&lt;br /&gt;
	obj._explanationText = blurbObj:makeBannerText(&#039;explanation&#039;)&lt;br /&gt;
	obj._page = protectionObj.title.prefixedText -- Only makes a difference in testing.&lt;br /&gt;
	return setmetatable(obj, Banner)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Banner:__tostring()&lt;br /&gt;
	-- Renders the banner.&lt;br /&gt;
	makeMessageBox = makeMessageBox or require(&#039;Module:Message box&#039;).main&lt;br /&gt;
	local reasonText = self._reasonText or error(&#039;no reason text set&#039;, 2)&lt;br /&gt;
	local explanationText = self._explanationText&lt;br /&gt;
	local mbargs = {&lt;br /&gt;
		page = self._page,&lt;br /&gt;
		type = &#039;protection&#039;,&lt;br /&gt;
		image = self:renderImage(),&lt;br /&gt;
		text = string.format(&lt;br /&gt;
			&amp;quot;&#039;&#039;&#039;%s&#039;&#039;&#039;%s&amp;quot;,&lt;br /&gt;
			reasonText,&lt;br /&gt;
			explanationText and &#039;&amp;lt;br /&amp;gt;&#039; .. explanationText or &#039;&#039;&lt;br /&gt;
		)&lt;br /&gt;
	}&lt;br /&gt;
	return makeMessageBox(&#039;mbox&#039;, mbargs)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Padlock class&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local Padlock = setmetatable({}, BannerTemplate)&lt;br /&gt;
Padlock.__index = Padlock&lt;br /&gt;
&lt;br /&gt;
function Padlock.new(protectionObj, blurbObj, cfg)&lt;br /&gt;
	local obj = BannerTemplate.new(protectionObj, cfg) -- This doesn&#039;t need the blurb.&lt;br /&gt;
	obj:setImageWidth(20)&lt;br /&gt;
	obj:setImageTooltip(blurbObj:makeBannerText(&#039;tooltip&#039;))&lt;br /&gt;
	obj._imageAlt = blurbObj:makeBannerText(&#039;alt&#039;)&lt;br /&gt;
	obj._imageLink = blurbObj:makeBannerText(&#039;link&#039;)&lt;br /&gt;
	obj._indicatorName = cfg.padlockIndicatorNames[protectionObj.action]&lt;br /&gt;
		or cfg.padlockIndicatorNames.default&lt;br /&gt;
		or &#039;pp-default&#039;&lt;br /&gt;
	return setmetatable(obj, Padlock)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function Padlock:__tostring()&lt;br /&gt;
	local frame = mw.getCurrentFrame()&lt;br /&gt;
	-- The nowiki tag helps prevent whitespace at the top of articles.&lt;br /&gt;
	local nowiki = frame:extensionTag{name = &#039;nowiki&#039;}&lt;br /&gt;
	local indicator = frame:extensionTag{&lt;br /&gt;
		name = &#039;indicator&#039;,&lt;br /&gt;
		args = {name = self._indicatorName},&lt;br /&gt;
		content = self:renderImage()&lt;br /&gt;
	}&lt;br /&gt;
	return nowiki .. indicator&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Exports&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
function p._exportClasses()&lt;br /&gt;
	-- This is used for testing purposes.&lt;br /&gt;
	return {&lt;br /&gt;
		Protection = Protection,&lt;br /&gt;
		Blurb = Blurb,&lt;br /&gt;
		BannerTemplate = BannerTemplate,&lt;br /&gt;
		Banner = Banner,&lt;br /&gt;
		Padlock = Padlock,&lt;br /&gt;
	}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(args, cfg, title)&lt;br /&gt;
	args = args or {}&lt;br /&gt;
	cfg = cfg or require(CONFIG_MODULE)&lt;br /&gt;
&lt;br /&gt;
	local protectionObj = Protection.new(args, cfg, title)&lt;br /&gt;
&lt;br /&gt;
	local ret = {}&lt;br /&gt;
&lt;br /&gt;
	-- If a page&#039;s edit protection is equally or more restrictive than its protection from some other action,&lt;br /&gt;
	-- then don&#039;t bother displaying anything for the other action (except categories).&lt;br /&gt;
	if protectionObj.action == &#039;edit&#039; or args.demolevel or not walkHierarchy(cfg.hierarchy, protectionObj.level)[effectiveProtectionLevel(&#039;edit&#039;, protectionObj.title)] then&lt;br /&gt;
		-- Initialise the blurb object&lt;br /&gt;
		local blurbObj = Blurb.new(protectionObj, args, cfg)&lt;br /&gt;
	&lt;br /&gt;
		-- Render the banner&lt;br /&gt;
		if protectionObj:isProtected() then&lt;br /&gt;
			ret[#ret + 1] = tostring(&lt;br /&gt;
				(yesno(args.small) and Padlock or Banner)&lt;br /&gt;
				.new(protectionObj, blurbObj, cfg)&lt;br /&gt;
			)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Render the categories&lt;br /&gt;
	if yesno(args.category) ~= false then&lt;br /&gt;
		ret[#ret + 1] = protectionObj:makeCategoryLinks()&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return table.concat(ret)	&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame, cfg)&lt;br /&gt;
	cfg = cfg or require(CONFIG_MODULE)&lt;br /&gt;
&lt;br /&gt;
	-- Find default args, if any.&lt;br /&gt;
	local parent = frame.getParent and frame:getParent()&lt;br /&gt;
	local defaultArgs = parent and cfg.wrappers[parent:getTitle():gsub(&#039;/sandbox$&#039;, &#039;&#039;)]&lt;br /&gt;
&lt;br /&gt;
	-- Find user args, and use the parent frame if we are being called from a&lt;br /&gt;
	-- wrapper template.&lt;br /&gt;
	getArgs = getArgs or require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
	local userArgs = getArgs(frame, {&lt;br /&gt;
		parentOnly = defaultArgs,&lt;br /&gt;
		frameOnly = not defaultArgs&lt;br /&gt;
	})&lt;br /&gt;
&lt;br /&gt;
	-- Build the args table. User-specified args overwrite default args.&lt;br /&gt;
	local args = {}&lt;br /&gt;
	for k, v in pairs(defaultArgs or {}) do&lt;br /&gt;
		args[k] = v&lt;br /&gt;
	end&lt;br /&gt;
	for k, v in pairs(userArgs) do&lt;br /&gt;
		args[k] = v&lt;br /&gt;
	end&lt;br /&gt;
	return p._main(args, cfg)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:No_globals&amp;diff=2422</id>
		<title>Module:No globals</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:No_globals&amp;diff=2422"/>
		<updated>2015-07-09T17:07:24Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local mt = getmetatable(_G) or {}&lt;br /&gt;
function mt.__index (t, k)&lt;br /&gt;
	if k ~= &#039;arg&#039; then&lt;br /&gt;
		error(&#039;Tried to read nil global &#039; .. tostring(k), 2)&lt;br /&gt;
	end&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
function mt.__newindex(t, k, v)&lt;br /&gt;
	if k ~= &#039;arg&#039; then&lt;br /&gt;
		error(&#039;Tried to write global &#039; .. tostring(k), 2)&lt;br /&gt;
	end&lt;br /&gt;
	rawset(t, k, v)&lt;br /&gt;
end&lt;br /&gt;
setmetatable(_G, mt)&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Navbox&amp;diff=2420</id>
		<title>Module:Navbox</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Navbox&amp;diff=2420"/>
		<updated>2015-07-09T17:07:24Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--&lt;br /&gt;
-- This module implements {{Navbox}}&lt;br /&gt;
--&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local navbar = require(&#039;Module:Navbar&#039;)._navbar&lt;br /&gt;
local getArgs -- lazily initialized&lt;br /&gt;
&lt;br /&gt;
local args&lt;br /&gt;
local tableRowAdded = false&lt;br /&gt;
local border&lt;br /&gt;
local listnums = {}&lt;br /&gt;
&lt;br /&gt;
local function trim(s)&lt;br /&gt;
    return (mw.ustring.gsub(s, &amp;quot;^%s*(.-)%s*$&amp;quot;, &amp;quot;%1&amp;quot;))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function addNewline(s)&lt;br /&gt;
    if s:match(&#039;^[*:;#]&#039;) or s:match(&#039;^{|&#039;) then&lt;br /&gt;
        return &#039;\n&#039; .. s ..&#039;\n&#039;&lt;br /&gt;
    else&lt;br /&gt;
        return s&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function addTableRow(tbl)&lt;br /&gt;
    -- If any other rows have already been added, then we add a 2px gutter row.&lt;br /&gt;
    if tableRowAdded then&lt;br /&gt;
        tbl&lt;br /&gt;
            :tag(&#039;tr&#039;)&lt;br /&gt;
                :css(&#039;height&#039;, &#039;2px&#039;)&lt;br /&gt;
                :tag(&#039;td&#039;)&lt;br /&gt;
                    :attr(&#039;colspan&#039;,2)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    tableRowAdded = true&lt;br /&gt;
&lt;br /&gt;
    return tbl:tag(&#039;tr&#039;)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderNavBar(titleCell)&lt;br /&gt;
    -- Depending on the presence of the navbar and/or show/hide link, we may need to add a spacer div on the left&lt;br /&gt;
    -- or right to keep the title centered.&lt;br /&gt;
    local spacerSide = nil&lt;br /&gt;
&lt;br /&gt;
    if args.navbar == &#039;off&#039; then&lt;br /&gt;
        -- No navbar, and client wants no spacer, i.e. wants the title to be shifted to the left. If there&#039;s&lt;br /&gt;
        -- also no show/hide link, then we need a spacer on the right to achieve the left shift.&lt;br /&gt;
        if args.state == &#039;plain&#039; then spacerSide = &#039;right&#039; end&lt;br /&gt;
    elseif args.navbar == &#039;plain&#039; or (not args.name and mw.getCurrentFrame():getParent():getTitle():gsub(&#039;/sandbox$&#039;, &#039;&#039;) == &#039;Template:Navbox&#039;) then&lt;br /&gt;
        -- No navbar. Need a spacer on the left to balance out the width of the show/hide link.&lt;br /&gt;
        if args.state ~= &#039;plain&#039; then spacerSide = &#039;left&#039; end&lt;br /&gt;
    else&lt;br /&gt;
        -- Will render navbar (or error message). If there&#039;s no show/hide link, need a spacer on the right&lt;br /&gt;
        -- to balance out the width of the navbar.&lt;br /&gt;
        if args.state == &#039;plain&#039; then spacerSide = &#039;right&#039; end&lt;br /&gt;
&lt;br /&gt;
        titleCell:wikitext(navbar{&lt;br /&gt;
            args.name,&lt;br /&gt;
            mini = 1,&lt;br /&gt;
            fontstyle = (args.basestyle or &#039;&#039;) .. &#039;;&#039; .. (args.titlestyle or &#039;&#039;) ..  &#039;;background:none transparent;border:none;&#039;&lt;br /&gt;
        })&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- Render the spacer div.&lt;br /&gt;
    if spacerSide then&lt;br /&gt;
        titleCell&lt;br /&gt;
            :tag(&#039;span&#039;)&lt;br /&gt;
                :css(&#039;float&#039;, spacerSide)&lt;br /&gt;
                :css(&#039;width&#039;, &#039;6em&#039;)&lt;br /&gt;
                :wikitext(&#039;&amp;amp;nbsp;&#039;)&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--&lt;br /&gt;
--   Title row&lt;br /&gt;
--&lt;br /&gt;
local function renderTitleRow(tbl)&lt;br /&gt;
    if not args.title then return end&lt;br /&gt;
&lt;br /&gt;
    local titleRow = addTableRow(tbl)&lt;br /&gt;
&lt;br /&gt;
    if args.titlegroup then&lt;br /&gt;
        titleRow&lt;br /&gt;
            :tag(&#039;th&#039;)&lt;br /&gt;
                :attr(&#039;scope&#039;, &#039;row&#039;)&lt;br /&gt;
                :addClass(&#039;navbox-group&#039;)&lt;br /&gt;
                :addClass(args.titlegroupclass)&lt;br /&gt;
                :cssText(args.basestyle)&lt;br /&gt;
                :cssText(args.groupstyle)&lt;br /&gt;
                :cssText(args.titlegroupstyle)&lt;br /&gt;
                :wikitext(args.titlegroup)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    local titleCell = titleRow:tag(&#039;th&#039;):attr(&#039;scope&#039;, &#039;col&#039;)&lt;br /&gt;
&lt;br /&gt;
    if args.titlegroup then&lt;br /&gt;
        titleCell&lt;br /&gt;
            :css(&#039;border-left&#039;, &#039;2px solid #fdfdfd&#039;)&lt;br /&gt;
            :css(&#039;width&#039;, &#039;100%&#039;)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    local titleColspan = 2&lt;br /&gt;
    if args.imageleft then titleColspan = titleColspan + 1 end&lt;br /&gt;
    if args.image then titleColspan = titleColspan + 1 end&lt;br /&gt;
    if args.titlegroup then titleColspan = titleColspan - 1 end&lt;br /&gt;
&lt;br /&gt;
    titleCell&lt;br /&gt;
        :cssText(args.basestyle)&lt;br /&gt;
        :cssText(args.titlestyle)&lt;br /&gt;
        :addClass(&#039;navbox-title&#039;)&lt;br /&gt;
        :attr(&#039;colspan&#039;, titleColspan)&lt;br /&gt;
&lt;br /&gt;
    renderNavBar(titleCell)&lt;br /&gt;
&lt;br /&gt;
    titleCell&lt;br /&gt;
         :tag(&#039;div&#039;)&lt;br /&gt;
             :addClass(args.titleclass)&lt;br /&gt;
             :css(&#039;font-size&#039;, &#039;110%&#039;)&lt;br /&gt;
             :wikitext(addNewline(args.title))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--&lt;br /&gt;
--   Above/Below rows&lt;br /&gt;
--&lt;br /&gt;
&lt;br /&gt;
local function getAboveBelowColspan()&lt;br /&gt;
    local ret = 2&lt;br /&gt;
    if args.imageleft then ret = ret + 1 end&lt;br /&gt;
    if args.image then ret = ret + 1 end&lt;br /&gt;
    return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderAboveRow(tbl)&lt;br /&gt;
    if not args.above then return end&lt;br /&gt;
&lt;br /&gt;
    addTableRow(tbl)&lt;br /&gt;
        :tag(&#039;td&#039;)&lt;br /&gt;
            :addClass(&#039;navbox-abovebelow&#039;)&lt;br /&gt;
            :addClass(args.aboveclass)&lt;br /&gt;
            :cssText(args.basestyle)&lt;br /&gt;
            :cssText(args.abovestyle)&lt;br /&gt;
            :attr(&#039;colspan&#039;, getAboveBelowColspan())&lt;br /&gt;
            :tag(&#039;div&#039;)&lt;br /&gt;
                :wikitext(addNewline(args.above))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderBelowRow(tbl)&lt;br /&gt;
    if not args.below then return end&lt;br /&gt;
&lt;br /&gt;
    addTableRow(tbl)&lt;br /&gt;
        :tag(&#039;td&#039;)&lt;br /&gt;
            :addClass(&#039;navbox-abovebelow&#039;)&lt;br /&gt;
            :addClass(args.belowclass)&lt;br /&gt;
            :cssText(args.basestyle)&lt;br /&gt;
            :cssText(args.belowstyle)&lt;br /&gt;
            :attr(&#039;colspan&#039;, getAboveBelowColspan())&lt;br /&gt;
            :tag(&#039;div&#039;)&lt;br /&gt;
                :wikitext(addNewline(args.below))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--&lt;br /&gt;
--   List rows&lt;br /&gt;
--&lt;br /&gt;
local function renderListRow(tbl, listnum)&lt;br /&gt;
    local row = addTableRow(tbl)&lt;br /&gt;
&lt;br /&gt;
    if listnum == 1 and args.imageleft then&lt;br /&gt;
        row&lt;br /&gt;
            :tag(&#039;td&#039;)&lt;br /&gt;
                :addClass(&#039;navbox-image&#039;)&lt;br /&gt;
                :addClass(args.imageclass)&lt;br /&gt;
                :css(&#039;width&#039;, &#039;0%&#039;)&lt;br /&gt;
                :css(&#039;padding&#039;, &#039;0px 2px 0px 0px&#039;)&lt;br /&gt;
                :cssText(args.imageleftstyle)&lt;br /&gt;
                :attr(&#039;rowspan&#039;, 2 * #listnums - 1)&lt;br /&gt;
                :tag(&#039;div&#039;)&lt;br /&gt;
                    :wikitext(addNewline(args.imageleft))&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    if args[&#039;group&#039; .. listnum] then&lt;br /&gt;
        local groupCell = row:tag(&#039;th&#039;)&lt;br /&gt;
&lt;br /&gt;
        groupCell&lt;br /&gt;
            :attr(&#039;scope&#039;, &#039;row&#039;)&lt;br /&gt;
            :addClass(&#039;navbox-group&#039;)&lt;br /&gt;
            :addClass(args.groupclass)&lt;br /&gt;
            :cssText(args.basestyle)&lt;br /&gt;
&lt;br /&gt;
        if args.groupwidth then&lt;br /&gt;
            groupCell:css(&#039;width&#039;, args.groupwidth)&lt;br /&gt;
        end&lt;br /&gt;
&lt;br /&gt;
        groupCell&lt;br /&gt;
            :cssText(args.groupstyle)&lt;br /&gt;
            :cssText(args[&#039;group&#039; .. listnum .. &#039;style&#039;])&lt;br /&gt;
            :wikitext(args[&#039;group&#039; .. listnum])&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    local listCell = row:tag(&#039;td&#039;)&lt;br /&gt;
&lt;br /&gt;
    if args[&#039;group&#039; .. listnum] then&lt;br /&gt;
        listCell&lt;br /&gt;
            :css(&#039;text-align&#039;, &#039;left&#039;)&lt;br /&gt;
            :css(&#039;border-left-width&#039;, &#039;2px&#039;)&lt;br /&gt;
            :css(&#039;border-left-style&#039;, &#039;solid&#039;)&lt;br /&gt;
    else&lt;br /&gt;
        listCell:attr(&#039;colspan&#039;, 2)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    if not args.groupwidth then&lt;br /&gt;
        listCell:css(&#039;width&#039;, &#039;100%&#039;)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    local isOdd = (listnum % 2) == 1&lt;br /&gt;
    local rowstyle = args.evenstyle&lt;br /&gt;
    if isOdd then rowstyle = args.oddstyle end&lt;br /&gt;
&lt;br /&gt;
    local evenOdd&lt;br /&gt;
    if args.evenodd == &#039;swap&#039; then&lt;br /&gt;
        if isOdd then evenOdd = &#039;even&#039; else evenOdd = &#039;odd&#039; end&lt;br /&gt;
    else&lt;br /&gt;
        if isOdd then evenOdd = args.evenodd or &#039;odd&#039; else evenOdd = args.evenodd or &#039;even&#039; end&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    listCell&lt;br /&gt;
        :css(&#039;padding&#039;, &#039;0px&#039;)&lt;br /&gt;
        :cssText(args.liststyle)&lt;br /&gt;
        :cssText(rowstyle)&lt;br /&gt;
        :cssText(args[&#039;list&#039; .. listnum .. &#039;style&#039;])&lt;br /&gt;
        :addClass(&#039;navbox-list&#039;)&lt;br /&gt;
        :addClass(&#039;navbox-&#039; .. evenOdd)&lt;br /&gt;
        :addClass(args.listclass)&lt;br /&gt;
        :tag(&#039;div&#039;)&lt;br /&gt;
            :css(&#039;padding&#039;, (listnum == 1 and args.list1padding) or args.listpadding or &#039;0em 0.25em&#039;)&lt;br /&gt;
            :wikitext(addNewline(args[&#039;list&#039; .. listnum]))&lt;br /&gt;
&lt;br /&gt;
    if listnum == 1 and args.image then&lt;br /&gt;
        row&lt;br /&gt;
            :tag(&#039;td&#039;)&lt;br /&gt;
                :addClass(&#039;navbox-image&#039;)&lt;br /&gt;
                :addClass(args.imageclass)&lt;br /&gt;
                :css(&#039;width&#039;, &#039;0%&#039;)&lt;br /&gt;
                :css(&#039;padding&#039;, &#039;0px 0px 0px 2px&#039;)&lt;br /&gt;
                :cssText(args.imagestyle)&lt;br /&gt;
                :attr(&#039;rowspan&#039;, 2 * #listnums - 1)&lt;br /&gt;
                :tag(&#039;div&#039;)&lt;br /&gt;
                    :wikitext(addNewline(args.image))&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--&lt;br /&gt;
--   Tracking categories&lt;br /&gt;
--&lt;br /&gt;
&lt;br /&gt;
local function needsHorizontalLists()&lt;br /&gt;
    if border == &#039;child&#039; or border == &#039;subgroup&#039;  or args.tracking == &#039;no&#039; then return false end&lt;br /&gt;
&lt;br /&gt;
    local listClasses = {&#039;plainlist&#039;, &#039;hlist&#039;, &#039;hlist hnum&#039;, &#039;hlist hwrap&#039;, &#039;hlist vcard&#039;, &#039;vcard hlist&#039;, &#039;hlist vevent&#039;}&lt;br /&gt;
    for i, cls in ipairs(listClasses) do&lt;br /&gt;
        if args.listclass == cls or args.bodyclass == cls then&lt;br /&gt;
            return false&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    return true&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function hasBackgroundColors()&lt;br /&gt;
    return mw.ustring.match(args.titlestyle or &#039;&#039;,&#039;background&#039;) or mw.ustring.match(args.groupstyle or &#039;&#039;,&#039;background&#039;) or mw.ustring.match(args.basestyle or &#039;&#039;,&#039;background&#039;)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getTrackingCategories()&lt;br /&gt;
    local cats = {}&lt;br /&gt;
    if needsHorizontalLists() then table.insert(cats, &#039;Navigational boxes without horizontal lists&#039;) end&lt;br /&gt;
    if hasBackgroundColors() then table.insert(cats, &#039;Navboxes using background colours&#039;) end&lt;br /&gt;
    return cats&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderTrackingCategories(builder)&lt;br /&gt;
    local title = mw.title.getCurrentTitle()&lt;br /&gt;
    if title.namespace ~= 10 then return end -- not in template space&lt;br /&gt;
    local subpage = title.subpageText&lt;br /&gt;
    if subpage == &#039;doc&#039; or subpage == &#039;sandbox&#039; or subpage == &#039;testcases&#039; then return end&lt;br /&gt;
&lt;br /&gt;
    for i, cat in ipairs(getTrackingCategories()) do&lt;br /&gt;
        builder:wikitext(&#039;[[Category:&#039; .. cat .. &#039;]]&#039;)&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--&lt;br /&gt;
--   Main navbox tables&lt;br /&gt;
--&lt;br /&gt;
local function renderMainTable()&lt;br /&gt;
    local tbl = mw.html.create(&#039;table&#039;)&lt;br /&gt;
        :addClass(&#039;nowraplinks&#039;)&lt;br /&gt;
        :addClass(args.bodyclass)&lt;br /&gt;
&lt;br /&gt;
    if args.title and (args.state ~= &#039;plain&#039; and args.state ~= &#039;off&#039;) then&lt;br /&gt;
        tbl&lt;br /&gt;
            :addClass(&#039;collapsible&#039;)&lt;br /&gt;
            :addClass(args.state or &#039;autocollapse&#039;)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    tbl:css(&#039;border-spacing&#039;, 0)&lt;br /&gt;
    if border == &#039;subgroup&#039; or border == &#039;child&#039; or border == &#039;none&#039; then&lt;br /&gt;
        tbl&lt;br /&gt;
            :addClass(&#039;navbox-subgroup&#039;)&lt;br /&gt;
            :cssText(args.bodystyle)&lt;br /&gt;
            :cssText(args.style)&lt;br /&gt;
    else -- regular navobx - bodystyle and style will be applied to the wrapper table&lt;br /&gt;
        tbl&lt;br /&gt;
            :addClass(&#039;navbox-inner&#039;)&lt;br /&gt;
            :css(&#039;background&#039;, &#039;transparent&#039;)&lt;br /&gt;
            :css(&#039;color&#039;, &#039;inherit&#039;)&lt;br /&gt;
    end&lt;br /&gt;
    tbl:cssText(args.innerstyle)&lt;br /&gt;
&lt;br /&gt;
    renderTitleRow(tbl)&lt;br /&gt;
    renderAboveRow(tbl)&lt;br /&gt;
    for i, listnum in ipairs(listnums) do&lt;br /&gt;
        renderListRow(tbl, listnum)&lt;br /&gt;
    end&lt;br /&gt;
    renderBelowRow(tbl)&lt;br /&gt;
&lt;br /&gt;
    return tbl&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._navbox(navboxArgs)&lt;br /&gt;
    args = navboxArgs&lt;br /&gt;
&lt;br /&gt;
    for k, v in pairs(args) do&lt;br /&gt;
        local listnum = (&#039;&#039; .. k):match(&#039;^list(%d+)$&#039;)&lt;br /&gt;
        if listnum then table.insert(listnums, tonumber(listnum)) end&lt;br /&gt;
    end&lt;br /&gt;
    table.sort(listnums)&lt;br /&gt;
&lt;br /&gt;
    border = trim(args.border or args[1] or &#039;&#039;)&lt;br /&gt;
&lt;br /&gt;
    -- render the main body of the navbox&lt;br /&gt;
    local tbl = renderMainTable()&lt;br /&gt;
&lt;br /&gt;
    -- render the appropriate wrapper around the navbox, depending on the border param&lt;br /&gt;
    local res = mw.html.create()&lt;br /&gt;
    if border == &#039;none&#039; then&lt;br /&gt;
        res:node(tbl)&lt;br /&gt;
    elseif border == &#039;subgroup&#039; or border == &#039;child&#039; then&lt;br /&gt;
        -- We assume that this navbox is being rendered in a list cell of a parent navbox, and is&lt;br /&gt;
        -- therefore inside a div with padding:0em 0.25em. We start with a &amp;lt;/div&amp;gt; to avoid the&lt;br /&gt;
        -- padding being applied, and at the end add a &amp;lt;div&amp;gt; to balance out the parent&#039;s &amp;lt;/div&amp;gt;&lt;br /&gt;
        res&lt;br /&gt;
            :wikitext(&#039;&amp;lt;/div&amp;gt;&#039;) -- XXX: hack due to lack of unclosed support in mw.html.&lt;br /&gt;
            :node(tbl)&lt;br /&gt;
            :wikitext(&#039;&amp;lt;div&amp;gt;&#039;) -- XXX: hack due to lack of unclosed support in mw.html.&lt;br /&gt;
    else&lt;br /&gt;
        res&lt;br /&gt;
            :tag(&#039;table&#039;)&lt;br /&gt;
                :addClass(&#039;navbox&#039;)&lt;br /&gt;
                :css(&#039;border-spacing&#039;, 0)&lt;br /&gt;
                :cssText(args.bodystyle)&lt;br /&gt;
                :cssText(args.style)&lt;br /&gt;
                :tag(&#039;tr&#039;)&lt;br /&gt;
                    :tag(&#039;td&#039;)&lt;br /&gt;
                        :css(&#039;padding&#039;, &#039;2px&#039;)&lt;br /&gt;
                        :node(tbl)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    renderTrackingCategories(res)&lt;br /&gt;
&lt;br /&gt;
    return tostring(res)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.navbox(frame)&lt;br /&gt;
    if not getArgs then&lt;br /&gt;
        getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
    end&lt;br /&gt;
    args = getArgs(frame, {wrappers = &#039;Template:Navbox&#039;})&lt;br /&gt;
&lt;br /&gt;
    -- Read the arguments in the order they&#039;ll be output in, to make references number in the right order.&lt;br /&gt;
    local _&lt;br /&gt;
    _ = args.title&lt;br /&gt;
    _ = args.above&lt;br /&gt;
    for i = 1, 20 do&lt;br /&gt;
        _ = args[&amp;quot;group&amp;quot; .. tostring(i)]&lt;br /&gt;
        _ = args[&amp;quot;list&amp;quot; .. tostring(i)]&lt;br /&gt;
    end&lt;br /&gt;
    _ = args.below&lt;br /&gt;
&lt;br /&gt;
    return p._navbox(args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Navbar&amp;diff=2418</id>
		<title>Module:Navbar</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Navbar&amp;diff=2418"/>
		<updated>2015-07-09T17:07:24Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local p = {}&lt;br /&gt;
&lt;br /&gt;
local getArgs&lt;br /&gt;
&lt;br /&gt;
function p._navbar(args)&lt;br /&gt;
	local titleArg = 1&lt;br /&gt;
&lt;br /&gt;
	if args.collapsible then&lt;br /&gt;
		titleArg = 2&lt;br /&gt;
		if not args.plain then&lt;br /&gt;
			args.mini = 1&lt;br /&gt;
		end&lt;br /&gt;
		if args.fontcolor then&lt;br /&gt;
			args.fontstyle = &#039;color:&#039; .. args.fontcolor .. &#039;;&#039;&lt;br /&gt;
		end&lt;br /&gt;
		args.style = &#039;float:left; text-align:left; width:6em;&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local titleText = args[titleArg] or (&#039;:&#039; .. mw.getCurrentFrame():getParent():getTitle())&lt;br /&gt;
	local title = mw.title.new(mw.text.trim(titleText), &#039;Template&#039;);&lt;br /&gt;
&lt;br /&gt;
	if not title then&lt;br /&gt;
		error(&#039;Invalid title &#039; .. titleText)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local talkpage = title.talkPageTitle and title.talkPageTitle.fullText or &#039;&#039;;&lt;br /&gt;
&lt;br /&gt;
	local div = mw.html.create():tag(&#039;div&#039;)&lt;br /&gt;
	div&lt;br /&gt;
		:addClass(&#039;plainlinks&#039;)&lt;br /&gt;
		:addClass(&#039;hlist&#039;)&lt;br /&gt;
		:addClass(&#039;navbar&#039;)&lt;br /&gt;
		:cssText(args.style)&lt;br /&gt;
&lt;br /&gt;
	if args.mini then div:addClass(&#039;mini&#039;) end&lt;br /&gt;
&lt;br /&gt;
	if not (args.mini or args.plain) then&lt;br /&gt;
		div&lt;br /&gt;
			:tag(&#039;span&#039;)&lt;br /&gt;
				:css(&#039;word-spacing&#039;, 0)&lt;br /&gt;
				:cssText(args.fontstyle)&lt;br /&gt;
				:wikitext(args.text or &#039;This box:&#039;)&lt;br /&gt;
				:wikitext(&#039; &#039;)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if args.brackets then&lt;br /&gt;
		div&lt;br /&gt;
			:tag(&#039;span&#039;)&lt;br /&gt;
				:css(&#039;margin-right&#039;, &#039;-0.125em&#039;)&lt;br /&gt;
				:cssText(args.fontstyle)&lt;br /&gt;
				:wikitext(&#039;&amp;amp;#91;&#039;)&lt;br /&gt;
				:newline();&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local ul = div:tag(&#039;ul&#039;);&lt;br /&gt;
&lt;br /&gt;
	ul&lt;br /&gt;
		:tag(&#039;li&#039;)&lt;br /&gt;
			:addClass(&#039;nv-view&#039;)&lt;br /&gt;
			:wikitext(&#039;[[&#039; .. title.fullText .. &#039;|&#039;)&lt;br /&gt;
			:tag(&#039;span&#039;)&lt;br /&gt;
				:attr(&#039;title&#039;, &#039;View this template&#039;)&lt;br /&gt;
				:cssText(args.fontstyle)&lt;br /&gt;
				:wikitext(args.mini and &#039;v&#039; or &#039;view&#039;)&lt;br /&gt;
				:done()&lt;br /&gt;
			:wikitext(&#039;]]&#039;)&lt;br /&gt;
			:done()&lt;br /&gt;
		:tag(&#039;li&#039;)&lt;br /&gt;
			:addClass(&#039;nv-talk&#039;)&lt;br /&gt;
			:wikitext(&#039;[[&#039; .. talkpage .. &#039;|&#039;)&lt;br /&gt;
			:tag(&#039;span&#039;)&lt;br /&gt;
				:attr(&#039;title&#039;, &#039;Discuss this template&#039;)&lt;br /&gt;
				:cssText(args.fontstyle)&lt;br /&gt;
				:wikitext(args.mini and &#039;t&#039; or &#039;talk&#039;)&lt;br /&gt;
				:done()&lt;br /&gt;
			:wikitext(&#039;]]&#039;);&lt;br /&gt;
&lt;br /&gt;
	if not args.noedit then&lt;br /&gt;
		ul&lt;br /&gt;
			:tag(&#039;li&#039;)&lt;br /&gt;
				:addClass(&#039;nv-edit&#039;)&lt;br /&gt;
				:wikitext(&#039;[&#039; .. title:fullUrl(&#039;action=edit&#039;) .. &#039; &#039;)&lt;br /&gt;
				:tag(&#039;span&#039;)&lt;br /&gt;
					:attr(&#039;title&#039;, &#039;Edit this template&#039;)&lt;br /&gt;
					:cssText(args.fontstyle)&lt;br /&gt;
					:wikitext(args.mini and &#039;e&#039; or &#039;edit&#039;)&lt;br /&gt;
					:done()&lt;br /&gt;
				:wikitext(&#039;]&#039;);&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if args.brackets then&lt;br /&gt;
		div&lt;br /&gt;
			:tag(&#039;span&#039;)&lt;br /&gt;
				:css(&#039;margin-left&#039;, &#039;-0.125em&#039;)&lt;br /&gt;
				:cssText(args.fontstyle)&lt;br /&gt;
				:wikitext(&#039;&amp;amp;#93;&#039;)&lt;br /&gt;
				:newline();&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if args.collapsible then&lt;br /&gt;
		div&lt;br /&gt;
			:done()&lt;br /&gt;
		:tag(&#039;span&#039;)&lt;br /&gt;
			:css(&#039;font-size&#039;, &#039;110%&#039;)&lt;br /&gt;
			:cssText(args.fontstyle)&lt;br /&gt;
			:wikitext(args[1])&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return tostring(div:done())&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.navbar(frame)&lt;br /&gt;
	if not getArgs then&lt;br /&gt;
		getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
	end&lt;br /&gt;
	return p._navbar(getArgs(frame))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Namespace_detect/data&amp;diff=2416</id>
		<title>Module:Namespace detect/data</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Namespace_detect/data&amp;diff=2416"/>
		<updated>2015-07-09T17:07:24Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--------------------------------------------------------------------------------&lt;br /&gt;
--                          Namespace detect data                             --&lt;br /&gt;
-- This module holds data for [[Module:Namespace detect]] to be loaded per    --&lt;br /&gt;
-- page, rather than per #invoke, for performance reasons.                    --&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local cfg = require(&#039;Module:Namespace detect/config&#039;)&lt;br /&gt;
&lt;br /&gt;
local function addKey(t, key, defaultKey)&lt;br /&gt;
	if key ~= defaultKey then&lt;br /&gt;
		t[#t + 1] = key&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Get a table of parameters to query for each default parameter name.&lt;br /&gt;
-- This allows wikis to customise parameter names in the cfg table while&lt;br /&gt;
-- ensuring that default parameter names will always work. The cfg table&lt;br /&gt;
-- values can be added as a string, or as an array of strings.&lt;br /&gt;
&lt;br /&gt;
local defaultKeys = {&lt;br /&gt;
	&#039;main&#039;,&lt;br /&gt;
	&#039;talk&#039;,&lt;br /&gt;
	&#039;other&#039;,&lt;br /&gt;
	&#039;subjectns&#039;,&lt;br /&gt;
	&#039;demospace&#039;,&lt;br /&gt;
	&#039;demopage&#039;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
local argKeys = {}&lt;br /&gt;
for i, defaultKey in ipairs(defaultKeys) do&lt;br /&gt;
	argKeys[defaultKey] = {defaultKey}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
for defaultKey, t in pairs(argKeys) do&lt;br /&gt;
	local cfgValue = cfg[defaultKey]&lt;br /&gt;
	local cfgValueType = type(cfgValue)&lt;br /&gt;
	if cfgValueType == &#039;string&#039; then&lt;br /&gt;
		addKey(t, cfgValue, defaultKey)&lt;br /&gt;
	elseif cfgValueType == &#039;table&#039; then&lt;br /&gt;
		for i, key in ipairs(cfgValue) do&lt;br /&gt;
			addKey(t, key, defaultKey)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	cfg[defaultKey] = nil -- Free the cfg value as we don&#039;t need it any more.&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getParamMappings()&lt;br /&gt;
	--[[&lt;br /&gt;
	-- Returns a table of how parameter names map to namespace names. The keys&lt;br /&gt;
	-- are the actual namespace names, in lower case, and the values are the&lt;br /&gt;
	-- possible parameter names for that namespace, also in lower case. The&lt;br /&gt;
	-- table entries are structured like this:&lt;br /&gt;
	-- {&lt;br /&gt;
	--   [&#039;&#039;] = {&#039;main&#039;},&lt;br /&gt;
	--   [&#039;wikipedia&#039;] = {&#039;wikipedia&#039;, &#039;project&#039;, &#039;wp&#039;},&lt;br /&gt;
	--   ...&lt;br /&gt;
	-- }&lt;br /&gt;
	--]]&lt;br /&gt;
	local mappings = {}&lt;br /&gt;
	local mainNsName = mw.site.subjectNamespaces[0].name&lt;br /&gt;
	mainNsName = mw.ustring.lower(mainNsName)&lt;br /&gt;
	mappings[mainNsName] = mw.clone(argKeys.main)&lt;br /&gt;
	mappings[&#039;talk&#039;] = mw.clone(argKeys.talk)&lt;br /&gt;
	for nsid, ns in pairs(mw.site.subjectNamespaces) do&lt;br /&gt;
		if nsid ~= 0 then -- Exclude main namespace.&lt;br /&gt;
			local nsname = mw.ustring.lower(ns.name)&lt;br /&gt;
			local canonicalName = mw.ustring.lower(ns.canonicalName)&lt;br /&gt;
			mappings[nsname] = {nsname}&lt;br /&gt;
			if canonicalName ~= nsname then&lt;br /&gt;
				table.insert(mappings[nsname], canonicalName)&lt;br /&gt;
			end&lt;br /&gt;
			for _, alias in ipairs(ns.aliases) do&lt;br /&gt;
				table.insert(mappings[nsname], mw.ustring.lower(alias))&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return mappings&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return {&lt;br /&gt;
	argKeys = argKeys,&lt;br /&gt;
	cfg = cfg,&lt;br /&gt;
	mappings = getParamMappings()&lt;br /&gt;
}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Namespace_detect/config&amp;diff=2414</id>
		<title>Module:Namespace detect/config</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Namespace_detect/config&amp;diff=2414"/>
		<updated>2015-07-09T17:07:24Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--------------------------------------------------------------------------------&lt;br /&gt;
--                    Namespace detect configuration data                     --&lt;br /&gt;
--                                                                            --&lt;br /&gt;
-- This module stores configuration data for Module:Namespace detect. Here    --&lt;br /&gt;
-- you can localise the module to your wiki&#039;s language.                       --&lt;br /&gt;
--                                                                            --&lt;br /&gt;
-- To activate a configuration item, you need to uncomment it. This means     --&lt;br /&gt;
-- that you need to remove the text &amp;quot;-- &amp;quot; at the start of the line.           --&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local cfg = {} -- Don&#039;t edit this line.&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
--                              Parameter names                               --&lt;br /&gt;
-- These configuration items specify custom parameter names. Values added     --&lt;br /&gt;
-- here will work in addition to the default English parameter names.         --&lt;br /&gt;
-- To add one extra name, you can use this format:                            --&lt;br /&gt;
--                                                                            --&lt;br /&gt;
-- cfg.foo = &#039;parameter name&#039;                                                 --&lt;br /&gt;
--                                                                            --&lt;br /&gt;
-- To add multiple names, you can use this format:                            --&lt;br /&gt;
--                                                                            --&lt;br /&gt;
-- cfg.foo = {&#039;parameter name 1&#039;, &#039;parameter name 2&#039;, &#039;parameter name 3&#039;}     --&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
---- This parameter displays content for the main namespace:&lt;br /&gt;
-- cfg.main = &#039;main&#039;&lt;br /&gt;
&lt;br /&gt;
---- This parameter displays in talk namespaces:&lt;br /&gt;
-- cfg.talk = &#039;talk&#039;&lt;br /&gt;
&lt;br /&gt;
---- This parameter displays content for &amp;quot;other&amp;quot; namespaces (namespaces for which&lt;br /&gt;
---- parameters have not been specified):&lt;br /&gt;
-- cfg.other = &#039;other&#039;&lt;br /&gt;
&lt;br /&gt;
---- This parameter makes talk pages behave as though they are the corresponding&lt;br /&gt;
---- subject namespace. Note that this parameter is used with [[Module:Yesno]].&lt;br /&gt;
---- Edit that module to change the default values of &amp;quot;yes&amp;quot;, &amp;quot;no&amp;quot;, etc.&lt;br /&gt;
-- cfg.subjectns = &#039;subjectns&#039;&lt;br /&gt;
&lt;br /&gt;
---- This parameter sets a demonstration namespace:&lt;br /&gt;
-- cfg.demospace = &#039;demospace&#039;&lt;br /&gt;
&lt;br /&gt;
---- This parameter sets a specific page to compare:&lt;br /&gt;
cfg.demopage = &#039;page&#039;&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
--                           Table configuration                              --&lt;br /&gt;
-- These configuration items allow customisation of the &amp;quot;table&amp;quot; function,     --&lt;br /&gt;
-- used to generate a table of possible parameters in the module              --&lt;br /&gt;
-- documentation.                                                             --&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
---- The header for the namespace column in the wikitable containing the list of&lt;br /&gt;
---- possible subject-space parameters.&lt;br /&gt;
-- cfg.wikitableNamespaceHeader = &#039;Namespace&#039;&lt;br /&gt;
&lt;br /&gt;
---- The header for the wikitable containing the list of possible subject-space&lt;br /&gt;
---- parameters.&lt;br /&gt;
-- cfg.wikitableAliasesHeader = &#039;Aliases&#039;&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
--                        End of configuration data                           --&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
return cfg -- Don&#039;t edit this line.&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Message_box/configuration&amp;diff=2412</id>
		<title>Module:Message box/configuration</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Message_box/configuration&amp;diff=2412"/>
		<updated>2015-07-09T17:07:24Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--------------------------------------------------------------------------------&lt;br /&gt;
--                          Message box configuration                         --&lt;br /&gt;
--                                                                            --&lt;br /&gt;
-- This module contains configuration data for [[Module:Message box]].        --&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
return {&lt;br /&gt;
	ambox = {&lt;br /&gt;
		types = {&lt;br /&gt;
			speedy = {&lt;br /&gt;
				class = &#039;ambox-speedy&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			delete = {&lt;br /&gt;
				class = &#039;ambox-delete&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			content = {&lt;br /&gt;
				class = &#039;ambox-content&#039;,&lt;br /&gt;
				image = &#039;Ambox important.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			style = {&lt;br /&gt;
				class = &#039;ambox-style&#039;,&lt;br /&gt;
				image = &#039;Edit-clear.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			move = {&lt;br /&gt;
				class = &#039;ambox-move&#039;,&lt;br /&gt;
				image = &#039;Merge-split-transwiki default.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			protection = {&lt;br /&gt;
				class = &#039;ambox-protection&#039;,&lt;br /&gt;
				image = &#039;Padlock-silver-medium.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			notice = {&lt;br /&gt;
				class = &#039;ambox-notice&#039;,&lt;br /&gt;
				image = &#039;Information icon4.svg&#039;&lt;br /&gt;
			}&lt;br /&gt;
		},&lt;br /&gt;
		default                     = &#039;notice&#039;,&lt;br /&gt;
		allowBlankParams            = {&#039;talk&#039;, &#039;sect&#039;, &#039;date&#039;, &#039;issue&#039;, &#039;fix&#039;, &#039;subst&#039;, &#039;hidden&#039;},&lt;br /&gt;
		allowSmall                  = true,&lt;br /&gt;
		smallParam                  = &#039;left&#039;,&lt;br /&gt;
		smallClass                  = &#039;mbox-small-left&#039;,&lt;br /&gt;
		substCheck                  = true,&lt;br /&gt;
		classes                     = {&#039;metadata&#039;, &#039;plainlinks&#039;, &#039;ambox&#039;},&lt;br /&gt;
		imageEmptyCell              = true,&lt;br /&gt;
		imageCheckBlank             = true,&lt;br /&gt;
		imageSmallSize              = &#039;20x20px&#039;,&lt;br /&gt;
		imageCellDiv                = true,&lt;br /&gt;
		useCollapsibleTextFields    = true,&lt;br /&gt;
		imageRightNone              = true,&lt;br /&gt;
		sectionDefault              = &#039;article&#039;,&lt;br /&gt;
		allowMainspaceCategories    = true,&lt;br /&gt;
		templateCategory            = &#039;Article message templates&#039;,&lt;br /&gt;
	        templateCategoryRequireName = true,&lt;br /&gt;
		templateErrorCategory       = &#039;Article message templates with missing parameters&#039;,&lt;br /&gt;
		templateErrorParamsToCheck  = {&#039;issue&#039;, &#039;fix&#039;, &#039;subst&#039;}&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	cmbox = {&lt;br /&gt;
		types = {&lt;br /&gt;
			speedy = {&lt;br /&gt;
				class = &#039;cmbox-speedy&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			delete = {&lt;br /&gt;
				class = &#039;cmbox-delete&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			content = {&lt;br /&gt;
				class = &#039;cmbox-content&#039;,&lt;br /&gt;
				image = &#039;Ambox important.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			style = {&lt;br /&gt;
				class = &#039;cmbox-style&#039;,&lt;br /&gt;
				image = &#039;Edit-clear.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			move = {&lt;br /&gt;
				class = &#039;cmbox-move&#039;,&lt;br /&gt;
				image = &#039;Merge-split-transwiki default.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			protection = {&lt;br /&gt;
				class = &#039;cmbox-protection&#039;,&lt;br /&gt;
				image = &#039;Padlock-silver-medium.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			notice = {&lt;br /&gt;
				class = &#039;cmbox-notice&#039;,&lt;br /&gt;
				image = &#039;Information icon4.svg&#039;&lt;br /&gt;
			}&lt;br /&gt;
		},&lt;br /&gt;
		default              = &#039;notice&#039;,&lt;br /&gt;
		showInvalidTypeError = true,&lt;br /&gt;
		classes              = {&#039;plainlinks&#039;, &#039;cmbox&#039;},&lt;br /&gt;
		imageEmptyCell       = true&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	fmbox = {&lt;br /&gt;
		types = {&lt;br /&gt;
			warning = {&lt;br /&gt;
				class = &#039;fmbox-warning&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			editnotice = {&lt;br /&gt;
				class = &#039;fmbox-editnotice&#039;,&lt;br /&gt;
				image = &#039;Information icon4.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			system = {&lt;br /&gt;
				class = &#039;fmbox-system&#039;,&lt;br /&gt;
				image = &#039;Information icon4.svg&#039;&lt;br /&gt;
			}&lt;br /&gt;
		},&lt;br /&gt;
		default              = &#039;system&#039;,&lt;br /&gt;
		showInvalidTypeError = true,&lt;br /&gt;
		allowId                = true,&lt;br /&gt;
		classes              = {&#039;plainlinks&#039;, &#039;fmbox&#039;},&lt;br /&gt;
		imageEmptyCell       = false,&lt;br /&gt;
		imageRightNone       = false&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	imbox = {&lt;br /&gt;
		types = {&lt;br /&gt;
			speedy = {&lt;br /&gt;
				class = &#039;imbox-speedy&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			delete = {&lt;br /&gt;
				class = &#039;imbox-delete&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			content = {&lt;br /&gt;
				class = &#039;imbox-content&#039;,&lt;br /&gt;
				image = &#039;Ambox important.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			style = {&lt;br /&gt;
				class = &#039;imbox-style&#039;,&lt;br /&gt;
				image = &#039;Edit-clear.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			move = {&lt;br /&gt;
				class = &#039;imbox-move&#039;,&lt;br /&gt;
				image = &#039;Merge-split-transwiki default.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			protection = {&lt;br /&gt;
				class = &#039;imbox-protection&#039;,&lt;br /&gt;
				image = &#039;Padlock-silver-medium.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			license = {&lt;br /&gt;
				class = &#039;imbox-license licensetpl&#039;,&lt;br /&gt;
				image = &#039;Imbox license.png&#039; -- @todo We need an SVG version of this&lt;br /&gt;
			},&lt;br /&gt;
			featured = {&lt;br /&gt;
				class = &#039;imbox-featured&#039;,&lt;br /&gt;
				image = &#039;Cscr-featured.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			notice = {&lt;br /&gt;
				class = &#039;imbox-notice&#039;,&lt;br /&gt;
				image = &#039;Information icon4.svg&#039;&lt;br /&gt;
			}&lt;br /&gt;
		},&lt;br /&gt;
		default              = &#039;notice&#039;,&lt;br /&gt;
		showInvalidTypeError = true,&lt;br /&gt;
		classes              = {&#039;imbox&#039;},&lt;br /&gt;
		usePlainlinksParam   = true,&lt;br /&gt;
		imageEmptyCell       = true,&lt;br /&gt;
		below                = true,&lt;br /&gt;
		templateCategory     = &#039;File message boxes&#039;&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	ombox = {&lt;br /&gt;
		types = {&lt;br /&gt;
			speedy = {&lt;br /&gt;
				class = &#039;ombox-speedy&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			delete = {&lt;br /&gt;
				class = &#039;ombox-delete&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			content = {&lt;br /&gt;
				class = &#039;ombox-content&#039;,&lt;br /&gt;
				image = &#039;Ambox important.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			style = {&lt;br /&gt;
				class = &#039;ombox-style&#039;,&lt;br /&gt;
				image = &#039;Edit-clear.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			move = {&lt;br /&gt;
				class = &#039;ombox-move&#039;,&lt;br /&gt;
				image = &#039;Merge-split-transwiki default.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			protection = {&lt;br /&gt;
				class = &#039;ombox-protection&#039;,&lt;br /&gt;
				image = &#039;Padlock-silver-medium.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			notice = {&lt;br /&gt;
				class = &#039;ombox-notice&#039;,&lt;br /&gt;
				image = &#039;Information icon4.svg&#039;&lt;br /&gt;
			}&lt;br /&gt;
		},&lt;br /&gt;
		default              = &#039;notice&#039;,&lt;br /&gt;
		showInvalidTypeError = true,&lt;br /&gt;
		classes              = {&#039;plainlinks&#039;, &#039;ombox&#039;},&lt;br /&gt;
		allowSmall           = true,&lt;br /&gt;
		imageEmptyCell       = true,&lt;br /&gt;
		imageRightNone       = true&lt;br /&gt;
	},&lt;br /&gt;
	&lt;br /&gt;
	tmbox = {&lt;br /&gt;
		types = {&lt;br /&gt;
			speedy = {&lt;br /&gt;
				class = &#039;tmbox-speedy&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			delete = {&lt;br /&gt;
				class = &#039;tmbox-delete&#039;,&lt;br /&gt;
				image = &#039;Ambox warning pn.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			content = {&lt;br /&gt;
				class = &#039;tmbox-content&#039;,&lt;br /&gt;
				image = &#039;Ambox important.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			style = {&lt;br /&gt;
				class = &#039;tmbox-style&#039;,&lt;br /&gt;
				image = &#039;Edit-clear.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			move = {&lt;br /&gt;
				class = &#039;tmbox-move&#039;,&lt;br /&gt;
				image = &#039;Merge-split-transwiki default.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			protection = {&lt;br /&gt;
				class = &#039;tmbox-protection&#039;,&lt;br /&gt;
				image = &#039;Padlock-silver-medium.svg&#039;&lt;br /&gt;
			},&lt;br /&gt;
			notice = {&lt;br /&gt;
				class = &#039;tmbox-notice&#039;,&lt;br /&gt;
				image = &#039;Information icon4.svg&#039;&lt;br /&gt;
			}&lt;br /&gt;
		},&lt;br /&gt;
		default              = &#039;notice&#039;,&lt;br /&gt;
		showInvalidTypeError = true,&lt;br /&gt;
		classes              = {&#039;plainlinks&#039;, &#039;tmbox&#039;},&lt;br /&gt;
		allowId              = true,&lt;br /&gt;
		allowSmall           = true,&lt;br /&gt;
		imageRightNone       = true,&lt;br /&gt;
		imageEmptyCell       = true,&lt;br /&gt;
		imageEmptyCellStyle  = true,&lt;br /&gt;
		templateCategory     = &#039;Talk message boxes&#039;&lt;br /&gt;
	}&lt;br /&gt;
}&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Message_box&amp;diff=2410</id>
		<title>Module:Message box</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Message_box&amp;diff=2410"/>
		<updated>2015-07-09T17:07:24Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This is a meta-module for producing message box templates, including&lt;br /&gt;
-- {{mbox}}, {{ambox}}, {{imbox}}, {{tmbox}}, {{ombox}}, {{cmbox}} and {{fmbox}}.&lt;br /&gt;
&lt;br /&gt;
-- Load necessary modules.&lt;br /&gt;
require(&#039;Module:No globals&#039;)&lt;br /&gt;
local getArgs&lt;br /&gt;
local categoryHandler = require(&#039;Module:Category handler&#039;)._main&lt;br /&gt;
local yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
&lt;br /&gt;
-- Get a language object for formatDate and ucfirst.&lt;br /&gt;
local lang = mw.language.getContentLanguage()&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Helper functions&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local function getTitleObject(...)&lt;br /&gt;
	-- Get the title object, passing the function through pcall&lt;br /&gt;
	-- in case we are over the expensive function count limit.&lt;br /&gt;
	local success, title = pcall(mw.title.new, ...)&lt;br /&gt;
	if success then&lt;br /&gt;
		return title&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function union(t1, t2)&lt;br /&gt;
	-- Returns the union of two arrays.&lt;br /&gt;
	local vals = {}&lt;br /&gt;
	for i, v in ipairs(t1) do&lt;br /&gt;
		vals[v] = true&lt;br /&gt;
	end&lt;br /&gt;
	for i, v in ipairs(t2) do&lt;br /&gt;
		vals[v] = true&lt;br /&gt;
	end&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for k in pairs(vals) do&lt;br /&gt;
		table.insert(ret, k)&lt;br /&gt;
	end&lt;br /&gt;
	table.sort(ret)&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getArgNums(args, prefix)&lt;br /&gt;
	local nums = {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		local num = mw.ustring.match(tostring(k), &#039;^&#039; .. prefix .. &#039;([1-9]%d*)$&#039;)&lt;br /&gt;
		if num then&lt;br /&gt;
			table.insert(nums, tonumber(num))&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	table.sort(nums)&lt;br /&gt;
	return nums&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Box class definition&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local MessageBox = {}&lt;br /&gt;
MessageBox.__index = MessageBox&lt;br /&gt;
&lt;br /&gt;
function MessageBox.new(boxType, args, cfg)&lt;br /&gt;
	args = args or {}&lt;br /&gt;
	local obj = {}&lt;br /&gt;
&lt;br /&gt;
	-- Set the title object and the namespace.&lt;br /&gt;
	obj.title = getTitleObject(args.page) or mw.title.getCurrentTitle()&lt;br /&gt;
&lt;br /&gt;
	-- Set the config for our box type.&lt;br /&gt;
	obj.cfg = cfg[boxType]&lt;br /&gt;
	if not obj.cfg then&lt;br /&gt;
		local ns = obj.title.namespace&lt;br /&gt;
		-- boxType is &amp;quot;mbox&amp;quot; or invalid input&lt;br /&gt;
		if ns == 0 then&lt;br /&gt;
			obj.cfg = cfg.ambox -- main namespace&lt;br /&gt;
		elseif ns == 6 then&lt;br /&gt;
			obj.cfg = cfg.imbox -- file namespace&lt;br /&gt;
		elseif ns == 14 then&lt;br /&gt;
			obj.cfg = cfg.cmbox -- category namespace&lt;br /&gt;
		else&lt;br /&gt;
			local nsTable = mw.site.namespaces[ns]&lt;br /&gt;
			if nsTable and nsTable.isTalk then&lt;br /&gt;
				obj.cfg = cfg.tmbox -- any talk namespace&lt;br /&gt;
			else&lt;br /&gt;
				obj.cfg = cfg.ombox -- other namespaces or invalid input&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Set the arguments, and remove all blank arguments except for the ones&lt;br /&gt;
	-- listed in cfg.allowBlankParams.&lt;br /&gt;
	do&lt;br /&gt;
		local newArgs = {}&lt;br /&gt;
		for k, v in pairs(args) do&lt;br /&gt;
			if v ~= &#039;&#039; then&lt;br /&gt;
				newArgs[k] = v&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		for i, param in ipairs(obj.cfg.allowBlankParams or {}) do&lt;br /&gt;
			newArgs[param] = args[param]&lt;br /&gt;
		end&lt;br /&gt;
		obj.args = newArgs&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Define internal data structure.&lt;br /&gt;
	obj.categories = {}&lt;br /&gt;
	obj.classes = {}&lt;br /&gt;
&lt;br /&gt;
	return setmetatable(obj, MessageBox)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function MessageBox:addCat(ns, cat, sort)&lt;br /&gt;
	if not cat then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	if sort then&lt;br /&gt;
		cat = string.format(&#039;[[Category:%s|%s]]&#039;, cat, sort)&lt;br /&gt;
	else&lt;br /&gt;
		cat = string.format(&#039;[[Category:%s]]&#039;, cat)&lt;br /&gt;
	end&lt;br /&gt;
	self.categories[ns] = self.categories[ns] or {}&lt;br /&gt;
	table.insert(self.categories[ns], cat)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function MessageBox:addClass(class)&lt;br /&gt;
	if not class then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	table.insert(self.classes, class)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function MessageBox:setParameters()&lt;br /&gt;
	local args = self.args&lt;br /&gt;
	local cfg = self.cfg&lt;br /&gt;
&lt;br /&gt;
	-- Get type data.&lt;br /&gt;
	self.type = args.type&lt;br /&gt;
	local typeData = cfg.types[self.type]&lt;br /&gt;
	self.invalidTypeError = cfg.showInvalidTypeError&lt;br /&gt;
		and self.type&lt;br /&gt;
		and not typeData&lt;br /&gt;
	typeData = typeData or cfg.types[cfg.default]&lt;br /&gt;
	self.typeClass = typeData.class&lt;br /&gt;
	self.typeImage = typeData.image&lt;br /&gt;
&lt;br /&gt;
	-- Find if the box has been wrongly substituted.&lt;br /&gt;
	self.isSubstituted = cfg.substCheck and args.subst == &#039;SUBST&#039;&lt;br /&gt;
&lt;br /&gt;
	-- Find whether we are using a small message box.&lt;br /&gt;
	self.isSmall = cfg.allowSmall and (&lt;br /&gt;
		cfg.smallParam and args.small == cfg.smallParam&lt;br /&gt;
		or not cfg.smallParam and yesno(args.small)&lt;br /&gt;
	)&lt;br /&gt;
&lt;br /&gt;
	-- Add attributes, classes and styles.&lt;br /&gt;
	if cfg.allowId then&lt;br /&gt;
		self.id = args.id&lt;br /&gt;
	end&lt;br /&gt;
	self:addClass(&lt;br /&gt;
		cfg.usePlainlinksParam and yesno(args.plainlinks or true) and &#039;plainlinks&#039;&lt;br /&gt;
	)&lt;br /&gt;
	for _, class in ipairs(cfg.classes or {}) do&lt;br /&gt;
		self:addClass(class)&lt;br /&gt;
	end&lt;br /&gt;
	if self.isSmall then&lt;br /&gt;
		self:addClass(cfg.smallClass or &#039;mbox-small&#039;)&lt;br /&gt;
	end&lt;br /&gt;
	self:addClass(self.typeClass)&lt;br /&gt;
	self:addClass(args.class)&lt;br /&gt;
	self.style = args.style&lt;br /&gt;
	self.attrs = args.attrs&lt;br /&gt;
&lt;br /&gt;
	-- Set text style.&lt;br /&gt;
	self.textstyle = args.textstyle&lt;br /&gt;
&lt;br /&gt;
	-- Find if we are on the template page or not. This functionality is only&lt;br /&gt;
	-- used if useCollapsibleTextFields is set, or if both cfg.templateCategory&lt;br /&gt;
	-- and cfg.templateCategoryRequireName are set.&lt;br /&gt;
	self.useCollapsibleTextFields = cfg.useCollapsibleTextFields&lt;br /&gt;
	if self.useCollapsibleTextFields&lt;br /&gt;
		or cfg.templateCategory&lt;br /&gt;
		and cfg.templateCategoryRequireName&lt;br /&gt;
	then&lt;br /&gt;
		self.name = args.name&lt;br /&gt;
		if self.name then&lt;br /&gt;
			local templateName = mw.ustring.match(&lt;br /&gt;
				self.name,&lt;br /&gt;
				&#039;^[tT][eE][mM][pP][lL][aA][tT][eE][%s_]*:[%s_]*(.*)$&#039;&lt;br /&gt;
			) or self.name&lt;br /&gt;
			templateName = &#039;Template:&#039; .. templateName&lt;br /&gt;
			self.templateTitle = getTitleObject(templateName)&lt;br /&gt;
		end&lt;br /&gt;
		self.isTemplatePage = self.templateTitle&lt;br /&gt;
			and mw.title.equals(self.title, self.templateTitle)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Process data for collapsible text fields. At the moment these are only&lt;br /&gt;
	-- used in {{ambox}}.&lt;br /&gt;
	if self.useCollapsibleTextFields then&lt;br /&gt;
		-- Get the self.issue value.&lt;br /&gt;
		if self.isSmall and args.smalltext then&lt;br /&gt;
			self.issue = args.smalltext&lt;br /&gt;
		else&lt;br /&gt;
			local sect&lt;br /&gt;
			if args.sect == &#039;&#039; then&lt;br /&gt;
				sect = &#039;This &#039; .. (cfg.sectionDefault or &#039;page&#039;)&lt;br /&gt;
			elseif type(args.sect) == &#039;string&#039; then&lt;br /&gt;
				sect = &#039;This &#039; .. args.sect&lt;br /&gt;
			end&lt;br /&gt;
			local issue = args.issue&lt;br /&gt;
			issue = type(issue) == &#039;string&#039; and issue ~= &#039;&#039; and issue or nil&lt;br /&gt;
			local text = args.text&lt;br /&gt;
			text = type(text) == &#039;string&#039; and text or nil&lt;br /&gt;
			local issues = {}&lt;br /&gt;
			table.insert(issues, sect)&lt;br /&gt;
			table.insert(issues, issue)&lt;br /&gt;
			table.insert(issues, text)&lt;br /&gt;
			self.issue = table.concat(issues, &#039; &#039;)&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		-- Get the self.talk value.&lt;br /&gt;
		local talk = args.talk&lt;br /&gt;
		-- Show talk links on the template page or template subpages if the talk&lt;br /&gt;
		-- parameter is blank.&lt;br /&gt;
		if talk == &#039;&#039;&lt;br /&gt;
			and self.templateTitle&lt;br /&gt;
			and (&lt;br /&gt;
				mw.title.equals(self.templateTitle, self.title)&lt;br /&gt;
				or self.title:isSubpageOf(self.templateTitle)&lt;br /&gt;
			)&lt;br /&gt;
		then&lt;br /&gt;
			talk = &#039;#&#039;&lt;br /&gt;
		elseif talk == &#039;&#039; then&lt;br /&gt;
			talk = nil&lt;br /&gt;
		end&lt;br /&gt;
		if talk then&lt;br /&gt;
			-- If the talk value is a talk page, make a link to that page. Else&lt;br /&gt;
			-- assume that it&#039;s a section heading, and make a link to the talk&lt;br /&gt;
			-- page of the current page with that section heading.&lt;br /&gt;
			local talkTitle = getTitleObject(talk)&lt;br /&gt;
			local talkArgIsTalkPage = true&lt;br /&gt;
			if not talkTitle or not talkTitle.isTalkPage then&lt;br /&gt;
				talkArgIsTalkPage = false&lt;br /&gt;
				talkTitle = getTitleObject(&lt;br /&gt;
					self.title.text,&lt;br /&gt;
					mw.site.namespaces[self.title.namespace].talk.id&lt;br /&gt;
				)&lt;br /&gt;
			end&lt;br /&gt;
			if talkTitle and talkTitle.exists then&lt;br /&gt;
				local talkText = &#039;Relevant discussion may be found on&#039;&lt;br /&gt;
				if talkArgIsTalkPage then&lt;br /&gt;
					talkText = string.format(&lt;br /&gt;
						&#039;%s [[%s|%s]].&#039;,&lt;br /&gt;
						talkText,&lt;br /&gt;
						talk,&lt;br /&gt;
						talkTitle.prefixedText&lt;br /&gt;
					)&lt;br /&gt;
				else&lt;br /&gt;
					talkText = string.format(&lt;br /&gt;
						&#039;%s the [[%s#%s|talk page]].&#039;,&lt;br /&gt;
						talkText,&lt;br /&gt;
						talkTitle.prefixedText,&lt;br /&gt;
						talk&lt;br /&gt;
					)&lt;br /&gt;
				end&lt;br /&gt;
				self.talk = talkText&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		-- Get other values.&lt;br /&gt;
		self.fix = args.fix ~= &#039;&#039; and args.fix or nil&lt;br /&gt;
		local date&lt;br /&gt;
		if args.date and args.date ~= &#039;&#039; then&lt;br /&gt;
			date = args.date&lt;br /&gt;
		elseif args.date == &#039;&#039; and self.isTemplatePage then&lt;br /&gt;
			date = lang:formatDate(&#039;F Y&#039;)&lt;br /&gt;
		end&lt;br /&gt;
		if date then&lt;br /&gt;
			self.date = string.format(&amp;quot; &amp;lt;small&amp;gt;&#039;&#039;(%s)&#039;&#039;&amp;lt;/small&amp;gt;&amp;quot;, date)&lt;br /&gt;
		end&lt;br /&gt;
		self.info = args.info&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Set the non-collapsible text field. At the moment this is used by all box&lt;br /&gt;
	-- types other than ambox, and also by ambox when small=yes.&lt;br /&gt;
	if self.isSmall then&lt;br /&gt;
		self.text = args.smalltext or args.text&lt;br /&gt;
	else&lt;br /&gt;
		self.text = args.text&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Set the below row.&lt;br /&gt;
	self.below = cfg.below and args.below&lt;br /&gt;
&lt;br /&gt;
	-- General image settings.&lt;br /&gt;
	self.imageCellDiv = not self.isSmall and cfg.imageCellDiv&lt;br /&gt;
	self.imageEmptyCell = cfg.imageEmptyCell&lt;br /&gt;
	if cfg.imageEmptyCellStyle then&lt;br /&gt;
		self.imageEmptyCellStyle = &#039;border:none;padding:0px;width:1px&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Left image settings.&lt;br /&gt;
	local imageLeft = self.isSmall and args.smallimage or args.image&lt;br /&gt;
	if cfg.imageCheckBlank and imageLeft ~= &#039;blank&#039; and imageLeft ~= &#039;none&#039;&lt;br /&gt;
		or not cfg.imageCheckBlank and imageLeft ~= &#039;none&#039;&lt;br /&gt;
	then&lt;br /&gt;
		self.imageLeft = imageLeft&lt;br /&gt;
		if not imageLeft then&lt;br /&gt;
			local imageSize = self.isSmall&lt;br /&gt;
				and (cfg.imageSmallSize or &#039;30x30px&#039;)&lt;br /&gt;
				or &#039;40x40px&#039;&lt;br /&gt;
			self.imageLeft = string.format(&#039;[[File:%s|%s|link=|alt=]]&#039;, self.typeImage&lt;br /&gt;
				or &#039;Imbox notice.png&#039;, imageSize)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Right image settings.&lt;br /&gt;
	local imageRight = self.isSmall and args.smallimageright or args.imageright&lt;br /&gt;
	if not (cfg.imageRightNone and imageRight == &#039;none&#039;) then&lt;br /&gt;
		self.imageRight = imageRight&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function MessageBox:setMainspaceCategories()&lt;br /&gt;
	local args = self.args&lt;br /&gt;
	local cfg = self.cfg&lt;br /&gt;
&lt;br /&gt;
	if not cfg.allowMainspaceCategories then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local nums = {}&lt;br /&gt;
	for _, prefix in ipairs{&#039;cat&#039;, &#039;category&#039;, &#039;all&#039;} do&lt;br /&gt;
		args[prefix .. &#039;1&#039;] = args[prefix]&lt;br /&gt;
		nums = union(nums, getArgNums(args, prefix))&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- The following is roughly equivalent to the old {{Ambox/category}}.&lt;br /&gt;
	local date = args.date&lt;br /&gt;
	date = type(date) == &#039;string&#039; and date&lt;br /&gt;
	local preposition = &#039;from&#039;&lt;br /&gt;
	for _, num in ipairs(nums) do&lt;br /&gt;
		local mainCat = args[&#039;cat&#039; .. tostring(num)]&lt;br /&gt;
			or args[&#039;category&#039; .. tostring(num)]&lt;br /&gt;
		local allCat = args[&#039;all&#039; .. tostring(num)]&lt;br /&gt;
		mainCat = type(mainCat) == &#039;string&#039; and mainCat&lt;br /&gt;
		allCat = type(allCat) == &#039;string&#039; and allCat&lt;br /&gt;
		if mainCat and date and date ~= &#039;&#039; then&lt;br /&gt;
			local catTitle = string.format(&#039;%s %s %s&#039;, mainCat, preposition, date)&lt;br /&gt;
			self:addCat(0, catTitle)&lt;br /&gt;
			catTitle = getTitleObject(&#039;Category:&#039; .. catTitle)&lt;br /&gt;
			if not catTitle or not catTitle.exists then&lt;br /&gt;
				self:addCat(0, &#039;Articles with invalid date parameter in template&#039;)&lt;br /&gt;
			end&lt;br /&gt;
		elseif mainCat and (not date or date == &#039;&#039;) then&lt;br /&gt;
			self:addCat(0, mainCat)&lt;br /&gt;
		end&lt;br /&gt;
		if allCat then&lt;br /&gt;
			self:addCat(0, allCat)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function MessageBox:setTemplateCategories()&lt;br /&gt;
	local args = self.args&lt;br /&gt;
	local cfg = self.cfg&lt;br /&gt;
&lt;br /&gt;
	-- Add template categories.&lt;br /&gt;
	if cfg.templateCategory then&lt;br /&gt;
		if cfg.templateCategoryRequireName then&lt;br /&gt;
			if self.isTemplatePage then&lt;br /&gt;
				self:addCat(10, cfg.templateCategory)&lt;br /&gt;
			end&lt;br /&gt;
		elseif not self.title.isSubpage then&lt;br /&gt;
			self:addCat(10, cfg.templateCategory)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add template error categories.&lt;br /&gt;
	if cfg.templateErrorCategory then&lt;br /&gt;
		local templateErrorCategory = cfg.templateErrorCategory&lt;br /&gt;
		local templateCat, templateSort&lt;br /&gt;
		if not self.name and not self.title.isSubpage then&lt;br /&gt;
			templateCat = templateErrorCategory&lt;br /&gt;
		elseif self.isTemplatePage then&lt;br /&gt;
			local paramsToCheck = cfg.templateErrorParamsToCheck or {}&lt;br /&gt;
			local count = 0&lt;br /&gt;
			for i, param in ipairs(paramsToCheck) do&lt;br /&gt;
				if not args[param] then&lt;br /&gt;
					count = count + 1&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			if count &amp;gt; 0 then&lt;br /&gt;
				templateCat = templateErrorCategory&lt;br /&gt;
				templateSort = tostring(count)&lt;br /&gt;
			end&lt;br /&gt;
			if self.categoryNums and #self.categoryNums &amp;gt; 0 then&lt;br /&gt;
				templateCat = templateErrorCategory&lt;br /&gt;
				templateSort = &#039;C&#039;&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		self:addCat(10, templateCat, templateSort)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function MessageBox:setAllNamespaceCategories()&lt;br /&gt;
	-- Set categories for all namespaces.&lt;br /&gt;
	if self.invalidTypeError then&lt;br /&gt;
		local allSort = (self.title.namespace == 0 and &#039;Main:&#039; or &#039;&#039;) .. self.title.prefixedText&lt;br /&gt;
		self:addCat(&#039;all&#039;, &#039;Wikipedia message box parameter needs fixing&#039;, allSort)&lt;br /&gt;
	end&lt;br /&gt;
	if self.isSubstituted then&lt;br /&gt;
		self:addCat(&#039;all&#039;, &#039;Pages with incorrectly substituted templates&#039;)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function MessageBox:setCategories()&lt;br /&gt;
	if self.title.namespace == 0 then&lt;br /&gt;
		self:setMainspaceCategories()&lt;br /&gt;
	elseif self.title.namespace == 10 then&lt;br /&gt;
		self:setTemplateCategories()&lt;br /&gt;
	end&lt;br /&gt;
	self:setAllNamespaceCategories()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function MessageBox:renderCategories()&lt;br /&gt;
	-- Convert category tables to strings and pass them through&lt;br /&gt;
	-- [[Module:Category handler]].&lt;br /&gt;
	return categoryHandler{&lt;br /&gt;
		main = table.concat(self.categories[0] or {}),&lt;br /&gt;
		template = table.concat(self.categories[10] or {}),&lt;br /&gt;
		all = table.concat(self.categories.all or {}),&lt;br /&gt;
		nocat = self.args.nocat,&lt;br /&gt;
		page = self.args.page&lt;br /&gt;
	}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function MessageBox:export()&lt;br /&gt;
	local root = mw.html.create()&lt;br /&gt;
&lt;br /&gt;
	-- Add the subst check error.&lt;br /&gt;
	if self.isSubstituted and self.name then&lt;br /&gt;
		root:tag(&#039;b&#039;)&lt;br /&gt;
			:addClass(&#039;error&#039;)&lt;br /&gt;
			:wikitext(string.format(&lt;br /&gt;
				&#039;Template &amp;lt;code&amp;gt;%s[[Template:%s|%s]]%s&amp;lt;/code&amp;gt; has been incorrectly substituted.&#039;,&lt;br /&gt;
				mw.text.nowiki(&#039;{{&#039;), self.name, self.name, mw.text.nowiki(&#039;}}&#039;)&lt;br /&gt;
			))&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Create the box table.&lt;br /&gt;
	local boxTable = root:tag(&#039;table&#039;)&lt;br /&gt;
	boxTable:attr(&#039;id&#039;, self.id or nil)&lt;br /&gt;
	for i, class in ipairs(self.classes or {}) do&lt;br /&gt;
		boxTable:addClass(class or nil)&lt;br /&gt;
	end&lt;br /&gt;
	boxTable&lt;br /&gt;
		:cssText(self.style or nil)&lt;br /&gt;
		:attr(&#039;role&#039;, &#039;presentation&#039;)&lt;br /&gt;
&lt;br /&gt;
	if self.attrs then&lt;br /&gt;
		boxTable:attr(self.attrs)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add the left-hand image.&lt;br /&gt;
	local row = boxTable:tag(&#039;tr&#039;)&lt;br /&gt;
	if self.imageLeft then&lt;br /&gt;
		local imageLeftCell = row:tag(&#039;td&#039;):addClass(&#039;mbox-image&#039;)&lt;br /&gt;
		if self.imageCellDiv then&lt;br /&gt;
			-- If we are using a div, redefine imageLeftCell so that the image&lt;br /&gt;
			-- is inside it. Divs use style=&amp;quot;width: 52px;&amp;quot;, which limits the&lt;br /&gt;
			-- image width to 52px. If any images in a div are wider than that,&lt;br /&gt;
			-- they may overlap with the text or cause other display problems.&lt;br /&gt;
			imageLeftCell = imageLeftCell:tag(&#039;div&#039;):css(&#039;width&#039;, &#039;52px&#039;)&lt;br /&gt;
		end&lt;br /&gt;
		imageLeftCell:wikitext(self.imageLeft or nil)&lt;br /&gt;
	elseif self.imageEmptyCell then&lt;br /&gt;
		-- Some message boxes define an empty cell if no image is specified, and&lt;br /&gt;
		-- some don&#039;t. The old template code in templates where empty cells are&lt;br /&gt;
		-- specified gives the following hint: &amp;quot;No image. Cell with some width&lt;br /&gt;
		-- or padding necessary for text cell to have 100% width.&amp;quot;&lt;br /&gt;
		row:tag(&#039;td&#039;)&lt;br /&gt;
			:addClass(&#039;mbox-empty-cell&#039;)&lt;br /&gt;
			:cssText(self.imageEmptyCellStyle or nil)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add the text.&lt;br /&gt;
	local textCell = row:tag(&#039;td&#039;):addClass(&#039;mbox-text&#039;)&lt;br /&gt;
	if self.useCollapsibleTextFields then&lt;br /&gt;
		-- The message box uses advanced text parameters that allow things to be&lt;br /&gt;
		-- collapsible. At the moment, only ambox uses this.&lt;br /&gt;
		textCell:cssText(self.textstyle or nil)&lt;br /&gt;
		local textCellSpan = textCell:tag(&#039;span&#039;)&lt;br /&gt;
		textCellSpan&lt;br /&gt;
			:addClass(&#039;mbox-text-span&#039;)&lt;br /&gt;
			:wikitext(self.issue or nil)&lt;br /&gt;
		if not self.isSmall then&lt;br /&gt;
			textCellSpan:tag(&#039;span&#039;)&lt;br /&gt;
				:addClass(&#039;hide-when-compact&#039;)&lt;br /&gt;
				:wikitext(self.talk and (&#039; &#039; .. self.talk) or nil)&lt;br /&gt;
				:wikitext(self.fix and (&#039; &#039; .. self.fix) or nil)&lt;br /&gt;
		end&lt;br /&gt;
		textCellSpan:wikitext(self.date and (&#039; &#039; .. self.date) or nil)&lt;br /&gt;
		if not self.isSmall then&lt;br /&gt;
			textCellSpan&lt;br /&gt;
				:tag(&#039;span&#039;)&lt;br /&gt;
				:addClass(&#039;hide-when-compact&#039;)&lt;br /&gt;
				:wikitext(self.info and (&#039; &#039; .. self.info) or nil)&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		-- Default text formatting - anything goes.&lt;br /&gt;
		textCell&lt;br /&gt;
			:cssText(self.textstyle or nil)&lt;br /&gt;
			:wikitext(self.text or nil)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add the right-hand image.&lt;br /&gt;
	if self.imageRight then&lt;br /&gt;
		local imageRightCell = row:tag(&#039;td&#039;):addClass(&#039;mbox-imageright&#039;)&lt;br /&gt;
		if self.imageCellDiv then&lt;br /&gt;
			-- If we are using a div, redefine imageRightCell so that the image&lt;br /&gt;
			-- is inside it.&lt;br /&gt;
			imageRightCell = imageRightCell:tag(&#039;div&#039;):css(&#039;width&#039;, &#039;52px&#039;)&lt;br /&gt;
		end&lt;br /&gt;
		imageRightCell&lt;br /&gt;
			:wikitext(self.imageRight or nil)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add the below row.&lt;br /&gt;
	if self.below then&lt;br /&gt;
		boxTable:tag(&#039;tr&#039;)&lt;br /&gt;
			:tag(&#039;td&#039;)&lt;br /&gt;
				:attr(&#039;colspan&#039;, self.imageRight and &#039;3&#039; or &#039;2&#039;)&lt;br /&gt;
				:addClass(&#039;mbox-text&#039;)&lt;br /&gt;
				:cssText(self.textstyle or nil)&lt;br /&gt;
				:wikitext(self.below or nil)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add error message for invalid type parameters.&lt;br /&gt;
	if self.invalidTypeError then&lt;br /&gt;
		root:tag(&#039;div&#039;)&lt;br /&gt;
			:css(&#039;text-align&#039;, &#039;center&#039;)&lt;br /&gt;
			:wikitext(string.format(&lt;br /&gt;
				&#039;This message box is using an invalid &amp;quot;type=%s&amp;quot; parameter and needs fixing.&#039;,&lt;br /&gt;
				self.type or &#039;&#039;&lt;br /&gt;
			))&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add categories.&lt;br /&gt;
	root:wikitext(self:renderCategories() or nil)&lt;br /&gt;
&lt;br /&gt;
	return tostring(root)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Exports&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local p, mt = {}, {}&lt;br /&gt;
&lt;br /&gt;
function p._exportClasses()&lt;br /&gt;
	-- For testing.&lt;br /&gt;
	return {&lt;br /&gt;
		MessageBox = MessageBox&lt;br /&gt;
	}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(boxType, args, cfgTables)&lt;br /&gt;
	local box = MessageBox.new(boxType, args, cfgTables or mw.loadData(&#039;Module:Message box/configuration&#039;))&lt;br /&gt;
	box:setParameters()&lt;br /&gt;
	box:setCategories()&lt;br /&gt;
	return box:export()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function mt.__index(t, k)&lt;br /&gt;
	return function (frame)&lt;br /&gt;
		if not getArgs then&lt;br /&gt;
			getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
		end&lt;br /&gt;
		return t.main(k, getArgs(frame, {trim = false, removeBlanks = false}))&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return setmetatable(p, mt)&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Main&amp;diff=2408</id>
		<title>Module:Main</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Main&amp;diff=2408"/>
		<updated>2015-07-09T17:07:24Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[&lt;br /&gt;
-- This module produces a link to a main article or articles. It implements the&lt;br /&gt;
-- template {{main}}.&lt;br /&gt;
-- &lt;br /&gt;
-- If the module is used in category or category talk space, it produces &amp;quot;The&lt;br /&gt;
-- main article for this category is xxx&amp;quot;. Otherwise, it produces&lt;br /&gt;
-- &amp;quot;Main article: xxx&amp;quot;.&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
local mHatnote = require(&#039;Module:Hatnote&#039;)&lt;br /&gt;
local mTableTools -- lazily initialise&lt;br /&gt;
local mArguments -- lazily initialise&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	mTableTools = require(&#039;Module:TableTools&#039;)&lt;br /&gt;
	mArguments = require(&#039;Module:Arguments&#039;)&lt;br /&gt;
	local args = mArguments.getArgs(frame, {parentOnly = true})&lt;br /&gt;
	local pages = {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		if type(k) == &#039;number&#039; then&lt;br /&gt;
			local display = args[&#039;l&#039; .. tostring(k)]&lt;br /&gt;
			local page = {v, display}&lt;br /&gt;
			pages[k] = page&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	pages = mTableTools.compressSparseArray(pages)&lt;br /&gt;
	local options = {&lt;br /&gt;
		selfref = args.selfref&lt;br /&gt;
	}&lt;br /&gt;
	return p._main(options, unpack(pages))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(options, ...)&lt;br /&gt;
	-- Get the list of pages. If no first page was specified we use the current&lt;br /&gt;
	-- page name.&lt;br /&gt;
	local pages = {...}&lt;br /&gt;
	local currentTitle = mw.title.getCurrentTitle()&lt;br /&gt;
	local firstPageTable = pages[1]&lt;br /&gt;
	local firstPage&lt;br /&gt;
	if firstPageTable then&lt;br /&gt;
		firstPage = firstPageTable[1]&lt;br /&gt;
	else&lt;br /&gt;
		firstPage = currentTitle.text&lt;br /&gt;
		firstPageTable = {firstPage}&lt;br /&gt;
		pages[1] = firstPageTable&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Find the pagetype.&lt;br /&gt;
	local firstPageNs = mHatnote.findNamespaceId(firstPage)&lt;br /&gt;
	local pagetype = firstPageNs == 0 and &#039;article&#039; or &#039;page&#039;&lt;br /&gt;
&lt;br /&gt;
	-- Make the formatted link text&lt;br /&gt;
	local links = mHatnote.formatPageTables(unpack(pages))&lt;br /&gt;
	links = mw.text.listToText(links)&lt;br /&gt;
&lt;br /&gt;
	-- Build the text.&lt;br /&gt;
	local isPlural = #pages &amp;gt; 1&lt;br /&gt;
	local currentNs = currentTitle.namespace&lt;br /&gt;
	local isCategoryNamespace = currentNs - currentNs % 2 == 14&lt;br /&gt;
	local stringToFormat&lt;br /&gt;
	if isCategoryNamespace then&lt;br /&gt;
		if isPlural then&lt;br /&gt;
			stringToFormat = &#039;The main %ss for this&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Categorization|category]] are %s&#039;&lt;br /&gt;
		else&lt;br /&gt;
			stringToFormat = &#039;The main %s for this&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Categorization|category]] is %s&#039;&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		if isPlural then&lt;br /&gt;
			stringToFormat = &#039;Main %ss: %s&#039;&lt;br /&gt;
		else&lt;br /&gt;
			stringToFormat = &#039;Main %s: %s&#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local text = string.format(stringToFormat, pagetype, links)&lt;br /&gt;
&lt;br /&gt;
	-- Process the options and pass the text to the _rellink function in&lt;br /&gt;
	-- [[Module:Hatnote]].&lt;br /&gt;
	options = options or {}&lt;br /&gt;
	local hnOptions = {&lt;br /&gt;
		extraclasses = &#039;relarticle mainarticle&#039;,&lt;br /&gt;
		selfref = options.selfref&lt;br /&gt;
	}&lt;br /&gt;
	return mHatnote._hatnote(text, hnOptions)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Lua_banner&amp;diff=2406</id>
		<title>Module:Lua banner</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Lua_banner&amp;diff=2406"/>
		<updated>2015-07-09T17:07:23Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module implements the {{lua}} template.&lt;br /&gt;
&lt;br /&gt;
local yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
local mList = require(&#039;Module:List&#039;)&lt;br /&gt;
local mTableTools = require(&#039;Module:TableTools&#039;)&lt;br /&gt;
local mMessageBox = require(&#039;Module:Message box&#039;)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local origArgs = frame:getParent().args&lt;br /&gt;
	local args = {}&lt;br /&gt;
	for k, v in pairs(origArgs) do&lt;br /&gt;
		v = v:match(&#039;^%s*(.-)%s*$&#039;)&lt;br /&gt;
		if v ~= &#039;&#039; then&lt;br /&gt;
			args[k] = v&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return p._main(args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(args)&lt;br /&gt;
	local modules = mTableTools.compressSparseArray(args)&lt;br /&gt;
	local box = p.renderBox(modules)&lt;br /&gt;
	local trackingCategories = p.renderTrackingCategories(args, modules)&lt;br /&gt;
	return box .. trackingCategories&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.renderBox(modules)&lt;br /&gt;
	local boxArgs = {}&lt;br /&gt;
	if #modules &amp;lt; 1 then&lt;br /&gt;
		boxArgs.text = &#039;&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Error: no modules specified&amp;lt;/strong&amp;gt;&#039;&lt;br /&gt;
	else&lt;br /&gt;
		local moduleLinks = {}&lt;br /&gt;
		for i, module in ipairs(modules) do&lt;br /&gt;
			moduleLinks[i] = string.format(&#039;[[:%s]]&#039;, module)&lt;br /&gt;
		end&lt;br /&gt;
		local moduleList = mList.makeList(&#039;bulleted&#039;, moduleLinks)&lt;br /&gt;
		boxArgs.text = &#039;Uses [[Wikipedia:Lua|Lua]]:\n&#039; .. moduleList&lt;br /&gt;
	end&lt;br /&gt;
	boxArgs.type = &#039;notice&#039;&lt;br /&gt;
	boxArgs.small = true&lt;br /&gt;
	boxArgs.image = &#039;[[File:Lua-logo-nolabel.svg|30px|alt=Lua logo|link=Wikipedia:Lua]]&#039;&lt;br /&gt;
	return mMessageBox.main(&#039;mbox&#039;, boxArgs)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.renderTrackingCategories(args, modules, titleObj)&lt;br /&gt;
	if yesno(args.nocat) then&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local cats = {}&lt;br /&gt;
	&lt;br /&gt;
	-- Error category&lt;br /&gt;
	if #modules &amp;lt; 1 then&lt;br /&gt;
		cats[#cats + 1] = &#039;Lua templates with errors&#039;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Lua templates category&lt;br /&gt;
	titleObj = titleObj or mw.title.getCurrentTitle()&lt;br /&gt;
	local subpageBlacklist = {&lt;br /&gt;
		doc = true,&lt;br /&gt;
		sandbox = true,&lt;br /&gt;
		sandbox2 = true,&lt;br /&gt;
		testcases = true&lt;br /&gt;
	}&lt;br /&gt;
	if titleObj.namespace == 10 &lt;br /&gt;
		and not subpageBlacklist[titleObj.subpageText]&lt;br /&gt;
	then&lt;br /&gt;
		local category = args.category&lt;br /&gt;
		if not category then&lt;br /&gt;
			local categories = {&lt;br /&gt;
				[&#039;Module:String&#039;] = &#039;Lua String-based templates&#039;,&lt;br /&gt;
				[&#039;Module:Math&#039;] = &#039;Templates based on the Math Lua module&#039;,&lt;br /&gt;
				[&#039;Module:BaseConvert&#039;] = &#039;Templates based on the BaseConvert Lua module&#039;,&lt;br /&gt;
				[&#039;Module:Citation&#039;] = &#039;Lua-based citation templates&#039;&lt;br /&gt;
			}&lt;br /&gt;
			categories[&#039;Module:Citation/CS1&#039;] = categories[&#039;Module:Citation&#039;]&lt;br /&gt;
			category = modules[1] and categories[modules[1]]&lt;br /&gt;
			category = category or &#039;Lua-based templates&#039;&lt;br /&gt;
		end&lt;br /&gt;
		cats[#cats + 1] = category&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	for i, cat in ipairs(cats) do&lt;br /&gt;
		cats[i] = string.format(&#039;[[Category:%s]]&#039;, cat)&lt;br /&gt;
	end&lt;br /&gt;
	return table.concat(cats)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:List&amp;diff=2404</id>
		<title>Module:List</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:List&amp;diff=2404"/>
		<updated>2015-07-09T17:07:23Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module outputs different kinds of lists. At the moment, bulleted,&lt;br /&gt;
-- unbulleted, horizontal, ordered, and horizontal ordered lists are supported.&lt;br /&gt;
&lt;br /&gt;
local libUtil = require(&#039;libraryUtil&#039;)&lt;br /&gt;
local checkType = libUtil.checkType&lt;br /&gt;
local mTableTools = require(&#039;Module:TableTools&#039;)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local listTypes = {&lt;br /&gt;
	[&#039;bulleted&#039;] = true,&lt;br /&gt;
	[&#039;unbulleted&#039;] = true,&lt;br /&gt;
	[&#039;horizontal&#039;] = true,&lt;br /&gt;
	[&#039;ordered&#039;] = true,&lt;br /&gt;
	[&#039;horizontal_ordered&#039;] = true&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
function p.makeListData(listType, args)&lt;br /&gt;
	-- Constructs a data table to be passed to p.renderList.&lt;br /&gt;
	local data = {}&lt;br /&gt;
&lt;br /&gt;
	-- Classes&lt;br /&gt;
	data.classes = {}&lt;br /&gt;
	if listType == &#039;horizontal&#039; or listType == &#039;horizontal_ordered&#039; then&lt;br /&gt;
		table.insert(data.classes, &#039;hlist&#039;)&lt;br /&gt;
	elseif listType == &#039;unbulleted&#039; then&lt;br /&gt;
		table.insert(data.classes, &#039;plainlist&#039;)&lt;br /&gt;
	end&lt;br /&gt;
	table.insert(data.classes, args.class)&lt;br /&gt;
&lt;br /&gt;
	-- Main div style&lt;br /&gt;
	data.style = args.style&lt;br /&gt;
&lt;br /&gt;
	-- Indent for horizontal lists&lt;br /&gt;
	if listType == &#039;horizontal&#039; or listType == &#039;horizontal_ordered&#039; then&lt;br /&gt;
		local indent = tonumber(args.indent)&lt;br /&gt;
		indent = indent and indent * 1.6 or 0&lt;br /&gt;
		if indent &amp;gt; 0 then&lt;br /&gt;
			data.marginLeft = indent .. &#039;em&#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- List style types for ordered lists&lt;br /&gt;
	-- This could be &amp;quot;1, 2, 3&amp;quot;, &amp;quot;a, b, c&amp;quot;, or a number of others. The list style&lt;br /&gt;
	-- type is either set by the &amp;quot;type&amp;quot; attribute or the &amp;quot;list-style-type&amp;quot; CSS&lt;br /&gt;
	-- property.&lt;br /&gt;
	if listType == &#039;ordered&#039; or listType == &#039;horizontal_ordered&#039; then &lt;br /&gt;
		data.listStyleType = args.list_style_type or args[&#039;list-style-type&#039;]&lt;br /&gt;
		data.type = args[&#039;type&#039;]&lt;br /&gt;
&lt;br /&gt;
		-- Detect invalid type attributes and attempt to convert them to&lt;br /&gt;
		-- list-style-type CSS properties.&lt;br /&gt;
		if data.type &lt;br /&gt;
			and not data.listStyleType&lt;br /&gt;
			and not tostring(data.type):find(&#039;^%s*[1AaIi]%s*$&#039;)&lt;br /&gt;
		then&lt;br /&gt;
			data.listStyleType = data.type&lt;br /&gt;
			data.type = nil&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- List tag type&lt;br /&gt;
	if listType == &#039;ordered&#039; or listType == &#039;horizontal_ordered&#039; then&lt;br /&gt;
		data.listTag = &#039;ol&#039;&lt;br /&gt;
	else&lt;br /&gt;
		data.listTag = &#039;ul&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Start number for ordered lists&lt;br /&gt;
	data.start = args.start&lt;br /&gt;
	if listType == &#039;horizontal_ordered&#039; then&lt;br /&gt;
		-- Apply fix to get start numbers working with horizontal ordered lists.&lt;br /&gt;
		local startNum = tonumber(data.start)&lt;br /&gt;
		if startNum then&lt;br /&gt;
			data.counterReset = &#039;listitem &#039; .. tostring(startNum - 1)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- List style&lt;br /&gt;
	 -- ul_style and ol_style are included for backwards compatibility. No&lt;br /&gt;
	 -- distinction is made for ordered or unordered lists.&lt;br /&gt;
	data.listStyle = args.list_style&lt;br /&gt;
&lt;br /&gt;
	-- List items&lt;br /&gt;
	-- li_style is included for backwards compatibility. item_style was included&lt;br /&gt;
	-- to be easier to understand for non-coders.&lt;br /&gt;
	data.itemStyle = args.item_style or args.li_style&lt;br /&gt;
	data.items = {}&lt;br /&gt;
	for i, num in ipairs(mTableTools.numKeys(args)) do&lt;br /&gt;
		local item = {}&lt;br /&gt;
		item.content = args[num]&lt;br /&gt;
		item.style = args[&#039;item&#039; .. tostring(num) .. &#039;_style&#039;]&lt;br /&gt;
			or args[&#039;item_style&#039; .. tostring(num)]&lt;br /&gt;
		item.value = args[&#039;item&#039; .. tostring(num) .. &#039;_value&#039;]&lt;br /&gt;
			or args[&#039;item_value&#039; .. tostring(num)]&lt;br /&gt;
		table.insert(data.items, item)&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return data&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.renderList(data)&lt;br /&gt;
	-- Renders the list HTML.&lt;br /&gt;
	&lt;br /&gt;
	-- Return the blank string if there are no list items.&lt;br /&gt;
	if type(data.items) ~= &#039;table&#039; or #data.items &amp;lt; 1 then&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Render the main div tag.&lt;br /&gt;
	local root = mw.html.create(&#039;div&#039;)&lt;br /&gt;
	for i, class in ipairs(data.classes or {}) do&lt;br /&gt;
		root:addClass(class)&lt;br /&gt;
	end&lt;br /&gt;
	root:css{[&#039;margin-left&#039;] = data.marginLeft}&lt;br /&gt;
	if data.style then&lt;br /&gt;
		root:cssText(data.style)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Render the list tag.&lt;br /&gt;
	local list = root:tag(data.listTag or &#039;ul&#039;)&lt;br /&gt;
	list&lt;br /&gt;
		:attr{start = data.start, type = data.type}&lt;br /&gt;
		:css{&lt;br /&gt;
			[&#039;counter-reset&#039;] = data.counterReset,&lt;br /&gt;
			[&#039;list-style-type&#039;] = data.listStyleType&lt;br /&gt;
		}&lt;br /&gt;
	if data.listStyle then&lt;br /&gt;
		list:cssText(data.listStyle)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Render the list items&lt;br /&gt;
	for i, t in ipairs(data.items or {}) do&lt;br /&gt;
		local item = list:tag(&#039;li&#039;)&lt;br /&gt;
		if data.itemStyle then&lt;br /&gt;
			item:cssText(data.itemStyle)&lt;br /&gt;
		end&lt;br /&gt;
		if t.style then&lt;br /&gt;
			item:cssText(t.style)&lt;br /&gt;
		end&lt;br /&gt;
		item&lt;br /&gt;
			:attr{value = t.value}&lt;br /&gt;
			:wikitext(t.content)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return tostring(root)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.renderTrackingCategories(args)&lt;br /&gt;
	local isDeprecated = false -- Tracks deprecated parameters.&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		k = tostring(k)&lt;br /&gt;
		if k:find(&#039;^item_style%d+$&#039;) or k:find(&#039;^item_value%d+$&#039;) then&lt;br /&gt;
			isDeprecated = true&lt;br /&gt;
			break&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local ret = &#039;&#039;&lt;br /&gt;
	if isDeprecated then&lt;br /&gt;
		ret = ret .. &#039;[[Category:List templates with deprecated parameters]]&#039;&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.makeList(listType, args)&lt;br /&gt;
	if not listType or not listTypes[listType] then&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&amp;quot;bad argument #1 to &#039;makeList&#039; (&#039;%s&#039; is not a valid list type)&amp;quot;,&lt;br /&gt;
			tostring(listType)&lt;br /&gt;
		), 2)&lt;br /&gt;
	end&lt;br /&gt;
	checkType(&#039;makeList&#039;, 2, args, &#039;table&#039;)&lt;br /&gt;
	local data = p.makeListData(listType, args)&lt;br /&gt;
	local list = p.renderList(data)&lt;br /&gt;
	local trackingCategories = p.renderTrackingCategories(args)&lt;br /&gt;
	return list .. trackingCategories&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
for listType in pairs(listTypes) do&lt;br /&gt;
	p[listType] = function (frame)&lt;br /&gt;
		local mArguments = require(&#039;Module:Arguments&#039;)&lt;br /&gt;
		local origArgs = mArguments.getArgs(frame)&lt;br /&gt;
		-- Copy all the arguments to a new table, for faster indexing.&lt;br /&gt;
		local args = {}&lt;br /&gt;
		for k, v in pairs(origArgs) do&lt;br /&gt;
			args[k] = v&lt;br /&gt;
		end&lt;br /&gt;
		return p.makeList(listType, args)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Hatnote&amp;diff=2402</id>
		<title>Module:Hatnote</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Hatnote&amp;diff=2402"/>
		<updated>2015-07-09T17:07:23Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--------------------------------------------------------------------------------&lt;br /&gt;
--                              Module:Hatnote                                --&lt;br /&gt;
--                                                                            --&lt;br /&gt;
-- This module produces hatnote links and links to related articles. It       --&lt;br /&gt;
-- implements the {{hatnote}} and {{format link}} meta-templates and includes --&lt;br /&gt;
-- helper functions for other Lua hatnote modules.                            --&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local libraryUtil = require(&#039;libraryUtil&#039;)&lt;br /&gt;
local checkType = libraryUtil.checkType&lt;br /&gt;
local mArguments -- lazily initialise [[Module:Arguments]]&lt;br /&gt;
local yesno -- lazily initialise [[Module:Yesno]]&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Helper functions&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local function getArgs(frame)&lt;br /&gt;
	-- Fetches the arguments from the parent frame. Whitespace is trimmed and&lt;br /&gt;
	-- blanks are removed.&lt;br /&gt;
	mArguments = require(&#039;Module:Arguments&#039;)&lt;br /&gt;
	return mArguments.getArgs(frame, {parentOnly = true})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function removeInitialColon(s)&lt;br /&gt;
	-- Removes the initial colon from a string, if present.&lt;br /&gt;
	return s:match(&#039;^:?(.*)&#039;)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.findNamespaceId(link, removeColon)&lt;br /&gt;
	-- Finds the namespace id (namespace number) of a link or a pagename. This&lt;br /&gt;
	-- function will not work if the link is enclosed in double brackets. Colons&lt;br /&gt;
	-- are trimmed from the start of the link by default. To skip colon&lt;br /&gt;
	-- trimming, set the removeColon parameter to true.&lt;br /&gt;
	checkType(&#039;findNamespaceId&#039;, 1, link, &#039;string&#039;)&lt;br /&gt;
	checkType(&#039;findNamespaceId&#039;, 2, removeColon, &#039;boolean&#039;, true)&lt;br /&gt;
	if removeColon ~= false then&lt;br /&gt;
		link = removeInitialColon(link)&lt;br /&gt;
	end&lt;br /&gt;
	local namespace = link:match(&#039;^(.-):&#039;)&lt;br /&gt;
	if namespace then&lt;br /&gt;
		local nsTable = mw.site.namespaces[namespace]&lt;br /&gt;
		if nsTable then&lt;br /&gt;
			return nsTable.id&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return 0&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.formatPages(...)&lt;br /&gt;
	-- Formats a list of pages using formatLink and returns it as an array. Nil&lt;br /&gt;
	-- values are not allowed.&lt;br /&gt;
	local pages = {...}&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for i, page in ipairs(pages) do&lt;br /&gt;
		ret[i] = p._formatLink(page)&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.formatPageTables(...)&lt;br /&gt;
	-- Takes a list of page/display tables and returns it as a list of&lt;br /&gt;
	-- formatted links. Nil values are not allowed.&lt;br /&gt;
	local pages = {...}&lt;br /&gt;
	local links = {}&lt;br /&gt;
	for i, t in ipairs(pages) do&lt;br /&gt;
		checkType(&#039;formatPageTables&#039;, i, t, &#039;table&#039;)&lt;br /&gt;
		local link = t[1]&lt;br /&gt;
		local display = t[2]&lt;br /&gt;
		links[i] = p._formatLink(link, display)&lt;br /&gt;
	end&lt;br /&gt;
	return links&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.makeWikitextError(msg, helpLink, addTrackingCategory)&lt;br /&gt;
	-- Formats an error message to be returned to wikitext. If&lt;br /&gt;
	-- addTrackingCategory is not false after being returned from&lt;br /&gt;
	-- [[Module:Yesno]], and if we are not on a talk page, a tracking category&lt;br /&gt;
	-- is added.&lt;br /&gt;
	checkType(&#039;makeWikitextError&#039;, 1, msg, &#039;string&#039;)&lt;br /&gt;
	checkType(&#039;makeWikitextError&#039;, 2, helpLink, &#039;string&#039;, true)&lt;br /&gt;
	yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
	local title = mw.title.getCurrentTitle()&lt;br /&gt;
	-- Make the help link text.&lt;br /&gt;
	local helpText&lt;br /&gt;
	if helpLink then&lt;br /&gt;
		helpText = &#039; ([[&#039; .. helpLink .. &#039;|help]])&#039;&lt;br /&gt;
	else&lt;br /&gt;
		helpText = &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	-- Make the category text.&lt;br /&gt;
	local category&lt;br /&gt;
	if not title.isTalkPage and yesno(addTrackingCategory) ~= false then&lt;br /&gt;
		category = &#039;Hatnote templates with errors&#039;&lt;br /&gt;
		category = string.format(&lt;br /&gt;
			&#039;[[%s:%s]]&#039;,&lt;br /&gt;
			mw.site.namespaces[14].name,&lt;br /&gt;
			category&lt;br /&gt;
		)&lt;br /&gt;
	else&lt;br /&gt;
		category = &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	return string.format(&lt;br /&gt;
		&#039;&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Error: %s%s.&amp;lt;/strong&amp;gt;%s&#039;,&lt;br /&gt;
		msg,&lt;br /&gt;
		helpText,&lt;br /&gt;
		category&lt;br /&gt;
	)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Format link&lt;br /&gt;
--&lt;br /&gt;
-- Makes a wikilink from the given link and display values. Links are escaped&lt;br /&gt;
-- with colons if necessary, and links to sections are detected and displayed&lt;br /&gt;
-- with &amp;quot; § &amp;quot; as a separator rather than the standard MediaWiki &amp;quot;#&amp;quot;. Used in&lt;br /&gt;
-- the {{format hatnote link}} template.&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
function p.formatLink(frame)&lt;br /&gt;
	local args = getArgs(frame)&lt;br /&gt;
	local link = args[1]&lt;br /&gt;
	local display = args[2]&lt;br /&gt;
	if not link then&lt;br /&gt;
		return p.makeWikitextError(&lt;br /&gt;
			&#039;no link specified&#039;,&lt;br /&gt;
			&#039;Template:Format hatnote link#Errors&#039;,&lt;br /&gt;
			args.category&lt;br /&gt;
		)&lt;br /&gt;
	end&lt;br /&gt;
	return p._formatLink(link, display)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._formatLink(link, display)&lt;br /&gt;
	-- Find whether we need to use the colon trick or not. We need to use the&lt;br /&gt;
	-- colon trick for categories and files, as otherwise category links&lt;br /&gt;
	-- categorise the page and file links display the file.&lt;br /&gt;
	checkType(&#039;_formatLink&#039;, 1, link, &#039;string&#039;)&lt;br /&gt;
	checkType(&#039;_formatLink&#039;, 2, display, &#039;string&#039;, true)&lt;br /&gt;
	link = removeInitialColon(link)&lt;br /&gt;
	local namespace = p.findNamespaceId(link, false)&lt;br /&gt;
	local colon&lt;br /&gt;
	if namespace == 6 or namespace == 14 then&lt;br /&gt;
		colon = &#039;:&#039;&lt;br /&gt;
	else&lt;br /&gt;
		colon = &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Find whether a faux display value has been added with the {{!}} magic&lt;br /&gt;
	-- word.&lt;br /&gt;
	if not display then&lt;br /&gt;
		local prePipe, postPipe = link:match(&#039;^(.-)|(.*)$&#039;)&lt;br /&gt;
		link = prePipe or link&lt;br /&gt;
		display = postPipe&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Find the display value.&lt;br /&gt;
	if not display then&lt;br /&gt;
		local page, section = link:match(&#039;^(.-)#(.*)$&#039;)&lt;br /&gt;
		if page then&lt;br /&gt;
			display = page .. &#039; § &#039; .. section&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Assemble the link.&lt;br /&gt;
	if display then&lt;br /&gt;
		return string.format(&#039;[[%s%s|%s]]&#039;, colon, link, display)&lt;br /&gt;
	else&lt;br /&gt;
		return string.format(&#039;[[%s%s]]&#039;, colon, link)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
-- Hatnote&lt;br /&gt;
--&lt;br /&gt;
-- Produces standard hatnote text. Implements the {{hatnote}} template.&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
function p.hatnote(frame)&lt;br /&gt;
	local args = getArgs(frame)&lt;br /&gt;
	local s = args[1]&lt;br /&gt;
	local options = {}&lt;br /&gt;
	if not s then&lt;br /&gt;
		return p.makeWikitextError(&lt;br /&gt;
			&#039;no text specified&#039;,&lt;br /&gt;
			&#039;Template:Hatnote#Errors&#039;,&lt;br /&gt;
			args.category&lt;br /&gt;
		)&lt;br /&gt;
	end&lt;br /&gt;
	options.extraclasses = args.extraclasses&lt;br /&gt;
	options.selfref = args.selfref&lt;br /&gt;
	return p._hatnote(s, options)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._hatnote(s, options)&lt;br /&gt;
	checkType(&#039;_hatnote&#039;, 1, s, &#039;string&#039;)&lt;br /&gt;
	checkType(&#039;_hatnote&#039;, 2, options, &#039;table&#039;, true)&lt;br /&gt;
	local classes = {&#039;hatnote&#039;}&lt;br /&gt;
	local extraclasses = options.extraclasses&lt;br /&gt;
	local selfref = options.selfref&lt;br /&gt;
	if type(extraclasses) == &#039;string&#039; then&lt;br /&gt;
		classes[#classes + 1] = extraclasses&lt;br /&gt;
	end&lt;br /&gt;
	if selfref then&lt;br /&gt;
		classes[#classes + 1] = &#039;selfref&#039;&lt;br /&gt;
	end&lt;br /&gt;
	return string.format(&lt;br /&gt;
		&#039;&amp;lt;div class=&amp;quot;%s&amp;quot;&amp;gt;%s&amp;lt;/div&amp;gt;&#039;,&lt;br /&gt;
		table.concat(classes, &#039; &#039;),&lt;br /&gt;
		s&lt;br /&gt;
	)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:File_link&amp;diff=2400</id>
		<title>Module:File link</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:File_link&amp;diff=2400"/>
		<updated>2015-07-09T17:07:23Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module provides a library for formatting file wikilinks.&lt;br /&gt;
&lt;br /&gt;
local yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
local checkType = require(&#039;libraryUtil&#039;).checkType&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
function p._main(args)&lt;br /&gt;
	checkType(&#039;_main&#039;, 1, args, &#039;table&#039;)&lt;br /&gt;
&lt;br /&gt;
	-- This is basically libraryUtil.checkTypeForNamedArg, but we are rolling our&lt;br /&gt;
	-- own function to get the right error level.&lt;br /&gt;
	local function checkArg(key, val, level)&lt;br /&gt;
		if type(val) ~= &#039;string&#039; then&lt;br /&gt;
			error(string.format(&lt;br /&gt;
				&amp;quot;type error in &#039;%s&#039; parameter of &#039;_main&#039; (expected string, got %s)&amp;quot;,&lt;br /&gt;
				key, type(val)&lt;br /&gt;
			), level)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local ret = {}&lt;br /&gt;
&lt;br /&gt;
	-- Adds a positional parameter to the buffer.&lt;br /&gt;
	local function addPositional(key)&lt;br /&gt;
		local val = args[key]&lt;br /&gt;
		if not val then&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
		checkArg(key, val, 4)&lt;br /&gt;
		ret[#ret + 1] = val&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Adds a named parameter to the buffer. We assume that the parameter name&lt;br /&gt;
	-- is the same as the argument key.&lt;br /&gt;
	local function addNamed(key)&lt;br /&gt;
		local val = args[key]&lt;br /&gt;
		if not val then&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
		checkArg(key, val, 4)&lt;br /&gt;
		ret[#ret + 1] = key .. &#039;=&#039; .. val&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Filename&lt;br /&gt;
	checkArg(&#039;file&#039;, args.file, 3)&lt;br /&gt;
	ret[#ret + 1] = &#039;File:&#039; .. args.file&lt;br /&gt;
&lt;br /&gt;
	-- Format&lt;br /&gt;
	if args.format then&lt;br /&gt;
		checkArg(&#039;format&#039;, args.format)&lt;br /&gt;
		if args.formatfile then&lt;br /&gt;
			checkArg(&#039;formatfile&#039;, args.formatfile)&lt;br /&gt;
			ret[#ret + 1] = args.format .. &#039;=&#039; .. args.formatfile&lt;br /&gt;
		else&lt;br /&gt;
			ret[#ret + 1] = args.format&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Border&lt;br /&gt;
	if yesno(args.border) then&lt;br /&gt;
		ret[#ret + 1] = &#039;border&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	addPositional(&#039;location&#039;)&lt;br /&gt;
	addPositional(&#039;alignment&#039;)&lt;br /&gt;
	addPositional(&#039;size&#039;)&lt;br /&gt;
	addNamed(&#039;upright&#039;)&lt;br /&gt;
	addNamed(&#039;link&#039;)&lt;br /&gt;
	addNamed(&#039;alt&#039;)&lt;br /&gt;
	addNamed(&#039;page&#039;)&lt;br /&gt;
	addNamed(&#039;class&#039;)&lt;br /&gt;
	addNamed(&#039;lang&#039;)&lt;br /&gt;
	addNamed(&#039;start&#039;)&lt;br /&gt;
	addNamed(&#039;end&#039;)&lt;br /&gt;
	addNamed(&#039;thumbtime&#039;)&lt;br /&gt;
	addPositional(&#039;caption&#039;)&lt;br /&gt;
&lt;br /&gt;
	return string.format(&#039;[[%s]]&#039;, table.concat(ret, &#039;|&#039;))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local origArgs = require(&#039;Module:Arguments&#039;).getArgs(frame, {&lt;br /&gt;
		wrappers = &#039;Template:File link&#039;&lt;br /&gt;
	})&lt;br /&gt;
	if not origArgs.file then&lt;br /&gt;
		error(&amp;quot;&#039;file&#039; parameter missing from [[Template:File link]]&amp;quot;, 0)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Copy the arguments that were passed to a new table to avoid looking up&lt;br /&gt;
	-- every possible parameter in the frame object.&lt;br /&gt;
	local args = {}&lt;br /&gt;
	for k, v in pairs(origArgs) do&lt;br /&gt;
		-- Make _BLANK a special argument to add a blank parameter. For use in&lt;br /&gt;
		-- conditional templates etc. it is useful for blank arguments to be&lt;br /&gt;
		-- ignored, but we still need a way to specify them so that we can do&lt;br /&gt;
		-- things like [[File:Example.png|link=]].&lt;br /&gt;
		if v == &#039;_BLANK&#039; then&lt;br /&gt;
			v = &#039;&#039;&lt;br /&gt;
		end&lt;br /&gt;
		args[k] = v&lt;br /&gt;
	end&lt;br /&gt;
	return p._main(args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
	<entry>
		<id>https://wiki.hackforums.net/index.php?title=Module:Effective_protection_level&amp;diff=2398</id>
		<title>Module:Effective protection level</title>
		<link rel="alternate" type="text/html" href="https://wiki.hackforums.net/index.php?title=Module:Effective_protection_level&amp;diff=2398"/>
		<updated>2015-07-09T17:07:23Z</updated>

		<summary type="html">&lt;p&gt;Ethereal: 1 revision imported: D3x request&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local p = {}&lt;br /&gt;
&lt;br /&gt;
-- Returns the permission required to perform a given action on a given title.&lt;br /&gt;
-- If no title is specified, the title of the page being displayed is used.&lt;br /&gt;
function p._main(action, pagename)&lt;br /&gt;
	local title&lt;br /&gt;
	if type(pagename) == &#039;table&#039; and pagename.prefixedText then&lt;br /&gt;
		title = pagename&lt;br /&gt;
	elseif pagename then&lt;br /&gt;
		title = mw.title.new(pagename)&lt;br /&gt;
	else&lt;br /&gt;
		title = mw.title.getCurrentTitle()&lt;br /&gt;
	end&lt;br /&gt;
	pagename = title.prefixedText&lt;br /&gt;
	if action == &#039;autoreview&#039; then&lt;br /&gt;
		local level = mw.getCurrentFrame():callParserFunction(&#039;PENDINGCHANGELEVEL&#039;, pagename)&lt;br /&gt;
		if level == &#039;review&#039; then&lt;br /&gt;
			return &#039;reviewer&#039;&lt;br /&gt;
		elseif level ~= &#039;&#039; then&lt;br /&gt;
			return level&lt;br /&gt;
		else&lt;br /&gt;
			return nil -- not &#039;*&#039;. a page not being PC-protected is distinct from it being PC-protected with anyone able to review. also not &#039;&#039;, as that would mean PC-protected but nobody can review&lt;br /&gt;
		end&lt;br /&gt;
	elseif action ~= &#039;edit&#039; and action ~= &#039;move&#039; and action ~= &#039;create&#039; and action ~= &#039;upload&#039; then&lt;br /&gt;
		error( &#039;First parameter must be one of edit, move, create, upload, autoreview&#039;, 2 )&lt;br /&gt;
	end&lt;br /&gt;
	if title.namespace == 8 then -- MediaWiki namespace&lt;br /&gt;
		return &#039;sysop&#039;&lt;br /&gt;
	elseif title.namespace == 2 and title.isSubpage and ( title.contentModel == &#039;javascript&#039; or title.contentModel == &#039;css&#039; ) then -- user JS or CSS page&lt;br /&gt;
		return &#039;sysop&#039;&lt;br /&gt;
	end&lt;br /&gt;
	local level = title.protectionLevels[action] and title.protectionLevels[action][1]&lt;br /&gt;
	if level == &#039;sysop&#039; or level == &#039;editprotected&#039; then&lt;br /&gt;
		return &#039;sysop&#039;&lt;br /&gt;
	elseif title.cascadingProtection.restrictions[action] and title.cascadingProtection.restrictions[action][1] then -- used by a cascading-protected page&lt;br /&gt;
		return &#039;sysop&#039;&lt;br /&gt;
	elseif level == &#039;templateeditor&#039; then&lt;br /&gt;
		return &#039;templateeditor&#039;&lt;br /&gt;
	elseif action == &#039;move&#039; then&lt;br /&gt;
		local blacklistentry = mw.ext.TitleBlacklist.test(&#039;edit&#039;, pagename) -- Testing action edit is correct, since this is for the source page. The target page name gets tested with action move.&lt;br /&gt;
		if blacklistentry and not blacklistentry.params.autoconfirmed then&lt;br /&gt;
			return &#039;templateeditor&#039;&lt;br /&gt;
		elseif title.namespace == 6 then&lt;br /&gt;
			return &#039;filemover&#039;&lt;br /&gt;
		else&lt;br /&gt;
			return &#039;autoconfirmed&#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local blacklistentry = mw.ext.TitleBlacklist.test(action, pagename)&lt;br /&gt;
	if blacklistentry then&lt;br /&gt;
		return blacklistentry.params.autoconfirmed and &#039;autoconfirmed&#039; or &#039;templateeditor&#039;&lt;br /&gt;
	elseif level == &#039;editsemiprotected&#039; then -- create-semiprotected pages return this for some reason&lt;br /&gt;
		return &#039;autoconfirmed&#039;&lt;br /&gt;
	elseif level then&lt;br /&gt;
		return level&lt;br /&gt;
	elseif action == &#039;upload&#039; then&lt;br /&gt;
		return &#039;autoconfirmed&#039;&lt;br /&gt;
	elseif action == &#039;create&#039; and title.namespace % 2 == 0 and title.namespace ~= 118 then -- You need to be registered, but not autoconfirmed, to create non-talk pages other than drafts&lt;br /&gt;
		return &#039;user&#039;&lt;br /&gt;
	else&lt;br /&gt;
		return &#039;*&#039;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
setmetatable(p, { __index = function(t, k)&lt;br /&gt;
	return function(frame)&lt;br /&gt;
		return t._main(k, frame.args[1])&lt;br /&gt;
	end&lt;br /&gt;
end })&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Ethereal</name></author>
	</entry>
</feed>