<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wikitest.baw.de/en/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=ArxioWikiSysop</id>
	<title>BAWiki - User contributions [en]</title>
	<link rel="self" type="application/atom+xml" href="https://wikitest.baw.de/en/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=ArxioWikiSysop"/>
	<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Special:Contributions/ArxioWikiSysop"/>
	<updated>2026-05-27T11:20:41Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.43.5</generator>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=BAW-Methoden-Wiki_(en):General_disclaimer&amp;diff=15361</id>
		<title>BAW-Methoden-Wiki (en):General disclaimer</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=BAW-Methoden-Wiki_(en):General_disclaimer&amp;diff=15361"/>
		<updated>2024-10-01T07:50:21Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Impressum==&lt;br /&gt;
&lt;br /&gt;
Das Internetangebot wird herausgegeben von:&lt;br /&gt;
 &lt;br /&gt;
&#039;&#039;&#039;Bundesanstalt für Wasserbau&#039;&#039;&#039;&amp;lt;br /&amp;gt;&lt;br /&gt;
Kußmaulstraße 17 &amp;lt;br /&amp;gt;&lt;br /&gt;
76187 Karlsruhe &amp;lt;br /&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Postanschrift: &amp;lt;br /&amp;gt;&lt;br /&gt;
Postfach 21 03 53 &amp;lt;br /&amp;gt;&lt;br /&gt;
76152 Karlsruhe &amp;lt;br /&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Telefon: 07 21/97 26-0 &amp;lt;br /&amp;gt;&lt;br /&gt;
Fax: 07 21/97 26-4540 &amp;lt;br /&amp;gt;&lt;br /&gt;
E-Mail: [mailto:info@baw.de info@baw.de] &amp;lt;br /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Vertretungsbefugte Person&#039;&#039;&#039; &amp;lt;br /&amp;gt;&lt;br /&gt;
Dr.-Ing. Jan Kayser  &amp;lt;br /&amp;gt;&lt;br /&gt;
Telefon: +49 (721) 9726-3000 &amp;lt;br /&amp;gt;&lt;br /&gt;
[mailto:jan.kayser@baw.de jan.kayser@baw.de] &amp;lt;br /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Verantwortlich&#039;&#039;&#039; &amp;lt;br /&amp;gt;&lt;br /&gt;
Peter Weinmann &amp;lt;br /&amp;gt;&lt;br /&gt;
[mailto:peter.weinmann@baw.de peter.weinmann@baw.de] &amp;lt;br /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Redaktionelle Leitung&#039;&#039;&#039; &amp;lt;br /&amp;gt;&lt;br /&gt;
Jennifer Pfrommer &amp;lt;br /&amp;gt;&lt;br /&gt;
[mailto:jennifer.pfrommer@baw.de jennifer.pfrommer@baw.de] &amp;lt;br /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Gestaltung, Realisierung&#039;&#039;&#039; &amp;lt;br /&amp;gt;&lt;br /&gt;
arxio GmbH (Programmierung, Umsetzung) &amp;lt;br /&amp;gt;&lt;br /&gt;
http://arxio.de &amp;lt;br /&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
DauthKaun (Design) &amp;lt;br /&amp;gt;&lt;br /&gt;
http://dauthkaun.de &lt;br /&gt;
&lt;br /&gt;
===Hinweis===&lt;br /&gt;
&lt;br /&gt;
Für Vollständigkeit, Fehler redaktioneller und technischer Art, Auslassungen usw. sowie die Richtigkeit der Eintragungen kann keine Haftung übernommen werden.&lt;br /&gt;
&lt;br /&gt;
Insbesondere kann keine Gewähr für die Vollständigkeit und Richtigkeit von Informationen übernommen werden, die über weiterführende Links erreicht werden. Anbieter sind für die eigenen Inhalte, die sie zur Nutzung bereithalten, nach den allgemeinen Gesetzen verantwortlich. Von diesen eigenen Inhalten sind Querverweise auf die von anderen Anbietern bereitgehaltenen Inhalte zu unterscheiden.&lt;br /&gt;
&lt;br /&gt;
Die Verweise durch Hyperlinks auf Inhalte fremder Webseiten dienen lediglich der Information.&lt;br /&gt;
Die Verantwortlichkeit für diese fremden Inhalte liegt alleine bei dem Anbieter, der die Inhalte bereithält. Vor dem Einrichten des entsprechenden Verweises sind die Web-Seiten der anderen Anbieter mit großer Sorgfalt und nach bestem Wissen und Gewissen überprüft worden. Es kann jedoch keine Gewähr für die Vollständigkeit und Richtigkeit von Informationen übernommen werden, die über weiterführende Hyperlinks erreicht werden. Der Inhalt der anderen Web-Seiten kann jederzeit ohne Wissen der Bundesanstalt für Wasserbau geändert werden. Für sämtliche Links auf diesen Seiten gilt: Wir betonen, dass wir keinen Einfluss auf die Gestaltung und die Inhalte der durch Link von unserer Homepage aus erreichbaren Seiten anderer Anbieter haben und uns deren Inhalt nicht zu eigen machen. Diese Erklärung gilt für alle Seiten dieser Homepage und die dort angebrachten Links.&lt;br /&gt;
&lt;br /&gt;
Falls die Bundesanstalt für Wasserbau auf Seiten verweist, deren Inhalt Anlass zur Beanstandung gibt, bitten wir um Mitteilung.&lt;br /&gt;
Die Bundesanstalt für Wasserbau behält sich das Recht vor, ohne vorherige Ankündigung die bereitgestellten Informationen zu ändern, zu ergänzen oder zu entfernen.&lt;br /&gt;
===Urheberrecht===&lt;br /&gt;
&lt;br /&gt;
Das Copyright für Texte liegt, soweit nicht anders vermerkt, bei der Bundesanstalt für Wasserbau.&lt;br /&gt;
&lt;br /&gt;
Das Copyright für Bilder liegt, soweit nicht anders vermerkt, bei der Bundesanstalt für Wasserbau oder bei der Wasser- und Schifffahrtsverwaltung des Bundes.&lt;br /&gt;
&lt;br /&gt;
Auf diesen Webseiten zur Verfügung gestellte Texte, Textteile, Grafiken, Tabellen oder Bildmaterialien dürfen ohne vorherige Zustimmung der Bundesanstalt für Wasserbau nicht vervielfältigt, nicht verbreitet und nicht ausgestellt werden.&lt;br /&gt;
&lt;br /&gt;
===Nutzungsbedingungen für Bilder===&lt;br /&gt;
&lt;br /&gt;
# Die Bundesansalt für Wasserbau hat alle Nutzungsrechte von den Urhebern der digitalen Bilder erworben, soweit nichts Gegenteiliges, z.B. in den begleitenden Bildinformationen, angegeben ist.&lt;br /&gt;
# Die Bildinformationen und die darin enthaltenen Nutzungs- und Verwendungsbeschränkungen sind zu beachten. Für die aus der Nichtbeachtung resultierenden Schäden haftet der Nutzer. Er hat die Bundesanstalt für Wasserbau insoweit von Ansprüchen Dritter freizustellen. Für die Nutzung des Bildmaterials im historischen Bildarchiv der Bundeswasserstraßen gelten gesonderte Nutzungsbedingungen.&lt;br /&gt;
# Die Bilder können grundsätzlich kostenfrei heruntergeladen und im Rahmen der Berichterstattung für folgende Zwecke genutzt werden: &lt;br /&gt;
#* Presseveröffentlichungen&lt;br /&gt;
#* Veröffentlichungen durch Film und Fernsehen&lt;br /&gt;
#:Eine darüber hinausgehende Nutzung für kommerzielle Zwecke, insbesondere für Werbezwecke, ist nicht zulässig.&lt;br /&gt;
# Jegliche Bearbeitung, Umgestaltung oder Manipulation der digitalen Bilder, die über Farbkorrekturen, Ausschnitte und Verkleinerungen hinausgehen, ist unzulässig und nur mit vorheriger schriftlicher Zustimmung seitens der Bundesanstalt für Wasserbau erlaubt. Ebenso darf das digitale Bild nicht in einem sinnentstellten Zusammenhang wiedergegeben werden.&lt;br /&gt;
# Eine Entstellung des urheberrechtlichen geschützten Werks in Bild, Wort bzw. jeglicher anderen Form, z.B. durch Nachfotografieren, zeichnerische Verfälschung, Fotocomposing oder elektronische Hilfsmittel ist nicht zulässig. Der Nutzer trägt die Verantwortung für die Betextung.&lt;br /&gt;
# Die Presse ist insbesondere zur Beachtung der publizistischen Grundsätze des Deutschen Presserates (Pressecodex) verpflichtet. Die Zustimmung zur Nutzung des Bildmaterials umfasst nicht die Zusicherung, dass die abgebildeten Personen, die Inhaber der Rechte an abgebildeten Werken oder die Inhaber von Marken- und sonstigen Schutzrechten die Einwilligung zu einer öffentlichen Wiedergabe erteilt haben. Die Einholung der im Einzelfall notwendigen Einwilligungen Dritter obliegt dem Nutzer. Er hat die Persönlichkeits-, Urheber-, Marken- und sonstigen Schutzrechte von abgebildeten Personen, Werken, Gegenständen oder Zeichen selbst zu beachten. Bei Missachtung solcher Rechte ist allein der Nutzer etwaigen Dritten gegenüber schadenersatzpflichtig.&lt;br /&gt;
# Die Bundesanstalt für Wasserbau behält sich vor, dem Verdacht einer missbräuchlichen Nutzung oder einer wesentlichen Nutzungsverletzung nachzugehen.&lt;br /&gt;
# Bei Verwendung des digitalen Bildes ist die Quelle &amp;quot;Vor- und Nachname des Fotografen/BAW&amp;quot; anzugeben. Dies gilt auch für elektronische Publikationen (z.B. Webseiten). Von jeder Veröffentlichung im Druck ist der Bundesanstalt für Wasserbau ein Belegexemplar unaufgefordert und kostenfrei zuzusenden.&lt;br /&gt;
&lt;br /&gt;
[[de:BAWiki:Impressum]]&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Test123&amp;diff=15360</id>
		<title>Test123</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Test123&amp;diff=15360"/>
		<updated>2023-12-19T12:02:31Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Playground ==&lt;br /&gt;
&#039;&#039;&#039;A&amp;lt;sub&amp;gt;T&amp;lt;/sub&amp;gt; / 0,5 A&amp;lt;sub&amp;gt;S&amp;lt;/sub&amp;gt;&#039;&#039;&#039;&lt;br /&gt;
{{#expr: 1 + 1 }}&lt;br /&gt;
&lt;br /&gt;
[[File:61 Bild 1.png|thumb|Titelbild FOX]]&lt;br /&gt;
&lt;br /&gt;
== Test Extensions ==&lt;br /&gt;
&lt;br /&gt;
=== Math ===&lt;br /&gt;
&amp;lt;math&amp;gt;E=mc^2&amp;lt;/math&amp;gt;&lt;br /&gt;
&amp;lt;math&amp;gt;&amp;lt;\frac{2+dc}{9}&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== ReplaceText ===&lt;br /&gt;
Rudolfstr&lt;br /&gt;
&lt;br /&gt;
=== ImageMap ===&lt;br /&gt;
&amp;lt;imagemap&amp;gt;&lt;br /&gt;
File:61 Bild 1.png|150px|alternativtext=Fluss mit Schiff&lt;br /&gt;
default [[Main Page|zur Hauptseite]]&lt;br /&gt;
&amp;lt;/imagemap&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== PdfHandler ===&lt;br /&gt;
[[File:Testdatei.pdf|page=2|600px]]&lt;br /&gt;
&lt;br /&gt;
=== LinkTitles ===&lt;br /&gt;
[[forecast]]&lt;br /&gt;
&lt;br /&gt;
=== SyntaxHighlight ===&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line&amp;gt;&lt;br /&gt;
def quick_sort(arr):&lt;br /&gt;
	less = []&lt;br /&gt;
	pivot_list = []&lt;br /&gt;
	more = []&lt;br /&gt;
	if len(arr) &amp;lt;= 1:&lt;br /&gt;
		return arr&lt;br /&gt;
	else:&lt;br /&gt;
		pass&lt;br /&gt;
‎&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Cite ===&lt;br /&gt;
Siehe &amp;lt;ref&amp;gt;Müller-Hagedorn&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Literatur ====&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Main_Page&amp;diff=15359</id>
		<title>Main Page</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Main_Page&amp;diff=15359"/>
		<updated>2023-12-15T09:41:37Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==BAWiki==&lt;br /&gt;
&lt;br /&gt;
* [[Hydraulic Engineering Methods]]&lt;br /&gt;
*# [[Mathematical Methods]]&lt;br /&gt;
*# [[Field Study Measurements]]&lt;br /&gt;
*# [[Ship Handling Simulation]]&lt;br /&gt;
*# [[Hydraulic Modelling]]&lt;br /&gt;
*# [[Automated Discharge and Water Level Control]]&lt;br /&gt;
*# [[Ecological Connectivity]]&lt;br /&gt;
*# [[Tidal Dynamics of Estuaries]]&lt;br /&gt;
*# [[Design Software]]&lt;br /&gt;
&lt;br /&gt;
* [[Structural Engineering Methods]]&lt;br /&gt;
*# [[Alkali Reactivity of Aggregates and Concretes]]&lt;br /&gt;
*# [[Analysis and Testing of Construction and Coating Materials]]&lt;br /&gt;
*# [[Durability tests for rebar corrosion]]&lt;br /&gt;
*# [[Assessing the Freeze-Thaw Resistance of Concrete]]&lt;br /&gt;
*# [[Development of Hydration Heat in Concrete]]&lt;br /&gt;
*# [[Corrosion protection tests (steel structures and corrosion protection)]]&lt;br /&gt;
*# [[Nonlinear structural engineering analysis (NiTrA)]]&lt;br /&gt;
*# [[Protecting offshore wind turbines against corrosion]]&lt;br /&gt;
*# [[Non-linear probabilistic calculations]]&lt;br /&gt;
*# [[Shear strength of concrete and masonry]]&lt;br /&gt;
*# [[Assessing the load-bearing capacity of closures on existing hydraulic steel structures (steel structures and corrosion protection)]]&lt;br /&gt;
*# [[Evaluating the condition of solid structures]]&lt;br /&gt;
*# [[Condition forecast]]&lt;br /&gt;
&lt;br /&gt;
* [[Geotechnical Engineering Methods]]&lt;br /&gt;
*# [[Geotechnical laboratory testing]]&lt;br /&gt;
*# [[Geotechnical field tests]]&lt;br /&gt;
*# [[Geotechnical measurements]]&lt;br /&gt;
*# [[Analytical methods]]&lt;br /&gt;
*# [[Numerical Methods]]&lt;br /&gt;
&lt;br /&gt;
* BAWiki: [[Overview|Quick Access]] to all topics&lt;br /&gt;
* BAWiki: Access according to [[Special:Categories|Categories]]&lt;br /&gt;
* BAWiki: [[:Category:Glossary|Glossary]]&lt;br /&gt;
[[de:Hauptseite]]&lt;br /&gt;
&lt;br /&gt;
----&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=File:Testdatei.pdf&amp;diff=15358</id>
		<title>File:Testdatei.pdf</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=File:Testdatei.pdf&amp;diff=15358"/>
		<updated>2023-12-15T09:39:23Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=File:61_Bild_1.png&amp;diff=15357</id>
		<title>File:61 Bild 1.png</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=File:61_Bild_1.png&amp;diff=15357"/>
		<updated>2023-12-15T09:38:06Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Test123&amp;diff=15356</id>
		<title>Test123</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Test123&amp;diff=15356"/>
		<updated>2023-12-15T09:37:48Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: Created page with &amp;quot;== Playground == &amp;#039;&amp;#039;&amp;#039;A&amp;lt;sub&amp;gt;T&amp;lt;/sub&amp;gt; / 0,5 A&amp;lt;sub&amp;gt;S&amp;lt;/sub&amp;gt;&amp;#039;&amp;#039;&amp;#039; {{#expr: 1 + 1 }}  Titelbild FOX  == Test Extensions ==  === Math === &amp;lt;math&amp;gt;E=mc^2&amp;lt;/math&amp;gt; &amp;lt;math&amp;gt;&amp;lt;\frac{2+dc}{9}&amp;lt;/math&amp;gt;  === ReplaceText === Rudolfstr  === ImageMap === &amp;lt;imagemap&amp;gt; File:61 Bild 1.png|150px|alternativtext=Fluss mit Schiff default zur Hauptseite &amp;lt;/imagemap&amp;gt;  === PdfHandler === 600px  === LinkTitles === forecast  === Cite === S...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Playground ==&lt;br /&gt;
&#039;&#039;&#039;A&amp;lt;sub&amp;gt;T&amp;lt;/sub&amp;gt; / 0,5 A&amp;lt;sub&amp;gt;S&amp;lt;/sub&amp;gt;&#039;&#039;&#039;&lt;br /&gt;
{{#expr: 1 + 1 }}&lt;br /&gt;
&lt;br /&gt;
[[File:61 Bild 1.png|thumb|Titelbild FOX]]&lt;br /&gt;
&lt;br /&gt;
== Test Extensions ==&lt;br /&gt;
&lt;br /&gt;
=== Math ===&lt;br /&gt;
&amp;lt;math&amp;gt;E=mc^2&amp;lt;/math&amp;gt;&lt;br /&gt;
&amp;lt;math&amp;gt;&amp;lt;\frac{2+dc}{9}&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== ReplaceText ===&lt;br /&gt;
Rudolfstr&lt;br /&gt;
&lt;br /&gt;
=== ImageMap ===&lt;br /&gt;
&amp;lt;imagemap&amp;gt;&lt;br /&gt;
File:61 Bild 1.png|150px|alternativtext=Fluss mit Schiff&lt;br /&gt;
default [[Main Page|zur Hauptseite]]&lt;br /&gt;
&amp;lt;/imagemap&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== PdfHandler ===&lt;br /&gt;
[[File:Testdatei.pdf|page=2|600px]]&lt;br /&gt;
&lt;br /&gt;
=== LinkTitles ===&lt;br /&gt;
[[forecast]]&lt;br /&gt;
&lt;br /&gt;
=== Cite ===&lt;br /&gt;
Siehe &amp;lt;ref&amp;gt;Müller-Hagedorn&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Literatur ====&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Main_Page&amp;diff=15355</id>
		<title>Main Page</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Main_Page&amp;diff=15355"/>
		<updated>2023-12-15T09:36:42Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==BAWiki==&lt;br /&gt;
&lt;br /&gt;
* [[Hydraulic Engineering Methods]]&lt;br /&gt;
*# [[Mathematical Methods]]&lt;br /&gt;
*# [[Field Study Measurements]]&lt;br /&gt;
*# [[Ship Handling Simulation]]&lt;br /&gt;
*# [[Hydraulic Modelling]]&lt;br /&gt;
*# [[Automated Discharge and Water Level Control]]&lt;br /&gt;
*# [[Ecological Connectivity]]&lt;br /&gt;
*# [[Tidal Dynamics of Estuaries]]&lt;br /&gt;
*# [[Design Software]]&lt;br /&gt;
&lt;br /&gt;
* [[Structural Engineering Methods]]&lt;br /&gt;
*# [[Alkali Reactivity of Aggregates and Concretes]]&lt;br /&gt;
*# [[Analysis and Testing of Construction and Coating Materials]]&lt;br /&gt;
*# [[Durability tests for rebar corrosion]]&lt;br /&gt;
*# [[Assessing the Freeze-Thaw Resistance of Concrete]]&lt;br /&gt;
*# [[Development of Hydration Heat in Concrete]]&lt;br /&gt;
*# [[Corrosion protection tests (steel structures and corrosion protection)]]&lt;br /&gt;
*# [[Nonlinear structural engineering analysis (NiTrA)]]&lt;br /&gt;
*# [[Protecting offshore wind turbines against corrosion]]&lt;br /&gt;
*# [[Non-linear probabilistic calculations]]&lt;br /&gt;
*# [[Shear strength of concrete and masonry]]&lt;br /&gt;
*# [[Assessing the load-bearing capacity of closures on existing hydraulic steel structures (steel structures and corrosion protection)]]&lt;br /&gt;
*# [[Evaluating the condition of solid structures]]&lt;br /&gt;
*# [[Condition forecast]]&lt;br /&gt;
&lt;br /&gt;
* [[Geotechnical Engineering Methods]]&lt;br /&gt;
*# [[Geotechnical laboratory testing]]&lt;br /&gt;
*# [[Geotechnical field tests]]&lt;br /&gt;
*# [[Geotechnical measurements]]&lt;br /&gt;
*# [[Analytical methods]]&lt;br /&gt;
*# [[Numerical Methods]]&lt;br /&gt;
[[test123]]&lt;br /&gt;
* BAWiki: [[Overview|Quick Access]] to all topics&lt;br /&gt;
* BAWiki: Access according to [[Special:Categories|Categories]]&lt;br /&gt;
* BAWiki: [[:Category:Glossary|Glossary]]&lt;br /&gt;
[[de:Hauptseite]]&lt;br /&gt;
&lt;br /&gt;
----&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=File:Test.pdf&amp;diff=15354</id>
		<title>File:Test.pdf</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=File:Test.pdf&amp;diff=15354"/>
		<updated>2023-12-08T11:08:44Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=BAWiki:Privacy_policy&amp;diff=15333</id>
		<title>BAWiki:Privacy policy</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=BAWiki:Privacy_policy&amp;diff=15333"/>
		<updated>2023-01-02T08:55:15Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: /* Official data protection officer */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Privacy policy==&lt;br /&gt;
&lt;br /&gt;
The Federal Waterways Engineering and Research Institute (BAW) takes the privacy of your personal data very seriously. We want you to know which data we collect and when, and also how we use this data. We have taken technical and organisational measures to ensure that both we and external service providers comply with data protection provisions. &lt;br /&gt;
&lt;br /&gt;
The BAW website can be used without disclosing any personal information.&lt;br /&gt;
&lt;br /&gt;
===Access to online content ===&lt;br /&gt;
When you visit our website for information purposes, our servers located in Germany only save the personal data transmitted to them by your browser. The log file stores the following data for a maximum of 30 days:&lt;br /&gt;
&lt;br /&gt;
* client’s IP address&lt;br /&gt;
* identity of the client’s PC&lt;br /&gt;
* time of the request&lt;br /&gt;
* URL&lt;br /&gt;
* HTTP status code &lt;br /&gt;
* size of the requested object&lt;br /&gt;
* referrer&lt;br /&gt;
* browser type and version&lt;br /&gt;
&lt;br /&gt;
All data stored are evaluated solely for the purpose of optimising the online content.&lt;br /&gt;
&lt;br /&gt;
===Information material, newsletters, contact forms===&lt;br /&gt;
If you order any information material or newsletters, we will ask you for your name and other personal data. You are free to decide whether or not to submit this information. We store your data on specially protected servers in Germany. Access hereto is limited to a small number of authorised persons who handle the technical or editorial maintenance of the servers.&lt;br /&gt;
&lt;br /&gt;
You can contact us directly via the contact forms available on our website. We collect, process and use the information provided by you via a contact form exclusively for the processing of your specific request and only with your consent.&lt;br /&gt;
&lt;br /&gt;
===Transmission of personal data to third parties ===&lt;br /&gt;
If you order any information material, the personal data that you submit will only be used within the BAW and the companies contracted to undertake the dispatch of information material. We will not forward your data to third parties without your explicit consent. Where we are required to do so by law or by the ruling of a court, we will forward your data to the relevant authorised agencies.&lt;br /&gt;
&lt;br /&gt;
===Use of cookies===&lt;br /&gt;
When you visit our website, information is stored on your computer in the form of cookies. Cookies help in many different ways to make your visit to our website easier, more comfortable and more intuitive. Cookies are text files that are automatically stored on your computer’s hard drive by your web browser whenever you visit our website.&lt;br /&gt;
&lt;br /&gt;
By using the corresponding settings, you can configure your browser at any time in such a way that no cookies are stored on your computer and that you therefore reject the placing of cookies on your computer. You can also delete existing cookies at any time via an Internet browser or other software programmes. This is possible in all standard web browsers. If you disable cookies in your Internet browser, the use of certain functions of our website may be restricted. &lt;br /&gt;
&lt;br /&gt;
We only use technically necessary cookies.&lt;br /&gt;
&lt;br /&gt;
===Statistics===&lt;br /&gt;
We analyse access to our web pages from a statistical perspective in order to optimise our con-tent. We do this using the open source application “AWStats”. AWStats uses our web server log file in order to conduct the analysis. Information regarding your use of this website is not for-warded to third parties. &lt;br /&gt;
&lt;br /&gt;
AWStats does not transfer any data to servers outside the control of the BAW.&lt;br /&gt;
&lt;br /&gt;
===Links ===&lt;br /&gt;
This privacy policy does not cover the websites of third parties to which a link is provided on our website. &lt;br /&gt;
&lt;br /&gt;
The providers of these websites are solely responsible for the contents contained therein. While applying a reasonable standard of review, unlawful contents were not recognisable at the time the link was created. Should any breach of the law come to our knowledge, we will remove these links immediately.&lt;br /&gt;
&lt;br /&gt;
===Protection of minors===&lt;br /&gt;
Persons under the age of 18 should not transmit any personal data without the prior consent of their parents or guardians. We do not request any personal data from children or adolescents. We do not knowingly collect or forward such data to third parties.&lt;br /&gt;
&lt;br /&gt;
===Right of access, rectification and erasure===&lt;br /&gt;
You shall have the right at any time to &lt;br /&gt;
* access, &lt;br /&gt;
* rectification, &lt;br /&gt;
* erasure, &lt;br /&gt;
* restriction of processing, &lt;br /&gt;
* objection to processing, and &lt;br /&gt;
* data portability &lt;br /&gt;
&lt;br /&gt;
with regard to the data stored in respect of you as a person, the origin of the data as well as the purpose of their storage, provided the following does not apply: &lt;br /&gt;
&lt;br /&gt;
Inquiries from the general public, both in paper and electronic form, are stored in accordance with the period for retaining records set by the Registry Directive, which complements the Joint Rules of Procedures of the Federal Ministries (GGO).&lt;br /&gt;
&lt;br /&gt;
Questions and complaints may be directed to the BAW’s Data Protection Officer.&lt;br /&gt;
&lt;br /&gt;
===Official data protection officer===&lt;br /&gt;
Dr. Nurullah Akbulut&amp;lt;br/&amp;gt;&lt;br /&gt;
Phone: +49 (0) 721 9726-2616&amp;lt;br/&amp;gt;&lt;br /&gt;
E-Mail: datenschutz@baw.de&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=BAW-Methoden-Wiki_(en):General_disclaimer&amp;diff=14741</id>
		<title>BAW-Methoden-Wiki (en):General disclaimer</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=BAW-Methoden-Wiki_(en):General_disclaimer&amp;diff=14741"/>
		<updated>2022-04-04T06:33:48Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Impressum==&lt;br /&gt;
&lt;br /&gt;
Das Internetangebot wird herausgegeben von:&lt;br /&gt;
 &lt;br /&gt;
&#039;&#039;&#039;Bundesanstalt für Wasserbau&#039;&#039;&#039;&amp;lt;br /&amp;gt;&lt;br /&gt;
Kußmaulstraße 17 &amp;lt;br /&amp;gt;&lt;br /&gt;
76187 Karlsruhe &amp;lt;br /&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Postanschrift: &amp;lt;br /&amp;gt;&lt;br /&gt;
Postfach 21 03 53 &amp;lt;br /&amp;gt;&lt;br /&gt;
76152 Karlsruhe &amp;lt;br /&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Telefon: 07 21/97 26-0 &amp;lt;br /&amp;gt;&lt;br /&gt;
Fax: 07 21/97 26-4540 &amp;lt;br /&amp;gt;&lt;br /&gt;
E-Mail: [mailto:info@baw.de info@baw.de] &amp;lt;br /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Verantwortlich&#039;&#039;&#039; &amp;lt;br /&amp;gt;&lt;br /&gt;
Peter Weinmann &amp;lt;br /&amp;gt;&lt;br /&gt;
[mailto:peter.weinmann@baw.de peter.weinmann@baw.de] &amp;lt;br /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Redaktionelle Leitung&#039;&#039;&#039; &amp;lt;br /&amp;gt;&lt;br /&gt;
Jennifer Pfrommer &amp;lt;br /&amp;gt;&lt;br /&gt;
[mailto:jennifer.pfrommer@baw.de jennifer.pfrommer@baw.de] &amp;lt;br /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Gestaltung, Realisierung&#039;&#039;&#039; &amp;lt;br /&amp;gt;&lt;br /&gt;
arxio GmbH (Programmierung, Umsetzung) &amp;lt;br /&amp;gt;&lt;br /&gt;
http://arxio.de &amp;lt;br /&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
DauthKaun (Design) &amp;lt;br /&amp;gt;&lt;br /&gt;
http://dauthkaun.de &lt;br /&gt;
&lt;br /&gt;
===Hinweis===&lt;br /&gt;
&lt;br /&gt;
Für Vollständigkeit, Fehler redaktioneller und technischer Art, Auslassungen usw. sowie die Richtigkeit der Eintragungen kann keine Haftung übernommen werden.&lt;br /&gt;
&lt;br /&gt;
Insbesondere kann keine Gewähr für die Vollständigkeit und Richtigkeit von Informationen übernommen werden, die über weiterführende Links erreicht werden. Anbieter sind für die eigenen Inhalte, die sie zur Nutzung bereithalten, nach den allgemeinen Gesetzen verantwortlich. Von diesen eigenen Inhalten sind Querverweise auf die von anderen Anbietern bereitgehaltenen Inhalte zu unterscheiden.&lt;br /&gt;
&lt;br /&gt;
Die Verweise durch Hyperlinks auf Inhalte fremder Webseiten dienen lediglich der Information.&lt;br /&gt;
Die Verantwortlichkeit für diese fremden Inhalte liegt alleine bei dem Anbieter, der die Inhalte bereithält. Vor dem Einrichten des entsprechenden Verweises sind die Web-Seiten der anderen Anbieter mit großer Sorgfalt und nach bestem Wissen und Gewissen überprüft worden. Es kann jedoch keine Gewähr für die Vollständigkeit und Richtigkeit von Informationen übernommen werden, die über weiterführende Hyperlinks erreicht werden. Der Inhalt der anderen Web-Seiten kann jederzeit ohne Wissen der Bundesanstalt für Wasserbau geändert werden. Für sämtliche Links auf diesen Seiten gilt: Wir betonen, dass wir keinen Einfluss auf die Gestaltung und die Inhalte der durch Link von unserer Homepage aus erreichbaren Seiten anderer Anbieter haben und uns deren Inhalt nicht zu eigen machen. Diese Erklärung gilt für alle Seiten dieser Homepage und die dort angebrachten Links.&lt;br /&gt;
&lt;br /&gt;
Falls die Bundesanstalt für Wasserbau auf Seiten verweist, deren Inhalt Anlass zur Beanstandung gibt, bitten wir um Mitteilung.&lt;br /&gt;
Die Bundesanstalt für Wasserbau behält sich das Recht vor, ohne vorherige Ankündigung die bereitgestellten Informationen zu ändern, zu ergänzen oder zu entfernen.&lt;br /&gt;
===Urheberrecht===&lt;br /&gt;
&lt;br /&gt;
Das Copyright für Texte liegt, soweit nicht anders vermerkt, bei der Bundesanstalt für Wasserbau.&lt;br /&gt;
&lt;br /&gt;
Das Copyright für Bilder liegt, soweit nicht anders vermerkt, bei der Bundesanstalt für Wasserbau oder bei der Wasser- und Schifffahrtsverwaltung des Bundes.&lt;br /&gt;
&lt;br /&gt;
Auf diesen Webseiten zur Verfügung gestellte Texte, Textteile, Grafiken, Tabellen oder Bildmaterialien dürfen ohne vorherige Zustimmung der Bundesanstalt für Wasserbau nicht vervielfältigt, nicht verbreitet und nicht ausgestellt werden.&lt;br /&gt;
&lt;br /&gt;
===Nutzungsbedingungen für Bilder===&lt;br /&gt;
&lt;br /&gt;
# Die Bundesansalt für Wasserbau hat alle Nutzungsrechte von den Urhebern der digitalen Bilder erworben, soweit nichts Gegenteiliges, z.B. in den begleitenden Bildinformationen, angegeben ist.&lt;br /&gt;
# Die Bildinformationen und die darin enthaltenen Nutzungs- und Verwendungsbeschränkungen sind zu beachten. Für die aus der Nichtbeachtung resultierenden Schäden haftet der Nutzer. Er hat die Bundesanstalt für Wasserbau insoweit von Ansprüchen Dritter freizustellen. Für die Nutzung des Bildmaterials im historischen Bildarchiv der Bundeswasserstraßen gelten gesonderte Nutzungsbedingungen.&lt;br /&gt;
# Die Bilder können grundsätzlich kostenfrei heruntergeladen und im Rahmen der Berichterstattung für folgende Zwecke genutzt werden: &lt;br /&gt;
#* Presseveröffentlichungen&lt;br /&gt;
#* Veröffentlichungen durch Film und Fernsehen&lt;br /&gt;
#:Eine darüber hinausgehende Nutzung für kommerzielle Zwecke, insbesondere für Werbezwecke, ist nicht zulässig.&lt;br /&gt;
# Jegliche Bearbeitung, Umgestaltung oder Manipulation der digitalen Bilder, die über Farbkorrekturen, Ausschnitte und Verkleinerungen hinausgehen, ist unzulässig und nur mit vorheriger schriftlicher Zustimmung seitens der Bundesanstalt für Wasserbau erlaubt. Ebenso darf das digitale Bild nicht in einem sinnentstellten Zusammenhang wiedergegeben werden.&lt;br /&gt;
# Eine Entstellung des urheberrechtlichen geschützten Werks in Bild, Wort bzw. jeglicher anderen Form, z.B. durch Nachfotografieren, zeichnerische Verfälschung, Fotocomposing oder elektronische Hilfsmittel ist nicht zulässig. Der Nutzer trägt die Verantwortung für die Betextung.&lt;br /&gt;
# Die Presse ist insbesondere zur Beachtung der publizistischen Grundsätze des Deutschen Presserates (Pressecodex) verpflichtet. Die Zustimmung zur Nutzung des Bildmaterials umfasst nicht die Zusicherung, dass die abgebildeten Personen, die Inhaber der Rechte an abgebildeten Werken oder die Inhaber von Marken- und sonstigen Schutzrechten die Einwilligung zu einer öffentlichen Wiedergabe erteilt haben. Die Einholung der im Einzelfall notwendigen Einwilligungen Dritter obliegt dem Nutzer. Er hat die Persönlichkeits-, Urheber-, Marken- und sonstigen Schutzrechte von abgebildeten Personen, Werken, Gegenständen oder Zeichen selbst zu beachten. Bei Missachtung solcher Rechte ist allein der Nutzer etwaigen Dritten gegenüber schadenersatzpflichtig.&lt;br /&gt;
# Die Bundesanstalt für Wasserbau behält sich vor, dem Verdacht einer missbräuchlichen Nutzung oder einer wesentlichen Nutzungsverletzung nachzugehen.&lt;br /&gt;
# Bei Verwendung des digitalen Bildes ist die Quelle &amp;quot;Vor- und Nachname des Fotografen/BAW&amp;quot; anzugeben. Dies gilt auch für elektronische Publikationen (z.B. Webseiten). Von jeder Veröffentlichung im Druck ist der Bundesanstalt für Wasserbau ein Belegexemplar unaufgefordert und kostenfrei zuzusenden.&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Federal_waterways_engineering_and_research_institute&amp;diff=14611</id>
		<title>Federal waterways engineering and research institute</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Federal_waterways_engineering_and_research_institute&amp;diff=14611"/>
		<updated>2022-01-25T15:15:39Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{GlossaryEntry&lt;br /&gt;
|definition=The federal waterways engineering and research institute (BAW) is a central technical-scientific federal authority to support the federal ministry for digital affairs and transport (BMDV). It is the central service provider for advising and supporting the ministry and the federal waterways and shipping administration (WSV) as part of their waterway engineering tasks.&lt;br /&gt;
|name_de=Bundesanstalt_für_Wasserbau&lt;br /&gt;
|source=&lt;br /&gt;
|links=https://www.baw.de/EN/Home/home_node.html&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Federal_waterways_and_shipping_administration&amp;diff=14610</id>
		<title>Federal waterways and shipping administration</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Federal_waterways_and_shipping_administration&amp;diff=14610"/>
		<updated>2022-01-25T15:14:33Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{GlossaryEntry&lt;br /&gt;
|definition=The federal waterways and shipping administration (WSV) which is subordinate to the federal ministry for digital affairs and transport, is responsible for the administration of the federal waterways of the Federal Republic of Germany and the safety and ease of shipping traffic.&lt;br /&gt;
|name_de=Wasserstraßen-_und_Schifffahrtsverwaltung_des_Bundes&lt;br /&gt;
|source=&lt;br /&gt;
|links=https://www.baw.de/EN/Home/home_node.html&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Federal_ministry_for_digital_and_transport&amp;diff=14609</id>
		<title>Federal ministry for digital and transport</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Federal_ministry_for_digital_and_transport&amp;diff=14609"/>
		<updated>2022-01-25T15:13:46Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{GlossaryEntry&lt;br /&gt;
|definition=The federal ministry for digital and transport (BMDV) is a supreme federal authority of the Federal Republic of Germany.&lt;br /&gt;
|name_de=Bundesministerium_für_Digitales_und_Verkehr&lt;br /&gt;
|source=&lt;br /&gt;
|links=https://www.baw.de/EN/Home/home_node.html&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Federal_ministry_for_digital_and_transport&amp;diff=14608</id>
		<title>Federal ministry for digital and transport</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Federal_ministry_for_digital_and_transport&amp;diff=14608"/>
		<updated>2022-01-25T14:24:53Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{GlossaryEntry&lt;br /&gt;
|definition=The federal ministry for digital and transport (BMDV) is a supreme federal authority of the Federal Republic of Germany.&lt;br /&gt;
|name_de=Bundesministerium für Digitales und Verkehr&lt;br /&gt;
|source=&lt;br /&gt;
|links=&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Federal_waterways_and_shipping_administration&amp;diff=14607</id>
		<title>Federal waterways and shipping administration</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Federal_waterways_and_shipping_administration&amp;diff=14607"/>
		<updated>2022-01-25T14:23:44Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: Created page with &amp;quot;{{GlossaryEntry |definition=The federal waterways and shipping administration (WSV) which is subordinate to the federal ministry for digital affairs and transport, is responsi...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{GlossaryEntry&lt;br /&gt;
|definition=The federal waterways and shipping administration (WSV) which is subordinate to the federal ministry for digital affairs and transport, is responsible for the administration of the federal waterways of the Federal Republic of Germany and the safety and ease of shipping traffic.&lt;br /&gt;
|name_de=Wasserstraßen- und Schifffahrtsverwaltung des Bundes&lt;br /&gt;
|source=&lt;br /&gt;
|links=&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Federal_waterways_engineering_and_research_institute&amp;diff=14606</id>
		<title>Federal waterways engineering and research institute</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Federal_waterways_engineering_and_research_institute&amp;diff=14606"/>
		<updated>2022-01-25T14:22:29Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{GlossaryEntry&lt;br /&gt;
|definition=The federal waterways engineering and research institute (BAW) is a central technical-scientific federal authority to support the federal ministry for digital affairs and transport (BMDV). It is the central service provider for advising and supporting the ministry and the federal waterways and shipping administration (WSV) as part of their waterway engineering tasks.&lt;br /&gt;
|name_de=Bundesanstalt für Wasserbau&lt;br /&gt;
|source=&lt;br /&gt;
|links=&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Federal_ministry_for_digital_and_transport&amp;diff=14605</id>
		<title>Federal ministry for digital and transport</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Federal_ministry_for_digital_and_transport&amp;diff=14605"/>
		<updated>2022-01-25T14:13:03Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: Created page with &amp;quot;{{GlossaryEntry |definition=The federal ministry for digital and transport (BMDV) is a supreme federal authority of the federal republic of Germany. |name_de=Bundesministerium...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{GlossaryEntry&lt;br /&gt;
|definition=The federal ministry for digital and transport (BMDV) is a supreme federal authority of the federal republic of Germany.&lt;br /&gt;
|name_de=Bundesministerium für Digitales und Verkehr&lt;br /&gt;
|source=&lt;br /&gt;
|links=&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Federal_waterways_engineering_and_research_institute&amp;diff=14604</id>
		<title>Federal waterways engineering and research institute</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Federal_waterways_engineering_and_research_institute&amp;diff=14604"/>
		<updated>2022-01-25T14:09:39Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: Created page with &amp;quot;{{GlossaryEntry |definition=The federal waterways engineering and research institute (BAW) is a central technical-scientific federal authority to support the Federal Ministry...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{GlossaryEntry&lt;br /&gt;
|definition=The federal waterways engineering and research institute (BAW) is a central technical-scientific federal authority to support the Federal Ministry for Digital Affairs and Transport (BMDV). It is the central service provider for advising and supporting the Ministry and the Federal Waterways and Shipping Administration (WSV) as part of their waterway engineering tasks.&lt;br /&gt;
|name_de=Bundesanstalt für Wasserbau&lt;br /&gt;
|source=&lt;br /&gt;
|links=&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=MediaWiki:Common.css&amp;diff=14516</id>
		<title>MediaWiki:Common.css</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=MediaWiki:Common.css&amp;diff=14516"/>
		<updated>2021-01-27T15:52:32Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;/* CSS placed here will be applied to all skins */&lt;br /&gt;
&lt;br /&gt;
/* shows british flag infront of laguage change button */&lt;br /&gt;
#p-lang &amp;gt; a:before {&lt;br /&gt;
	padding: 0 5px 0 0;&lt;br /&gt;
	content: url(&amp;quot;resources/assets/uk_small.png&amp;quot;);&lt;br /&gt;
	vertical-align: -5%;&lt;br /&gt;
}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=MediaWiki:Common.css&amp;diff=14515</id>
		<title>MediaWiki:Common.css</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=MediaWiki:Common.css&amp;diff=14515"/>
		<updated>2021-01-27T15:51:11Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: Created page with &amp;quot;/* CSS placed here will be applied to all skins */ #p-lang &amp;gt; a:before { 	/* picture 20px width */ 	padding: 0 5px 0 0; 	content: url(&amp;quot;resources/assets/uk_small.png&amp;quot;); 	vertica...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;/* CSS placed here will be applied to all skins */&lt;br /&gt;
#p-lang &amp;gt; a:before {&lt;br /&gt;
	/* picture 20px width */&lt;br /&gt;
	padding: 0 5px 0 0;&lt;br /&gt;
	content: url(&amp;quot;resources/assets/uk_small.png&amp;quot;);&lt;br /&gt;
	vertical-align: -5%;&lt;br /&gt;
}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=BAWiki:Privacy_policy&amp;diff=14510</id>
		<title>BAWiki:Privacy policy</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=BAWiki:Privacy_policy&amp;diff=14510"/>
		<updated>2020-12-01T11:16:40Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Privacy policy==&lt;br /&gt;
&lt;br /&gt;
The Federal Waterways Engineering and Research Institute (BAW) takes the privacy of your personal data very seriously. We want you to know which data we collect and when, and also how we use this data. We have taken technical and organisational measures to ensure that both we and external service providers comply with data protection provisions. &lt;br /&gt;
&lt;br /&gt;
The BAW website can be used without disclosing any personal information.&lt;br /&gt;
&lt;br /&gt;
===Access to online content ===&lt;br /&gt;
When you visit our website for information purposes, our servers located in Germany only save the personal data transmitted to them by your browser. The log file stores the following data for a maximum of 30 days:&lt;br /&gt;
&lt;br /&gt;
* client’s IP address&lt;br /&gt;
* identity of the client’s PC&lt;br /&gt;
* time of the request&lt;br /&gt;
* URL&lt;br /&gt;
* HTTP status code &lt;br /&gt;
* size of the requested object&lt;br /&gt;
* referrer&lt;br /&gt;
* browser type and version&lt;br /&gt;
&lt;br /&gt;
All data stored are evaluated solely for the purpose of optimising the online content.&lt;br /&gt;
&lt;br /&gt;
===Information material, newsletters, contact forms===&lt;br /&gt;
If you order any information material or newsletters, we will ask you for your name and other personal data. You are free to decide whether or not to submit this information. We store your data on specially protected servers in Germany. Access hereto is limited to a small number of authorised persons who handle the technical or editorial maintenance of the servers.&lt;br /&gt;
&lt;br /&gt;
You can contact us directly via the contact forms available on our website. We collect, process and use the information provided by you via a contact form exclusively for the processing of your specific request and only with your consent.&lt;br /&gt;
&lt;br /&gt;
===Transmission of personal data to third parties ===&lt;br /&gt;
If you order any information material, the personal data that you submit will only be used within the BAW and the companies contracted to undertake the dispatch of information material. We will not forward your data to third parties without your explicit consent. Where we are required to do so by law or by the ruling of a court, we will forward your data to the relevant authorised agencies.&lt;br /&gt;
&lt;br /&gt;
===Use of cookies===&lt;br /&gt;
When you visit our website, information is stored on your computer in the form of cookies. Cookies help in many different ways to make your visit to our website easier, more comfortable and more intuitive. Cookies are text files that are automatically stored on your computer’s hard drive by your web browser whenever you visit our website.&lt;br /&gt;
&lt;br /&gt;
By using the corresponding settings, you can configure your browser at any time in such a way that no cookies are stored on your computer and that you therefore reject the placing of cookies on your computer. You can also delete existing cookies at any time via an Internet browser or other software programmes. This is possible in all standard web browsers. If you disable cookies in your Internet browser, the use of certain functions of our website may be restricted. &lt;br /&gt;
&lt;br /&gt;
We only use technically necessary cookies.&lt;br /&gt;
&lt;br /&gt;
===Statistics===&lt;br /&gt;
We analyse access to our web pages from a statistical perspective in order to optimise our con-tent. We do this using the open source application “AWStats”. AWStats uses our web server log file in order to conduct the analysis. Information regarding your use of this website is not for-warded to third parties. &lt;br /&gt;
&lt;br /&gt;
AWStats does not transfer any data to servers outside the control of the BAW.&lt;br /&gt;
&lt;br /&gt;
===Links ===&lt;br /&gt;
This privacy policy does not cover the websites of third parties to which a link is provided on our website. &lt;br /&gt;
&lt;br /&gt;
The providers of these websites are solely responsible for the contents contained therein. While applying a reasonable standard of review, unlawful contents were not recognisable at the time the link was created. Should any breach of the law come to our knowledge, we will remove these links immediately.&lt;br /&gt;
&lt;br /&gt;
===Protection of minors===&lt;br /&gt;
Persons under the age of 18 should not transmit any personal data without the prior consent of their parents or guardians. We do not request any personal data from children or adolescents. We do not knowingly collect or forward such data to third parties.&lt;br /&gt;
&lt;br /&gt;
===Right of access, rectification and erasure===&lt;br /&gt;
You shall have the right at any time to &lt;br /&gt;
* access, &lt;br /&gt;
* rectification, &lt;br /&gt;
* erasure, &lt;br /&gt;
* restriction of processing, &lt;br /&gt;
* objection to processing, and &lt;br /&gt;
* data portability &lt;br /&gt;
&lt;br /&gt;
with regard to the data stored in respect of you as a person, the origin of the data as well as the purpose of their storage, provided the following does not apply: &lt;br /&gt;
&lt;br /&gt;
Inquiries from the general public, both in paper and electronic form, are stored in accordance with the period for retaining records set by the Registry Directive, which complements the Joint Rules of Procedures of the Federal Ministries (GGO).&lt;br /&gt;
&lt;br /&gt;
Questions and complaints may be directed to the BAW’s Data Protection Officer.&lt;br /&gt;
&lt;br /&gt;
===Official data protection officer===&lt;br /&gt;
Sigfrid Knapp&amp;lt;br/&amp;gt;&lt;br /&gt;
Phone: +49 (0) 721 9726-4550&amp;lt;br/&amp;gt;&lt;br /&gt;
E-Mail: datenschutz@baw.de&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Category:Glossary&amp;diff=14503</id>
		<title>Category:Glossary</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Category:Glossary&amp;diff=14503"/>
		<updated>2020-10-21T14:34:56Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Category TOC|align=center|top=no|numerals=no}}&lt;br /&gt;
[[de:Kategorie:Glossar]]&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Category:Glossary&amp;diff=14502</id>
		<title>Category:Glossary</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Category:Glossary&amp;diff=14502"/>
		<updated>2020-10-21T14:34:49Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{CategoryTOC|align=center|top=no|numerals=no}}&lt;br /&gt;
[[de:Kategorie:Glossar]]&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Category:Glossary&amp;diff=14501</id>
		<title>Category:Glossary</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Category:Glossary&amp;diff=14501"/>
		<updated>2020-10-21T14:22:08Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Category TOC|align=center|top=no|numerals=no}}&lt;br /&gt;
[[de:Kategorie:Glossar]]&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Namespace_detect/data&amp;diff=14500</id>
		<title>Module:Namespace detect/data</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Namespace_detect/data&amp;diff=14500"/>
		<updated>2020-10-21T14:21:46Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Namespace_detect/config&amp;diff=14498</id>
		<title>Module:Namespace detect/config</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Namespace_detect/config&amp;diff=14498"/>
		<updated>2020-10-21T14:21:46Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Namespace_detect&amp;diff=14496</id>
		<title>Module:Namespace detect</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Namespace_detect&amp;diff=14496"/>
		<updated>2020-10-21T14:21:45Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
--                                                                            --&lt;br /&gt;
--                            NAMESPACE DETECT                                --&lt;br /&gt;
--                                                                            --&lt;br /&gt;
-- This module implements the {{namespace detect}} template in Lua, with a    --&lt;br /&gt;
-- few improvements: all namespaces and all namespace aliases are supported,  --&lt;br /&gt;
-- and namespace names are detected automatically for the local wiki. The     --&lt;br /&gt;
-- module can also use the corresponding subject namespace value if it is     --&lt;br /&gt;
-- used on a talk page. Parameter names can be configured for different wikis --&lt;br /&gt;
-- by altering the values in the &amp;quot;cfg&amp;quot; table in                               --&lt;br /&gt;
-- Module:Namespace detect/config.                                            --&lt;br /&gt;
--                                                                            --&lt;br /&gt;
--------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
local data = mw.loadData(&#039;Module:Namespace detect/data&#039;)&lt;br /&gt;
local argKeys = data.argKeys&lt;br /&gt;
local cfg = data.cfg&lt;br /&gt;
local mappings = data.mappings&lt;br /&gt;
&lt;br /&gt;
local yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
local mArguments -- Lazily initialise Module:Arguments&lt;br /&gt;
local mTableTools -- Lazily initilalise Module:TableTools&lt;br /&gt;
local ustringLower = mw.ustring.lower&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function fetchValue(t1, t2)&lt;br /&gt;
	-- Fetches a value from the table t1 for the first key in array t2 where&lt;br /&gt;
	-- a non-nil value of t1 exists.&lt;br /&gt;
	for i, key in ipairs(t2) do&lt;br /&gt;
		local value = t1[key]&lt;br /&gt;
		if value ~= nil then&lt;br /&gt;
			return value&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function equalsArrayValue(t, value)&lt;br /&gt;
	-- Returns true if value equals a value in the array t. Otherwise&lt;br /&gt;
	-- returns false.&lt;br /&gt;
	for i, arrayValue in ipairs(t) do&lt;br /&gt;
		if value == arrayValue then&lt;br /&gt;
			return true&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return false&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.getPageObject(page)&lt;br /&gt;
	-- Get the page object, passing the function through pcall in case of&lt;br /&gt;
	-- errors, e.g. being over the expensive function count limit.&lt;br /&gt;
	if page then&lt;br /&gt;
		local success, pageObject = pcall(mw.title.new, page)&lt;br /&gt;
		if success then&lt;br /&gt;
			return pageObject&lt;br /&gt;
		else&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		return mw.title.getCurrentTitle()&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Provided for backward compatibility with other modules&lt;br /&gt;
function p.getParamMappings()&lt;br /&gt;
	return mappings&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getNamespace(args)&lt;br /&gt;
	-- This function gets the namespace name from the page object.&lt;br /&gt;
	local page = fetchValue(args, argKeys.demopage)&lt;br /&gt;
	if page == &#039;&#039; then&lt;br /&gt;
		page = nil&lt;br /&gt;
	end&lt;br /&gt;
	local demospace = fetchValue(args, argKeys.demospace)&lt;br /&gt;
	if demospace == &#039;&#039; then&lt;br /&gt;
		demospace = nil&lt;br /&gt;
	end&lt;br /&gt;
	local subjectns = fetchValue(args, argKeys.subjectns)&lt;br /&gt;
	local ret&lt;br /&gt;
	if demospace then&lt;br /&gt;
		-- Handle &amp;quot;demospace = main&amp;quot; properly.&lt;br /&gt;
		if equalsArrayValue(argKeys.main, ustringLower(demospace)) then&lt;br /&gt;
			ret = mw.site.namespaces[0].name&lt;br /&gt;
		else&lt;br /&gt;
			ret = demospace&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		local pageObject = p.getPageObject(page)&lt;br /&gt;
		if pageObject then&lt;br /&gt;
			if pageObject.isTalkPage then&lt;br /&gt;
				-- Get the subject namespace if the option is set,&lt;br /&gt;
				-- otherwise use &amp;quot;talk&amp;quot;.&lt;br /&gt;
				if yesno(subjectns) then&lt;br /&gt;
					ret = mw.site.namespaces[pageObject.namespace].subject.name&lt;br /&gt;
				else&lt;br /&gt;
					ret = &#039;talk&#039;&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				ret = pageObject.nsText&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			return nil -- return nil if the page object doesn&#039;t exist.&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	ret = ret:gsub(&#039;_&#039;, &#039; &#039;)&lt;br /&gt;
	return ustringLower(ret)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(args)&lt;br /&gt;
	-- Check the parameters stored in the mappings table for any matches.&lt;br /&gt;
	local namespace = getNamespace(args) or &#039;other&#039; -- &amp;quot;other&amp;quot; avoids nil table keys&lt;br /&gt;
	local params = mappings[namespace] or {}&lt;br /&gt;
	local ret = fetchValue(args, params)&lt;br /&gt;
	--[[&lt;br /&gt;
	-- If there were no matches, return parameters for other namespaces.&lt;br /&gt;
	-- This happens if there was no text specified for the namespace that&lt;br /&gt;
	-- was detected or if the demospace parameter is not a valid&lt;br /&gt;
	-- namespace. Note that the parameter for the detected namespace must be&lt;br /&gt;
	-- completely absent for this to happen, not merely blank.&lt;br /&gt;
	--]]&lt;br /&gt;
	if ret == nil then&lt;br /&gt;
		ret = fetchValue(args, argKeys.other)&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	mArguments = require(&#039;Module:Arguments&#039;)&lt;br /&gt;
	local args = mArguments.getArgs(frame, {removeBlanks = false})&lt;br /&gt;
	local ret = p._main(args)&lt;br /&gt;
	return ret or &#039;&#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.table(frame)&lt;br /&gt;
	--[[&lt;br /&gt;
	-- Create a wikitable of all subject namespace parameters, for&lt;br /&gt;
	-- documentation purposes. The talk parameter is optional, in case it&lt;br /&gt;
	-- needs to be excluded in the documentation.&lt;br /&gt;
	--]]&lt;br /&gt;
	&lt;br /&gt;
	-- Load modules and initialise variables.&lt;br /&gt;
	mTableTools = require(&#039;Module:TableTools&#039;)&lt;br /&gt;
	local namespaces = mw.site.namespaces&lt;br /&gt;
	local cfg = data.cfg&lt;br /&gt;
	local useTalk = type(frame) == &#039;table&#039; &lt;br /&gt;
		and type(frame.args) == &#039;table&#039; &lt;br /&gt;
		and yesno(frame.args.talk) -- Whether to use the talk parameter.&lt;br /&gt;
	&lt;br /&gt;
	-- Get the header names.&lt;br /&gt;
	local function checkValue(value, default)&lt;br /&gt;
		if type(value) == &#039;string&#039; then&lt;br /&gt;
			return value&lt;br /&gt;
		else&lt;br /&gt;
			return default&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local nsHeader = checkValue(cfg.wikitableNamespaceHeader, &#039;Namespace&#039;)&lt;br /&gt;
	local aliasesHeader = checkValue(cfg.wikitableAliasesHeader, &#039;Aliases&#039;)&lt;br /&gt;
&lt;br /&gt;
	-- Put the namespaces in order.&lt;br /&gt;
	local mappingsOrdered = {}&lt;br /&gt;
	for nsname, params in pairs(mappings) do&lt;br /&gt;
		if useTalk or nsname ~= &#039;talk&#039; then&lt;br /&gt;
			local nsid = namespaces[nsname].id&lt;br /&gt;
			-- Add 1, as the array must start with 1; nsid 0 would be lost otherwise.&lt;br /&gt;
			nsid = nsid + 1 &lt;br /&gt;
			mappingsOrdered[nsid] = params&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	mappingsOrdered = mTableTools.compressSparseArray(mappingsOrdered)&lt;br /&gt;
&lt;br /&gt;
	-- Build the table.&lt;br /&gt;
	local ret = &#039;{| class=&amp;quot;wikitable&amp;quot;&#039;&lt;br /&gt;
		.. &#039;\n|-&#039;&lt;br /&gt;
		.. &#039;\n! &#039; .. nsHeader&lt;br /&gt;
		.. &#039;\n! &#039; .. aliasesHeader&lt;br /&gt;
	for i, params in ipairs(mappingsOrdered) do&lt;br /&gt;
		for j, param in ipairs(params) do&lt;br /&gt;
			if j == 1 then&lt;br /&gt;
				ret = ret .. &#039;\n|-&#039;&lt;br /&gt;
					.. &#039;\n| &amp;lt;code&amp;gt;&#039; .. param .. &#039;&amp;lt;/code&amp;gt;&#039;&lt;br /&gt;
					.. &#039;\n| &#039;&lt;br /&gt;
			elseif j == 2 then&lt;br /&gt;
				ret = ret .. &#039;&amp;lt;code&amp;gt;&#039; .. param .. &#039;&amp;lt;/code&amp;gt;&#039;&lt;br /&gt;
			else&lt;br /&gt;
				ret = ret .. &#039;, &amp;lt;code&amp;gt;&#039; .. param .. &#039;&amp;lt;/code&amp;gt;&#039;&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	ret = ret .. &#039;\n|-&#039;&lt;br /&gt;
		.. &#039;\n|}&#039;&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:HTMLDecode/doc&amp;diff=14494</id>
		<title>Module:HTMLDecode/doc</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:HTMLDecode/doc&amp;diff=14494"/>
		<updated>2020-10-21T14:21:45Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;!-- Please place categories where indicated at the bottom of this page and interwikis at Wikidata (see [[Wikipedia:Wikidata]]) --&amp;gt;&lt;br /&gt;
Only&amp;lt;ref name=&amp;quot;undefined&amp;quot; /&amp;gt;== Usage ==&lt;br /&gt;
&#039;&#039;&#039;Module:HTMLDecode&#039;&#039;&#039; can be used to remove HTML encoding from any text.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{&amp;lt;/nowiki&amp;gt;#invoke:HTMLDecode | HTMLDecode | text=***text to remove HTML encoding from*** }}&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;includeonly&amp;gt;{{#ifeq:{{SUBPAGENAME}}|sandbox | |&lt;br /&gt;
&amp;lt;!-- Categories below this line, please; interwikis at Wikidata --&amp;gt;&lt;br /&gt;
&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Template:Broken_ref/lang&amp;diff=14492</id>
		<title>Template:Broken ref/lang</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Template:Broken_ref/lang&amp;diff=14492"/>
		<updated>2020-10-21T14:21:44Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;noinclude&amp;gt;{{pp-template|small=yes}}{{used in system}}&amp;lt;/noinclude&amp;gt;{{{msg|&amp;lt;span class=&amp;quot;error&amp;quot;&amp;gt;Error: no message set for {{tl|broken ref}}&amp;lt;/span&amp;gt;}}} ({{#switch:{{{lang|}}}&lt;br /&gt;
| en    = see the [[Help:Cite errors/{{{help|}}}|help page]]&lt;br /&gt;
| es    = consulta la [[Help:Cite errors/{{{help|}}}|página de ayuda]]&lt;br /&gt;
| en-gb = see the [[Help:Cite errors/{{{help|}}}|help page]]&lt;br /&gt;
| fr    = vous pouvez consulter [[Help:Cite errors/{{{help|}}}|la page d&#039;aide]] pour plus d&#039;informations&lt;br /&gt;
| pt-br = veja [[Help:Cite errors/{{{help|}}}|a página de ajuda]] para mais informações&lt;br /&gt;
| ru    = подробнее см. [[Help:Cite errors/{{{help|}}}|справочную страницу]]&lt;br /&gt;
| de    = siehe die [[Help:Cite errors/{{{help|}}}|Hilfeseite]] für weitere Informationen&lt;br /&gt;
| id    = lihat [[Help:Cite errors/{{{help|}}}|halaman bantuan]] untuk informasi lebih lanjut&lt;br /&gt;
| ar    =  [[Help:Cite errors/{{{help|}}}|صفحة المساعدة]] للمزيد من المعلومات&lt;br /&gt;
| nl    = meer informatie staat op de [[Help:Cite errors/{{{help|}}}|hulppagina]]&lt;br /&gt;
| zh-cn = 详情参见[[Help:Cite errors/{{{help|}}}|帮助页]].&lt;br /&gt;
| ro    = vedeți [[Help:Cite errors/{{{help|}}}|pagina de ajutor]] pentru mai multe informații&lt;br /&gt;
| it    = vedi la [[Help:Cite errors/{{{help|}}}|pagina di aiuto]] per maggiori informazioni&lt;br /&gt;
| tr    = [[Help:Cite errors/{{{help|}}}|yardım sayfasına]] bakınız&lt;br /&gt;
| en-ca = see the [[Help:Cite errors/{{{help|}}}|help page]]&lt;br /&gt;
}}).&amp;lt;!-- Languages are in order by preference popularity --&amp;gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Template:Broken_ref&amp;diff=14490</id>
		<title>Template:Broken ref</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Template:Broken_ref&amp;diff=14490"/>
		<updated>2020-10-21T14:21:44Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;!-- Prefix: MediaWiki:Cite error --&amp;gt;{{#if:{{{prefix|}}}&lt;br /&gt;
 |{{#invoke:Namespace detect|main&lt;br /&gt;
 | main              = {{{prefix|}}}&lt;br /&gt;
 | category          = {{{prefix|}}}&lt;br /&gt;
 | template          = {{{prefix|}}}&lt;br /&gt;
 | file              = {{{prefix|}}}&lt;br /&gt;
 | help              = {{{prefix|}}}&lt;br /&gt;
 | portal            = {{{prefix|}}}&lt;br /&gt;
 | wikipedia         = {{{prefix|}}}&lt;br /&gt;
 | draft             = {{{prefix|}}}&lt;br /&gt;
 | other             = &amp;lt;span class=&amp;quot;brokenref&amp;quot;&amp;gt;{{{prefix|}}}&amp;lt;/span&amp;gt;&lt;br /&gt;
}}&amp;lt;!-- All other errors --&amp;gt;|{{#invoke:Namespace detect|main&lt;br /&gt;
 | main              = {{broken ref/lang |msg={{{msg|}}} |lang={{{lang|}}} |help={{{help|}}}}}&lt;br /&gt;
 | category          = {{broken ref/lang |msg={{{msg|}}} |lang={{{lang|}}} |help={{{help|}}}}}&lt;br /&gt;
 | template          = {{broken ref/lang |msg={{{msg|}}} |lang={{{lang|}}} |help={{{help|}}}}}&lt;br /&gt;
 | file              = {{broken ref/lang |msg={{{msg|}}} |lang={{{lang|}}} |help={{{help|}}}}}&lt;br /&gt;
 | help              = {{broken ref/lang |msg={{{msg|}}} |lang={{{lang|}}} |help={{{help|}}}}}&lt;br /&gt;
 | portal            = {{broken ref/lang |msg={{{msg|}}} |lang={{{lang|}}} |help={{{help|}}}}}&lt;br /&gt;
 | wikipedia         = {{broken ref/lang |msg={{{msg|}}} |lang={{{lang|}}} |help={{{help|}}}}}&lt;br /&gt;
 | draft             = {{broken ref/lang |msg={{{msg|}}} |lang={{{lang|}}} |help={{{help|}}}}}&lt;br /&gt;
 | other             = &amp;lt;span class=&amp;quot;brokenref&amp;quot;&amp;gt;{{broken ref/lang |msg={{{msg|}}} |lang={{{lang|}}} |help={{{help|}}} }}&amp;lt;/span&amp;gt;&lt;br /&gt;
}}&amp;lt;!-- Category management --&amp;gt;{{#invoke:Namespace detect|main&lt;br /&gt;
 | main              = {{broken ref/cat |help={{{help|}}} |nocat={{{nocat|}}} |sortkey=}}&lt;br /&gt;
 | category          = {{broken ref/cat |help={{{help|}}} |nocat={{{nocat|}}} |sortkey=γ}}&lt;br /&gt;
 | template          = {{broken ref/cat |help={{{help|}}} |nocat={{{nocat|}}} |sortkey=τ}}&lt;br /&gt;
 | file              = {{broken ref/cat |help={{{help|}}} |nocat={{{nocat|}}} |sortkey=ι}}&lt;br /&gt;
 | help              = {{broken ref/cat |help={{{help|}}} |nocat={{{nocat|}}} |sortkey=ω}}&lt;br /&gt;
 | portal            = {{broken ref/cat |help={{{help|}}} |nocat={{{nocat|}}} |sortkey=ρ}}&lt;br /&gt;
 | wikipedia         = {{broken ref/cat |help={{{help|}}} |nocat={{{nocat|}}} |sortkey=ψ}}&lt;br /&gt;
 | draft             = {{broken ref/cat |help={{{help|}}} |nocat={{{nocat|}}} |sortkey=δ}}&lt;br /&gt;
 | other             = &lt;br /&gt;
}}&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;noinclude&amp;gt;{{documentation}}&lt;br /&gt;
&amp;lt;!-- Add categories and interwikis to the /doc subpage, not here! --&amp;gt;&lt;br /&gt;
{{reflist}} &amp;lt;!-- dummy to steer automated tools away from this template --&amp;gt;&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:HTMLDecode&amp;diff=14488</id>
		<title>Module:HTMLDecode</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:HTMLDecode&amp;diff=14488"/>
		<updated>2020-10-21T14:21:44Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local i = {};&lt;br /&gt;
&lt;br /&gt;
function i.HTMLDecode(frame)&lt;br /&gt;
    return mw.text.decode(frame.args[&amp;quot;text&amp;quot;]);&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return i;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Template:Pp-template&amp;diff=14486</id>
		<title>Template:Pp-template</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Template:Pp-template&amp;diff=14486"/>
		<updated>2020-10-21T14:19:40Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;{{#invoke:Protection banner|main}}&amp;lt;/includeonly&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;!-- Categories go on the /doc subpage, and interwikis go on Wikidata. --&amp;gt;&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Template:Category_TOC/tracking&amp;diff=14484</id>
		<title>Template:Category TOC/tracking</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Template:Category_TOC/tracking&amp;diff=14484"/>
		<updated>2020-10-21T14:19:39Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;noinclude&amp;gt;{{pp-template|small=yes}}&amp;lt;/noinclude&amp;gt;&amp;lt;!--&lt;br /&gt;
 ############################################################################&lt;br /&gt;
 # NOTE: The sort key {{PAGENAME}} is used on all these tracking categories #&lt;br /&gt;
 #       to override any {{DEFAULTSORT}} used in the category               #&lt;br /&gt;
 ############################################################################&lt;br /&gt;
--&amp;gt;&amp;lt;includeonly&amp;gt;&amp;lt;!--&lt;br /&gt;
--&amp;gt;{{#ifexpr: {{{pagecount|}}} &amp;lt;= 0&amp;lt;!--&lt;br /&gt;
    --&amp;gt;|[[Category:Template Category TOC on pages where PAGESINCATEGORY returns zero]]&amp;lt;!--&lt;br /&gt;
    --&amp;gt;|{{#ifexpr: {{{pagecount|}}} &amp;lt;= 100&amp;lt;!--&lt;br /&gt;
        --&amp;gt;|[[Category:Template Category TOC on category with up to 100 pages]]&amp;lt;!--&lt;br /&gt;
        --&amp;gt;|{{#ifexpr: {{{pagecount|}}} &amp;lt;= 200&amp;lt;!--&lt;br /&gt;
            --&amp;gt;|{{#ifeq: {{{CatAutoTOC|}}} |yes&amp;lt;!--&lt;br /&gt;
                --&amp;gt;|[[Category:Template Category TOC via CatAutoTOC on category with 101–200 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                --&amp;gt;|[[Category:Template Category TOC without CatAutoTOC on category with 101–200 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
            --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
            --&amp;gt;|{{#ifexpr: {{{pagecount|}}} &amp;lt;= 300&amp;lt;!--&lt;br /&gt;
                --&amp;gt;|{{#ifeq: {{{CatAutoTOC|}}} |yes&amp;lt;!--&lt;br /&gt;
                    --&amp;gt;|[[Category:Template Category TOC via CatAutoTOC on category with 201–300 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                    --&amp;gt;|[[Category:Template Category TOC without CatAutoTOC on category with 201–300 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
                --&amp;gt;|{{#ifexpr: {{{pagecount|}}} &amp;lt;= 600&amp;lt;!--&lt;br /&gt;
                    --&amp;gt;|{{#ifeq: {{{CatAutoTOC|}}} |yes&amp;lt;!--&lt;br /&gt;
                        --&amp;gt;|[[Category:Template Category TOC via CatAutoTOC on category with 301–600 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                        --&amp;gt;|[[Category:Template Category TOC without CatAutoTOC on category with 301–600 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                    --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
                    --&amp;gt;|{{#ifexpr: {{{pagecount|}}} &amp;lt;= 900&amp;lt;!--&lt;br /&gt;
                        --&amp;gt;|{{#ifeq: {{{CatAutoTOC|}}} |yes&amp;lt;!--&lt;br /&gt;
                            --&amp;gt;|[[Category:Template Category TOC via CatAutoTOC on category with 601–900 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                            --&amp;gt;|[[Category:Template Category TOC without CatAutoTOC on category with 601–900 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                        --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
                            --&amp;gt;|{{#ifexpr: {{{pagecount|}}} &amp;lt;= 1200&amp;lt;!--&lt;br /&gt;
                                --&amp;gt;|{{#ifeq: {{{CatAutoTOC|}}} |yes&amp;lt;!--&lt;br /&gt;
                                    --&amp;gt;|[[Category:Template Category TOC via CatAutoTOC on category with 901–1200 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                                    --&amp;gt;|[[Category:Template Category TOC without CatAutoTOC on category with 901–1200 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                                --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
                                --&amp;gt;|&amp;lt;!-- #pagecount is &amp;gt; 1200 &lt;br /&gt;
                                  --&amp;gt;[[Category:Template Category TOC on category with over 1200 pages|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
                             --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
                    --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
                --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
            --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
        --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
    --&amp;gt;}}&amp;lt;!--&lt;br /&gt;
--&amp;gt;}}&amp;lt;!--&lt;br /&gt;
--&amp;gt;{{#switch: {{{align|}}}&amp;lt;!--&lt;br /&gt;
    --&amp;gt;|center|right=[[Category:Template Category TOC with non-left alignment|{{PAGENAME}}]]&amp;lt;!--&lt;br /&gt;
--&amp;gt;}}&amp;lt;!--&lt;br /&gt;
--&amp;gt;&amp;lt;/includeonly&amp;gt;&amp;lt;!--&lt;br /&gt;
--&amp;gt;&amp;lt;noinclude&amp;gt;&amp;lt;!--&lt;br /&gt;
--&amp;gt;{{documentation|content=This is a sub-template for [[Template:Category TOC]].  All the tracking is done via this template.&lt;br /&gt;
== See also ==&lt;br /&gt;
* [[:Template:Large category TOC/tracking]]&lt;br /&gt;
}}&amp;lt;!--&lt;br /&gt;
--&amp;gt;&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Yesno&amp;diff=14482</id>
		<title>Module:Yesno</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Yesno&amp;diff=14482"/>
		<updated>2020-10-21T14:17:21Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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 val == &#039;on&#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 val == &#039;off&#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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Transclusion_count/data/C&amp;diff=14480</id>
		<title>Module:Transclusion count/data/C</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Transclusion_count/data/C&amp;diff=14480"/>
		<updated>2020-10-21T14:17:21Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;return {&lt;br /&gt;
[&amp;quot;C&amp;quot;] = 514000,&lt;br /&gt;
[&amp;quot;C-Class&amp;quot;] = 59000,&lt;br /&gt;
[&amp;quot;C-SPAN&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;C-cmn&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;C-pl&amp;quot;] = 53000,&lt;br /&gt;
[&amp;quot;CAN&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;CANelec&amp;quot;] = 8800,&lt;br /&gt;
[&amp;quot;CANelec/hold&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;CANelec/source&amp;quot;] = 5000,&lt;br /&gt;
[&amp;quot;CANelec/top&amp;quot;] = 5100,&lt;br /&gt;
[&amp;quot;CANelec/total&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;CAS&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;CBB_Standings_End&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;CBB_Standings_Entry&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;CBB_Standings_Start&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;CBB_Yearly_Record_End&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;CBB_Yearly_Record_Entry&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;CBB_Yearly_Record_Start&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;CBB_Yearly_Record_Subhead&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;CBB_Yearly_Record_Subtotal&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;CBB_roster/Footer&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;CBB_roster/Header&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;CBB_roster/Player&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;CBB_schedule_end&amp;quot;] = 7700,&lt;br /&gt;
[&amp;quot;CBB_schedule_entry&amp;quot;] = 7700,&lt;br /&gt;
[&amp;quot;CBB_schedule_start&amp;quot;] = 7700,&lt;br /&gt;
[&amp;quot;CBB_yearly_record_end&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;CBB_yearly_record_end/legend&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;CBB_yearly_record_entry&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;CBB_yearly_record_start&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;CBB_yearly_record_subhead&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;CBB_yearly_record_subtotal&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;CBSB_Standings_End&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;CBSB_Standings_Entry&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;CBSB_Standings_Start&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;CBSB_link&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;CC0&amp;quot;] = 5700,&lt;br /&gt;
[&amp;quot;CENTURY&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;CFB_Standings_End&amp;quot;] = 26000,&lt;br /&gt;
[&amp;quot;CFB_Standings_Entry&amp;quot;] = 26000,&lt;br /&gt;
[&amp;quot;CFB_Standings_Start&amp;quot;] = 26000,&lt;br /&gt;
[&amp;quot;CFB_Yearly_Record_End&amp;quot;] = 5700,&lt;br /&gt;
[&amp;quot;CFB_Yearly_Record_End/legend&amp;quot;] = 2000,&lt;br /&gt;
[&amp;quot;CFB_Yearly_Record_Entry&amp;quot;] = 5700,&lt;br /&gt;
[&amp;quot;CFB_Yearly_Record_Start&amp;quot;] = 5700,&lt;br /&gt;
[&amp;quot;CFB_Yearly_Record_Subhead&amp;quot;] = 5700,&lt;br /&gt;
[&amp;quot;CFB_Yearly_Record_Subtotal&amp;quot;] = 5600,&lt;br /&gt;
[&amp;quot;CFB_schedule&amp;quot;] = 20000,&lt;br /&gt;
[&amp;quot;CFB_schedule_entry&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;CFL_Year&amp;quot;] = 4800,&lt;br /&gt;
[&amp;quot;CGF_year&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;CHE&amp;quot;] = 9200,&lt;br /&gt;
[&amp;quot;CHI&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;CHL&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;CHN&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;COI&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;COIUL&amp;quot;] = 112000,&lt;br /&gt;
[&amp;quot;COI_editnotice&amp;quot;] = 5300,&lt;br /&gt;
[&amp;quot;COL&amp;quot;] = 4400,&lt;br /&gt;
[&amp;quot;COLON&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;CRO&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;CSK&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;CSS_image_crop&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;CUB&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;CURRENTDATE&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;CURRENTMINUTE&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;CZE&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Calendar&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;California&#039;s_Geographic_Names&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;California/color&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Call_sign_disambiguation&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Campaignbox&amp;quot;] = 20000,&lt;br /&gt;
[&amp;quot;CanadaByProvinceCatNav&amp;quot;] = 9200,&lt;br /&gt;
[&amp;quot;CanadaProvinceThe&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;Canadian_English&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Canadian_Parliament_links&amp;quot;] = 4900,&lt;br /&gt;
[&amp;quot;Canadian_election_result&amp;quot;] = 8800,&lt;br /&gt;
[&amp;quot;Canadian_election_result/hold&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Canadian_election_result/source&amp;quot;] = 5800,&lt;br /&gt;
[&amp;quot;Canadian_election_result/top&amp;quot;] = 8100,&lt;br /&gt;
[&amp;quot;Canadian_election_result/top/ElectionYearTest&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Canadian_election_result/total&amp;quot;] = 6900,&lt;br /&gt;
[&amp;quot;Canadian_party_colour&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Canadian_party_colour/colour&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Canadian_party_colour/colour/default&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Canadian_party_colour/name&amp;quot;] = 9600,&lt;br /&gt;
[&amp;quot;Canadian_party_colour/name/default&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Cascite&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Caselaw_source&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;Cast_listing&amp;quot;] = 5800,&lt;br /&gt;
[&amp;quot;Cat&amp;quot;] = 222000,&lt;br /&gt;
[&amp;quot;CatAutoTOC&amp;quot;] = 571000,&lt;br /&gt;
[&amp;quot;CatAutoTOC/core&amp;quot;] = 570000,&lt;br /&gt;
[&amp;quot;CatRel&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;CatTrack&amp;quot;] = 3100,&lt;br /&gt;
[&amp;quot;Cat_class&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Cat_in_use&amp;quot;] = 56000,&lt;br /&gt;
[&amp;quot;Cat_main&amp;quot;] = 161000,&lt;br /&gt;
[&amp;quot;Cat_more&amp;quot;] = 110000,&lt;br /&gt;
[&amp;quot;Cat_more_if_exists&amp;quot;] = 40000,&lt;br /&gt;
[&amp;quot;Cat_see_also&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Catalog_lookup_link&amp;quot;] = 468000,&lt;br /&gt;
[&amp;quot;Category-Class&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Category-inline&amp;quot;] = 6800,&lt;br /&gt;
[&amp;quot;Category_TOC&amp;quot;] = 66000,&lt;br /&gt;
[&amp;quot;Category_TOC/tracking&amp;quot;] = 65000,&lt;br /&gt;
[&amp;quot;Category_U.S._State_elections_by_year&amp;quot;] = 6900,&lt;br /&gt;
[&amp;quot;Category_U.S._State_elections_by_year/core&amp;quot;] = 6900,&lt;br /&gt;
[&amp;quot;Category_class&amp;quot;] = 40000,&lt;br /&gt;
[&amp;quot;Category_class/column&amp;quot;] = 40000,&lt;br /&gt;
[&amp;quot;Category_class/second_row_column&amp;quot;] = 40000,&lt;br /&gt;
[&amp;quot;Category_described_in_year&amp;quot;] = 5400,&lt;br /&gt;
[&amp;quot;Category_diffuse&amp;quot;] = 8900,&lt;br /&gt;
[&amp;quot;Category_disambiguation&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Category_disambiguation/category_link&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Category_explanation&amp;quot;] = 67000,&lt;br /&gt;
[&amp;quot;Category_handler&amp;quot;] = 2970000,&lt;br /&gt;
[&amp;quot;Category_ifexist&amp;quot;] = 4600,&lt;br /&gt;
[&amp;quot;Category_importance&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Category_importance/column&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Category_importance/second_row_column&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Category_link&amp;quot;] = 100000,&lt;br /&gt;
[&amp;quot;Category_link_with_count&amp;quot;] = 5000,&lt;br /&gt;
[&amp;quot;Category_ordered_by_date&amp;quot;] = 9200,&lt;br /&gt;
[&amp;quot;Category_other&amp;quot;] = 783000,&lt;br /&gt;
[&amp;quot;Category_pair&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Category_pair/core&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Category_redirect&amp;quot;] = 99000,&lt;br /&gt;
[&amp;quot;Category_see_also&amp;quot;] = 37000,&lt;br /&gt;
[&amp;quot;Category_see_also/Category_pair_check&amp;quot;] = 37000,&lt;br /&gt;
[&amp;quot;Category_see_also_if_exists&amp;quot;] = 45000,&lt;br /&gt;
[&amp;quot;Category_see_also_if_exists_2&amp;quot;] = 77000,&lt;br /&gt;
[&amp;quot;Category_title&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Catexp&amp;quot;] = 5500,&lt;br /&gt;
[&amp;quot;CathEncy&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Catholic&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Catholic_Encyclopedia&amp;quot;] = 4900,&lt;br /&gt;
[&amp;quot;Catmain&amp;quot;] = 22000,&lt;br /&gt;
[&amp;quot;Catmore&amp;quot;] = 9100,&lt;br /&gt;
[&amp;quot;Caution&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Cbb_link&amp;quot;] = 6100,&lt;br /&gt;
[&amp;quot;Cbignore&amp;quot;] = 22000,&lt;br /&gt;
[&amp;quot;Cc-by-2.5&amp;quot;] = 5100,&lt;br /&gt;
[&amp;quot;Cc-by-3.0&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Cc-by-sa-2.5&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;Cc-by-sa-2.5,2.0,1.0&amp;quot;] = 3700,&lt;br /&gt;
[&amp;quot;Cc-by-sa-3.0&amp;quot;] = 36000,&lt;br /&gt;
[&amp;quot;Cc-by-sa-3.0,2.5,2.0,1.0&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Cc-by-sa-3.0-migrated&amp;quot;] = 34000,&lt;br /&gt;
[&amp;quot;Cc-by-sa-4.0&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Cc-zero&amp;quot;] = 5700,&lt;br /&gt;
[&amp;quot;CensusAU&amp;quot;] = 9400,&lt;br /&gt;
[&amp;quot;Census_2016_AUS&amp;quot;] = 7500,&lt;br /&gt;
[&amp;quot;Cent&amp;quot;] = 4700,&lt;br /&gt;
[&amp;quot;Center&amp;quot;] = 563000,&lt;br /&gt;
[&amp;quot;Centralized_discussion&amp;quot;] = 5000,&lt;br /&gt;
[&amp;quot;Centralized_discussion/core&amp;quot;] = 5000,&lt;br /&gt;
[&amp;quot;Centre&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Century&amp;quot;] = 2000,&lt;br /&gt;
[&amp;quot;Century_name_from_decade_or_year&amp;quot;] = 67000,&lt;br /&gt;
[&amp;quot;Century_name_from_title_decade&amp;quot;] = 5900,&lt;br /&gt;
[&amp;quot;Century_name_from_title_year&amp;quot;] = 6100,&lt;br /&gt;
[&amp;quot;Certification_Cite/Title&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Certification_Cite/URL&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Certification_Cite_Ref&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Certification_Table_Bottom&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Certification_Table_Entry&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Certification_Table_Entry/Foot&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Certification_Table_Entry/Region&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Certification_Table_Entry/Sales&amp;quot;] = 17000,&lt;br /&gt;
[&amp;quot;Certification_Table_Entry/Sales/GermanPeriod&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Certification_Table_Top&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Cfb_link&amp;quot;] = 20000,&lt;br /&gt;
[&amp;quot;Cfd_result&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Cfdend&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;Chart&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Chart/end&amp;quot;] = 4400,&lt;br /&gt;
[&amp;quot;Chart/start&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Check_completeness_of_transclusions&amp;quot;] = 3700,&lt;br /&gt;
[&amp;quot;Check_talk&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Check_talk_wp&amp;quot;] = 1300000,&lt;br /&gt;
[&amp;quot;Check_winner_by_scores&amp;quot;] = 9900,&lt;br /&gt;
[&amp;quot;CheckedSockpuppet&amp;quot;] = 7100,&lt;br /&gt;
[&amp;quot;Checked_sockpuppet&amp;quot;] = 17000,&lt;br /&gt;
[&amp;quot;Checkedsockpuppet&amp;quot;] = 5300,&lt;br /&gt;
[&amp;quot;Checkip&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Checkuser&amp;quot;] = 60000,&lt;br /&gt;
[&amp;quot;Checkuserblock-account&amp;quot;] = 6400,&lt;br /&gt;
[&amp;quot;Chem&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;Chem/atom&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;Chem/link&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;Chem_molar_mass&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Chem_molar_mass/format&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Chembox&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_3DMet&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_3DMet/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_AllOtherNames&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Chembox_AllOtherNames/format&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Chembox_Appearance&amp;quot;] = 5100,&lt;br /&gt;
[&amp;quot;Chembox_BoilingPt&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Chembox_CASNo&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_CASNo/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_CalcTemperatures&amp;quot;] = 6100,&lt;br /&gt;
[&amp;quot;Chembox_ChEBI&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_ChEBI/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_ChEMBL&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_ChEMBL/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_ChemSpiderID&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_ChemSpiderID/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_CompTox&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_CompTox/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_Density&amp;quot;] = 4400,&lt;br /&gt;
[&amp;quot;Chembox_DrugBank&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_DrugBank/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_ECHA&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Chembox_ECNumber&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_ECNumber/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_Elements&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_Elements/molecular_formula&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Chembox_Footer&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_Footer/tracking&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_Hazards&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Chembox_IUPHAR_ligand&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_IUPHAR_ligand/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_Identifiers&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_InChI&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Chembox_InChI/format&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Chembox_Indexlist&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_Jmol&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_Jmol/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_KEGG&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_KEGG/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_MeltingPt&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;Chembox_Properties&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_PubChem&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_PubChem/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_RTECS&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_RTECS/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_Related&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Chembox_SMILES&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Chembox_SMILES/format&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Chembox_SolubilityInWater&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Chembox_UNII&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_UNII/format&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_headerbar&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_image&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_image_cell&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Chembox_image_sbs&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_parametercheck&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_templatePar/formatPreviewMessage&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Chembox_verification&amp;quot;] = 7200,&lt;br /&gt;
[&amp;quot;Chemicals&amp;quot;] = 8400,&lt;br /&gt;
[&amp;quot;Chemistry&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Chemspidercite&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Chessgames_player&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Chinese&amp;quot;] = 6900,&lt;br /&gt;
[&amp;quot;Chinese_name&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Chr&amp;quot;] = 8700,&lt;br /&gt;
[&amp;quot;ChristianityWikiProject&amp;quot;] = 6900,&lt;br /&gt;
[&amp;quot;Chrysomelidae-stub&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Circa&amp;quot;] = 34000,&lt;br /&gt;
[&amp;quot;Circular_reference&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;Citation&amp;quot;] = 301000,&lt;br /&gt;
[&amp;quot;Citation/make_link&amp;quot;] = 4600,&lt;br /&gt;
[&amp;quot;Citation_needed&amp;quot;] = 444000,&lt;br /&gt;
[&amp;quot;Citation_needed_span&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Citation_style&amp;quot;] = 4400,&lt;br /&gt;
[&amp;quot;Cite_AV_media&amp;quot;] = 28000,&lt;br /&gt;
[&amp;quot;Cite_AV_media_notes&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Cite_Appletons&#039;&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Cite_Australian_Dictionary_of_Biography&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Cite_Catholic_Encyclopedia&amp;quot;] = 7800,&lt;br /&gt;
[&amp;quot;Cite_DCB&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Cite_DNB&amp;quot;] = 17000,&lt;br /&gt;
[&amp;quot;Cite_EB1911&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Cite_GNIS&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Cite_Jewish_Encyclopedia&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Cite_NIE&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;Cite_NSW_Parliament&amp;quot;] = 3100,&lt;br /&gt;
[&amp;quot;Cite_NSW_SHR&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Cite_ODNB&amp;quot;] = 8800,&lt;br /&gt;
[&amp;quot;Cite_Q&amp;quot;] = 43000,&lt;br /&gt;
[&amp;quot;Cite_QHR&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Cite_QPN&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Cite_Russian_law&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Cite_Sports-Reference&amp;quot;] = 53000,&lt;br /&gt;
[&amp;quot;Cite_WoRMS&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Cite_arXiv&amp;quot;] = 3700,&lt;br /&gt;
[&amp;quot;Cite_article&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Cite_av_media&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Cite_bcgnis&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Cite_book&amp;quot;] = 1270000,&lt;br /&gt;
[&amp;quot;Cite_certification&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Cite_cgndb&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Cite_conference&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Cite_court&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Cite_document&amp;quot;] = 6800,&lt;br /&gt;
[&amp;quot;Cite_encyclopedia&amp;quot;] = 122000,&lt;br /&gt;
[&amp;quot;Cite_episode&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Cite_gnis&amp;quot;] = 32000,&lt;br /&gt;
[&amp;quot;Cite_interview&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;Cite_iucn&amp;quot;] = 30000,&lt;br /&gt;
[&amp;quot;Cite_journal&amp;quot;] = 713000,&lt;br /&gt;
[&amp;quot;Cite_magazine&amp;quot;] = 120000,&lt;br /&gt;
[&amp;quot;Cite_map&amp;quot;] = 28000,&lt;br /&gt;
[&amp;quot;Cite_news&amp;quot;] = 1150000,&lt;br /&gt;
[&amp;quot;Cite_newspaper&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Cite_newspaper_The_Times&amp;quot;] = 5600,&lt;br /&gt;
[&amp;quot;Cite_paper&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Cite_patent&amp;quot;] = 4000,&lt;br /&gt;
[&amp;quot;Cite_patent/authors&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Cite_patent/core&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Cite_peakbagger&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Cite_podcast&amp;quot;] = 2000,&lt;br /&gt;
[&amp;quot;Cite_press_release&amp;quot;] = 46000,&lt;br /&gt;
[&amp;quot;Cite_report&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Cite_simbad&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Cite_sports-reference&amp;quot;] = 57000,&lt;br /&gt;
[&amp;quot;Cite_thesis&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Cite_tweet&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Cite_video&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Cite_video_game&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Cite_web&amp;quot;] = 3700000,&lt;br /&gt;
[&amp;quot;Cite_wikisource&amp;quot;] = 4100,&lt;br /&gt;
[&amp;quot;Cite_wikisource/make_link&amp;quot;] = 50000,&lt;br /&gt;
[&amp;quot;Civil_navigation&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Cl&amp;quot;] = 99000,&lt;br /&gt;
[&amp;quot;Clade&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;Clade/styles.css&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;Clarify&amp;quot;] = 36000,&lt;br /&gt;
[&amp;quot;Class&amp;quot;] = 8840000,&lt;br /&gt;
[&amp;quot;Class/colour&amp;quot;] = 8900000,&lt;br /&gt;
[&amp;quot;Class/icon&amp;quot;] = 8860000,&lt;br /&gt;
[&amp;quot;Class_mask&amp;quot;] = 9040000,&lt;br /&gt;
[&amp;quot;Class_mask/b&amp;quot;] = 290000,&lt;br /&gt;
[&amp;quot;Classical&amp;quot;] = 7600,&lt;br /&gt;
[&amp;quot;Classicon&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Clc&amp;quot;] = 4100,&lt;br /&gt;
[&amp;quot;Cleanup&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Cleanup_reorganize&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Cleanup_rewrite&amp;quot;] = 5300,&lt;br /&gt;
[&amp;quot;Clear&amp;quot;] = 3000000,&lt;br /&gt;
[&amp;quot;Clear-left&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Clear_left&amp;quot;] = 30000,&lt;br /&gt;
[&amp;quot;Clear_right&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Clerk-Note&amp;quot;] = 7600,&lt;br /&gt;
[&amp;quot;Clerknote&amp;quot;] = 5400,&lt;br /&gt;
[&amp;quot;Clickable_button&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Clickable_button_2&amp;quot;] = 719000,&lt;br /&gt;
[&amp;quot;Clr&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Cmbox&amp;quot;] = 327000,&lt;br /&gt;
[&amp;quot;Cn&amp;quot;] = 74000,&lt;br /&gt;
[&amp;quot;Coat_of_arms&amp;quot;] = 7600,&lt;br /&gt;
[&amp;quot;Cob&amp;quot;] = 8700,&lt;br /&gt;
[&amp;quot;Code&amp;quot;] = 36000,&lt;br /&gt;
[&amp;quot;Col-1-of-2&amp;quot;] = 3100,&lt;br /&gt;
[&amp;quot;Col-2&amp;quot;] = 146000,&lt;br /&gt;
[&amp;quot;Col-2-of-2&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Col-3&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Col-4&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Col-begin&amp;quot;] = 193000,&lt;br /&gt;
[&amp;quot;Col-break&amp;quot;] = 190000,&lt;br /&gt;
[&amp;quot;Col-end&amp;quot;] = 190000,&lt;br /&gt;
[&amp;quot;Col-start&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Colbegin&amp;quot;] = 49000,&lt;br /&gt;
[&amp;quot;Colend&amp;quot;] = 58000,&lt;br /&gt;
[&amp;quot;Collapse&amp;quot;] = 8700,&lt;br /&gt;
[&amp;quot;Collapse_bottom&amp;quot;] = 44000,&lt;br /&gt;
[&amp;quot;Collapse_top&amp;quot;] = 44000,&lt;br /&gt;
[&amp;quot;Collapsebottom&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;Collapsetop&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;Collapsible_list&amp;quot;] = 43000,&lt;br /&gt;
[&amp;quot;Collapsible_option&amp;quot;] = 120000,&lt;br /&gt;
[&amp;quot;Colledge&amp;quot;] = 3100,&lt;br /&gt;
[&amp;quot;College&amp;quot;] = 6400,&lt;br /&gt;
[&amp;quot;CollegePrimaryHeader&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;CollegePrimaryStyle&amp;quot;] = 78000,&lt;br /&gt;
[&amp;quot;College_Athlete_Recruit_End&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;College_Athlete_Recruit_Entry&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;College_Athlete_Recruit_Start&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;College_athlete_recruit_end&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;College_athlete_recruit_entry&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;College_athlete_recruit_start&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;College_color_list&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Colon&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Color&amp;quot;] = 400000,&lt;br /&gt;
[&amp;quot;Color_box&amp;quot;] = 57000,&lt;br /&gt;
[&amp;quot;Colorbox&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Colorbull&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Colored_link&amp;quot;] = 25000,&lt;br /&gt;
[&amp;quot;Colors&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Colour&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Coloured_link&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Column-count&amp;quot;] = 17000,&lt;br /&gt;
[&amp;quot;Column-width&amp;quot;] = 939000,&lt;br /&gt;
[&amp;quot;Columns-list&amp;quot;] = 85000,&lt;br /&gt;
[&amp;quot;Columns/styles.css&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Comedy&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Comic_Book_DB&amp;quot;] = 3700,&lt;br /&gt;
[&amp;quot;Comicbookdb&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;Comics-replaceability&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Comics_infobox_sec&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Comics_infobox_sec/creator_nat&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Comics_infobox_sec/formcat&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Comics_infobox_sec/genre&amp;quot;] = 3700,&lt;br /&gt;
[&amp;quot;Comics_infobox_sec/genrecat&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Comicsproj&amp;quot;] = 30000,&lt;br /&gt;
[&amp;quot;Comicsyrimage&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Comma_separated_entries&amp;quot;] = 306000,&lt;br /&gt;
[&amp;quot;Comment&amp;quot;] = 3700,&lt;br /&gt;
[&amp;quot;Committed_identity&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Committed_identity/styles.css&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Commons&amp;quot;] = 64000,&lt;br /&gt;
[&amp;quot;Commons-inline&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Commons_cat&amp;quot;] = 49000,&lt;br /&gt;
[&amp;quot;Commons_category&amp;quot;] = 784000,&lt;br /&gt;
[&amp;quot;Commons_category-inline&amp;quot;] = 110000,&lt;br /&gt;
[&amp;quot;Commons_category_inline&amp;quot;] = 6900,&lt;br /&gt;
[&amp;quot;Commonscat&amp;quot;] = 75000,&lt;br /&gt;
[&amp;quot;Commonscat-inline&amp;quot;] = 26000,&lt;br /&gt;
[&amp;quot;Commonscat_inline&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Commonscatinline&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Compact_ToC&amp;quot;] = 6400,&lt;br /&gt;
[&amp;quot;Compare&amp;quot;] = 7100,&lt;br /&gt;
[&amp;quot;Compare_image_with_Wikidata&amp;quot;] = 7100,&lt;br /&gt;
[&amp;quot;Composition_bar&amp;quot;] = 7800,&lt;br /&gt;
[&amp;quot;ConfirmationOTRS&amp;quot;] = 3100,&lt;br /&gt;
[&amp;quot;Confirmed&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Confused&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Confusing&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;CongBio&amp;quot;] = 9800,&lt;br /&gt;
[&amp;quot;CongLinks&amp;quot;] = 4100,&lt;br /&gt;
[&amp;quot;Connected_contributor&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Connected_contributor_(paid)&amp;quot;] = 4800,&lt;br /&gt;
[&amp;quot;Conservative_Party_(UK)/meta/color&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Conservative_Party_(UK)/meta/shortname&amp;quot;] = 8900,&lt;br /&gt;
[&amp;quot;Conservative_and_Unionist_Party_(UK)/meta/color&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Constellation_navbox&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Container&amp;quot;] = 8400,&lt;br /&gt;
[&amp;quot;Container_cat&amp;quot;] = 6400,&lt;br /&gt;
[&amp;quot;Container_category&amp;quot;] = 33000,&lt;br /&gt;
[&amp;quot;Containercat&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Contains_special_characters&amp;quot;] = 4100,&lt;br /&gt;
[&amp;quot;Contains_special_characters/core&amp;quot;] = 4100,&lt;br /&gt;
[&amp;quot;Content_category&amp;quot;] = 6500,&lt;br /&gt;
[&amp;quot;Context&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Continent2continental&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Continent_adjective_to_noun&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Controversial&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Convert&amp;quot;] = 1040000,&lt;br /&gt;
[&amp;quot;Convinfobox&amp;quot;] = 178000,&lt;br /&gt;
[&amp;quot;Convinfobox/2&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Convinfobox/3&amp;quot;] = 107000,&lt;br /&gt;
[&amp;quot;Convinfobox/pri2&amp;quot;] = 54000,&lt;br /&gt;
[&amp;quot;Convinfobox/prisec2&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Convinfobox/prisec3&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Convinfobox/sec2&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Coord&amp;quot;] = 1240000,&lt;br /&gt;
[&amp;quot;Coord_missing&amp;quot;] = 119000,&lt;br /&gt;
[&amp;quot;Coord_missing/CheckCat&amp;quot;] = 118000,&lt;br /&gt;
[&amp;quot;Coords&amp;quot;] = 6800,&lt;br /&gt;
[&amp;quot;Copied&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Copy_to_Wikimedia_Commons&amp;quot;] = 158000,&lt;br /&gt;
[&amp;quot;Copyvios&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Cospar&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Cot&amp;quot;] = 8500,&lt;br /&gt;
[&amp;quot;Count&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Country2continent&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;CountryPrefixThe&amp;quot;] = 95000,&lt;br /&gt;
[&amp;quot;Country_abbreviation&amp;quot;] = 102000,&lt;br /&gt;
[&amp;quot;Country_alias&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_at_games_navbox&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Country_at_games_navbox/below&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Country_data&amp;quot;] = 4900,&lt;br /&gt;
[&amp;quot;Country_data_ALB&amp;quot;] = 5800,&lt;br /&gt;
[&amp;quot;Country_data_ALG&amp;quot;] = 7500,&lt;br /&gt;
[&amp;quot;Country_data_AND&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_ANG&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Country_data_ARG&amp;quot;] = 40000,&lt;br /&gt;
[&amp;quot;Country_data_ARM&amp;quot;] = 5900,&lt;br /&gt;
[&amp;quot;Country_data_AUS&amp;quot;] = 65000,&lt;br /&gt;
[&amp;quot;Country_data_AUT&amp;quot;] = 38000,&lt;br /&gt;
[&amp;quot;Country_data_AZE&amp;quot;] = 6900,&lt;br /&gt;
[&amp;quot;Country_data_Afghanistan&amp;quot;] = 9600,&lt;br /&gt;
[&amp;quot;Country_data_Alaska&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Country_data_Albania&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Country_data_Alberta&amp;quot;] = 3700,&lt;br /&gt;
[&amp;quot;Country_data_Algeria&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Country_data_American_Samoa&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Country_data_Andorra&amp;quot;] = 6400,&lt;br /&gt;
[&amp;quot;Country_data_Angola&amp;quot;] = 9700,&lt;br /&gt;
[&amp;quot;Country_data_Anguilla&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Country_data_Antigua_and_Barbuda&amp;quot;] = 5500,&lt;br /&gt;
[&amp;quot;Country_data_Apulia&amp;quot;] = 7900,&lt;br /&gt;
[&amp;quot;Country_data_Argentina&amp;quot;] = 65000,&lt;br /&gt;
[&amp;quot;Country_data_Arizona&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_Armenia&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_Aruba&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Country_data_Australia&amp;quot;] = 102000,&lt;br /&gt;
[&amp;quot;Country_data_Austria&amp;quot;] = 59000,&lt;br /&gt;
[&amp;quot;Country_data_Azerbaijan&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_BAH&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;Country_data_BAN&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Country_data_BAR&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_BEL&amp;quot;] = 43000,&lt;br /&gt;
[&amp;quot;Country_data_BHR&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Country_data_BIH&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Country_data_BLR&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_BOL&amp;quot;] = 5600,&lt;br /&gt;
[&amp;quot;Country_data_BOT&amp;quot;] = 2000,&lt;br /&gt;
[&amp;quot;Country_data_BRA&amp;quot;] = 49000,&lt;br /&gt;
[&amp;quot;Country_data_BUL&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_Bahamas&amp;quot;] = 8700,&lt;br /&gt;
[&amp;quot;Country_data_Bahrain&amp;quot;] = 8600,&lt;br /&gt;
[&amp;quot;Country_data_Bangladesh&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_data_Barbados&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Country_data_Belarus&amp;quot;] = 33000,&lt;br /&gt;
[&amp;quot;Country_data_Belgium&amp;quot;] = 68000,&lt;br /&gt;
[&amp;quot;Country_data_Belize&amp;quot;] = 4600,&lt;br /&gt;
[&amp;quot;Country_data_Benin&amp;quot;] = 6000,&lt;br /&gt;
[&amp;quot;Country_data_Bermuda&amp;quot;] = 5100,&lt;br /&gt;
[&amp;quot;Country_data_Bhutan&amp;quot;] = 4100,&lt;br /&gt;
[&amp;quot;Country_data_Bolivia&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Country_data_Bosnia_and_Herzegovina&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_Botswana&amp;quot;] = 7300,&lt;br /&gt;
[&amp;quot;Country_data_Brazil&amp;quot;] = 83000,&lt;br /&gt;
[&amp;quot;Country_data_British_Columbia&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_British_Virgin_Islands&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Country_data_Brunei&amp;quot;] = 5300,&lt;br /&gt;
[&amp;quot;Country_data_Bulgaria&amp;quot;] = 40000,&lt;br /&gt;
[&amp;quot;Country_data_Burkina_Faso&amp;quot;] = 8500,&lt;br /&gt;
[&amp;quot;Country_data_Burma&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Country_data_Burundi&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Country_data_CAN&amp;quot;] = 51000,&lt;br /&gt;
[&amp;quot;Country_data_CHE&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Country_data_CHI&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_CHN&amp;quot;] = 35000,&lt;br /&gt;
[&amp;quot;Country_data_CIV&amp;quot;] = 6200,&lt;br /&gt;
[&amp;quot;Country_data_CMR&amp;quot;] = 6800,&lt;br /&gt;
[&amp;quot;Country_data_COD&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_COL&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_CRC&amp;quot;] = 6100,&lt;br /&gt;
[&amp;quot;Country_data_CRO&amp;quot;] = 28000,&lt;br /&gt;
[&amp;quot;Country_data_CUB&amp;quot;] = 8000,&lt;br /&gt;
[&amp;quot;Country_data_CYP&amp;quot;] = 7500,&lt;br /&gt;
[&amp;quot;Country_data_CZE&amp;quot;] = 40000,&lt;br /&gt;
[&amp;quot;Country_data_California&amp;quot;] = 6200,&lt;br /&gt;
[&amp;quot;Country_data_Cambodia&amp;quot;] = 7700,&lt;br /&gt;
[&amp;quot;Country_data_Cameroon&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_data_Canada&amp;quot;] = 101000,&lt;br /&gt;
[&amp;quot;Country_data_Cape_Verde&amp;quot;] = 4800,&lt;br /&gt;
[&amp;quot;Country_data_Catalonia&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_Cayman_Islands&amp;quot;] = 4100,&lt;br /&gt;
[&amp;quot;Country_data_Central_African_Republic&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Country_data_Chad&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Country_data_Chile&amp;quot;] = 32000,&lt;br /&gt;
[&amp;quot;Country_data_China&amp;quot;] = 65000,&lt;br /&gt;
[&amp;quot;Country_data_Chinese_Taipei&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Country_data_Colombia&amp;quot;] = 37000,&lt;br /&gt;
[&amp;quot;Country_data_Colorado&amp;quot;] = 4800,&lt;br /&gt;
[&amp;quot;Country_data_Comoros&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Country_data_Confederate_States_of_America&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Country_data_Connecticut&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Country_data_Cook_Islands&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;Country_data_Costa_Rica&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_data_Croatia&amp;quot;] = 45000,&lt;br /&gt;
[&amp;quot;Country_data_Cuba&amp;quot;] = 17000,&lt;br /&gt;
[&amp;quot;Country_data_Curaçao&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Country_data_Cyprus&amp;quot;] = 17000,&lt;br /&gt;
[&amp;quot;Country_data_Czech_Republic&amp;quot;] = 63000,&lt;br /&gt;
[&amp;quot;Country_data_Czechoslovakia&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Country_data_DEN&amp;quot;] = 29000,&lt;br /&gt;
[&amp;quot;Country_data_DEU&amp;quot;] = 7500,&lt;br /&gt;
[&amp;quot;Country_data_DNK&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Country_data_DOM&amp;quot;] = 7100,&lt;br /&gt;
[&amp;quot;Country_data_Democratic_Republic_of_the_Congo&amp;quot;] = 9100,&lt;br /&gt;
[&amp;quot;Country_data_Denmark&amp;quot;] = 56000,&lt;br /&gt;
[&amp;quot;Country_data_Djibouti&amp;quot;] = 3700,&lt;br /&gt;
[&amp;quot;Country_data_Dominica&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Country_data_Dominican_Republic&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Country_data_ECU&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Country_data_EGY&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Country_data_ENG&amp;quot;] = 38000,&lt;br /&gt;
[&amp;quot;Country_data_ESA&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_ESP&amp;quot;] = 60000,&lt;br /&gt;
[&amp;quot;Country_data_EST&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Country_data_ETH&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;Country_data_EU&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Country_data_East_Germany&amp;quot;] = 9600,&lt;br /&gt;
[&amp;quot;Country_data_East_Timor&amp;quot;] = 4000,&lt;br /&gt;
[&amp;quot;Country_data_Ecuador&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Country_data_Egypt&amp;quot;] = 25000,&lt;br /&gt;
[&amp;quot;Country_data_El_Salvador&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Country_data_Empire_of_Japan&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Country_data_England&amp;quot;] = 77000,&lt;br /&gt;
[&amp;quot;Country_data_Equatorial_Guinea&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Country_data_Eritrea&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Country_data_Estonia&amp;quot;] = 26000,&lt;br /&gt;
[&amp;quot;Country_data_Eswatini&amp;quot;] = 4000,&lt;br /&gt;
[&amp;quot;Country_data_Ethiopia&amp;quot;] = 9800,&lt;br /&gt;
[&amp;quot;Country_data_Europe&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_European_Union&amp;quot;] = 6500,&lt;br /&gt;
[&amp;quot;Country_data_FIJ&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;Country_data_FIN&amp;quot;] = 29000,&lt;br /&gt;
[&amp;quot;Country_data_FRA&amp;quot;] = 81000,&lt;br /&gt;
[&amp;quot;Country_data_FRG&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Country_data_FR_Yugoslavia&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Country_data_Faroe_Islands&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Country_data_Federated_States_of_Micronesia&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_Fiji&amp;quot;] = 9000,&lt;br /&gt;
[&amp;quot;Country_data_Finland&amp;quot;] = 52000,&lt;br /&gt;
[&amp;quot;Country_data_Florida&amp;quot;] = 6400,&lt;br /&gt;
[&amp;quot;Country_data_France&amp;quot;] = 174000,&lt;br /&gt;
[&amp;quot;Country_data_French_Polynesia&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;Country_data_GAB&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_GBR&amp;quot;] = 45000,&lt;br /&gt;
[&amp;quot;Country_data_GDR&amp;quot;] = 5500,&lt;br /&gt;
[&amp;quot;Country_data_GEO&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Country_data_GER&amp;quot;] = 67000,&lt;br /&gt;
[&amp;quot;Country_data_GHA&amp;quot;] = 8100,&lt;br /&gt;
[&amp;quot;Country_data_GRE&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_GUA&amp;quot;] = 4800,&lt;br /&gt;
[&amp;quot;Country_data_GUI&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_GUY&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_Gabon&amp;quot;] = 6400,&lt;br /&gt;
[&amp;quot;Country_data_Gambia&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;Country_data_Georgia&amp;quot;] = 9300,&lt;br /&gt;
[&amp;quot;Country_data_Georgia_(U.S._state)&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_Georgia_(country)&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_German_Empire&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Country_data_Germany&amp;quot;] = 121000,&lt;br /&gt;
[&amp;quot;Country_data_Ghana&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Country_data_Gibraltar&amp;quot;] = 4000,&lt;br /&gt;
[&amp;quot;Country_data_Great_Britain&amp;quot;] = 53000,&lt;br /&gt;
[&amp;quot;Country_data_Greece&amp;quot;] = 45000,&lt;br /&gt;
[&amp;quot;Country_data_Greenland&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_Grenada&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Country_data_Guadeloupe&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_Guam&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Country_data_Guatemala&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Country_data_Guernsey&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Country_data_Guinea&amp;quot;] = 6700,&lt;br /&gt;
[&amp;quot;Country_data_Guinea-Bissau&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Country_data_Guyana&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Country_data_HAI&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Country_data_HKG&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Country_data_HON&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Country_data_HUN&amp;quot;] = 30000,&lt;br /&gt;
[&amp;quot;Country_data_Haiti&amp;quot;] = 7700,&lt;br /&gt;
[&amp;quot;Country_data_Honduras&amp;quot;] = 9600,&lt;br /&gt;
[&amp;quot;Country_data_Hong_Kong&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_Hungary&amp;quot;] = 52000,&lt;br /&gt;
[&amp;quot;Country_data_IDN&amp;quot;] = 4700,&lt;br /&gt;
[&amp;quot;Country_data_INA&amp;quot;] = 8900,&lt;br /&gt;
[&amp;quot;Country_data_IND&amp;quot;] = 26000,&lt;br /&gt;
[&amp;quot;Country_data_IRE&amp;quot;] = 9700,&lt;br /&gt;
[&amp;quot;Country_data_IRI&amp;quot;] = 4100,&lt;br /&gt;
[&amp;quot;Country_data_IRL&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Country_data_IRN&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;Country_data_IRQ&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Country_data_ISL&amp;quot;] = 7700,&lt;br /&gt;
[&amp;quot;Country_data_ISR&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Country_data_ITA&amp;quot;] = 72000,&lt;br /&gt;
[&amp;quot;Country_data_Iceland&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Country_data_Illinois&amp;quot;] = 5000,&lt;br /&gt;
[&amp;quot;Country_data_India&amp;quot;] = 86000,&lt;br /&gt;
[&amp;quot;Country_data_Indiana&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Country_data_Indonesia&amp;quot;] = 29000,&lt;br /&gt;
[&amp;quot;Country_data_Iowa&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Country_data_Iran&amp;quot;] = 88000,&lt;br /&gt;
[&amp;quot;Country_data_Iraq&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Country_data_Ireland&amp;quot;] = 28000,&lt;br /&gt;
[&amp;quot;Country_data_Isle_of_Man&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Country_data_Israel&amp;quot;] = 35000,&lt;br /&gt;
[&amp;quot;Country_data_Italy&amp;quot;] = 115000,&lt;br /&gt;
[&amp;quot;Country_data_Ivory_Coast&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Country_data_JAM&amp;quot;] = 8200,&lt;br /&gt;
[&amp;quot;Country_data_JOR&amp;quot;] = 3100,&lt;br /&gt;
[&amp;quot;Country_data_JP&amp;quot;] = 7600,&lt;br /&gt;
[&amp;quot;Country_data_JPN&amp;quot;] = 50000,&lt;br /&gt;
[&amp;quot;Country_data_Jamaica&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_Japan&amp;quot;] = 94000,&lt;br /&gt;
[&amp;quot;Country_data_Jersey&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Country_data_Jordan&amp;quot;] = 9300,&lt;br /&gt;
[&amp;quot;Country_data_KAZ&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_KEN&amp;quot;] = 6000,&lt;br /&gt;
[&amp;quot;Country_data_KGZ&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Country_data_KOR&amp;quot;] = 27000,&lt;br /&gt;
[&amp;quot;Country_data_KSA&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Country_data_KUW&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Country_data_Kazakhstan&amp;quot;] = 25000,&lt;br /&gt;
[&amp;quot;Country_data_Kenya&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Country_data_Kingdom_of_Great_Britain&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Country_data_Kingdom_of_Italy&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Country_data_Kiribati&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Country_data_Kosovo&amp;quot;] = 6500,&lt;br /&gt;
[&amp;quot;Country_data_Kuwait&amp;quot;] = 8700,&lt;br /&gt;
[&amp;quot;Country_data_Kyrgyzstan&amp;quot;] = 7600,&lt;br /&gt;
[&amp;quot;Country_data_LAT&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Country_data_LIB&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_LIE&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Country_data_LIT&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Country_data_LTU&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Country_data_LUX&amp;quot;] = 8900,&lt;br /&gt;
[&amp;quot;Country_data_Laos&amp;quot;] = 6400,&lt;br /&gt;
[&amp;quot;Country_data_Latvia&amp;quot;] = 25000,&lt;br /&gt;
[&amp;quot;Country_data_Lebanon&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Country_data_Lesotho&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Country_data_Liberia&amp;quot;] = 5800,&lt;br /&gt;
[&amp;quot;Country_data_Libya&amp;quot;] = 7200,&lt;br /&gt;
[&amp;quot;Country_data_Liechtenstein&amp;quot;] = 6500,&lt;br /&gt;
[&amp;quot;Country_data_Lithuania&amp;quot;] = 24000,&lt;br /&gt;
[&amp;quot;Country_data_Luxembourg&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Country_data_MAC&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_MAR&amp;quot;] = 9400,&lt;br /&gt;
[&amp;quot;Country_data_MAS&amp;quot;] = 9300,&lt;br /&gt;
[&amp;quot;Country_data_MDA&amp;quot;] = 5900,&lt;br /&gt;
[&amp;quot;Country_data_MEX&amp;quot;] = 27000,&lt;br /&gt;
[&amp;quot;Country_data_MGL&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Country_data_MKD&amp;quot;] = 5800,&lt;br /&gt;
[&amp;quot;Country_data_MLI&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;Country_data_MLT&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;Country_data_MNE&amp;quot;] = 6600,&lt;br /&gt;
[&amp;quot;Country_data_MON&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Country_data_MRI&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_MYA&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Country_data_MYS&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Country_data_Macau&amp;quot;] = 6300,&lt;br /&gt;
[&amp;quot;Country_data_Macedonia&amp;quot;] = 5100,&lt;br /&gt;
[&amp;quot;Country_data_Madagascar&amp;quot;] = 7500,&lt;br /&gt;
[&amp;quot;Country_data_Malawi&amp;quot;] = 4600,&lt;br /&gt;
[&amp;quot;Country_data_Malaysia&amp;quot;] = 30000,&lt;br /&gt;
[&amp;quot;Country_data_Maldives&amp;quot;] = 5000,&lt;br /&gt;
[&amp;quot;Country_data_Mali&amp;quot;] = 9200,&lt;br /&gt;
[&amp;quot;Country_data_Malta&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Country_data_Manitoba&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_Marshall_Islands&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Country_data_Martinique&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Country_data_Maryland&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Country_data_Massachusetts&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Country_data_Mauritania&amp;quot;] = 4600,&lt;br /&gt;
[&amp;quot;Country_data_Mauritius&amp;quot;] = 7100,&lt;br /&gt;
[&amp;quot;Country_data_Mexico&amp;quot;] = 51000,&lt;br /&gt;
[&amp;quot;Country_data_Michigan&amp;quot;] = 3700,&lt;br /&gt;
[&amp;quot;Country_data_Minnesota&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Country_data_Moldova&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_data_Monaco&amp;quot;] = 8500,&lt;br /&gt;
[&amp;quot;Country_data_Mongolia&amp;quot;] = 7600,&lt;br /&gt;
[&amp;quot;Country_data_Montana&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_Montenegro&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_data_Montserrat&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Country_data_Morocco&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_Mozambique&amp;quot;] = 6000,&lt;br /&gt;
[&amp;quot;Country_data_Myanmar&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Country_data_NAM&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;Country_data_NED&amp;quot;] = 49000,&lt;br /&gt;
[&amp;quot;Country_data_NEP&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_NGA&amp;quot;] = 6500,&lt;br /&gt;
[&amp;quot;Country_data_NGR&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Country_data_NIR&amp;quot;] = 8300,&lt;br /&gt;
[&amp;quot;Country_data_NLD&amp;quot;] = 5700,&lt;br /&gt;
[&amp;quot;Country_data_NOR&amp;quot;] = 24000,&lt;br /&gt;
[&amp;quot;Country_data_NZ&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Country_data_NZL&amp;quot;] = 28000,&lt;br /&gt;
[&amp;quot;Country_data_Namibia&amp;quot;] = 8500,&lt;br /&gt;
[&amp;quot;Country_data_Nazi_Germany&amp;quot;] = 8500,&lt;br /&gt;
[&amp;quot;Country_data_Nepal&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Country_data_Netherlands&amp;quot;] = 87000,&lt;br /&gt;
[&amp;quot;Country_data_Netherlands_Antilles&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Country_data_New_Brunswick&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Country_data_New_Caledonia&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Country_data_New_Jersey&amp;quot;] = 4000,&lt;br /&gt;
[&amp;quot;Country_data_New_South_Wales&amp;quot;] = 5000,&lt;br /&gt;
[&amp;quot;Country_data_New_York&amp;quot;] = 3500,&lt;br /&gt;
[&amp;quot;Country_data_New_York_(state)&amp;quot;] = 4800,&lt;br /&gt;
[&amp;quot;Country_data_New_Zealand&amp;quot;] = 50000,&lt;br /&gt;
[&amp;quot;Country_data_Newfoundland_and_Labrador&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_Nicaragua&amp;quot;] = 8100,&lt;br /&gt;
[&amp;quot;Country_data_Niger&amp;quot;] = 4700,&lt;br /&gt;
[&amp;quot;Country_data_Nigeria&amp;quot;] = 26000,&lt;br /&gt;
[&amp;quot;Country_data_North_Carolina&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;Country_data_North_Korea&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Country_data_North_Macedonia&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Country_data_Northern_Ireland&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Country_data_Northern_Mariana_Islands&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_Norway&amp;quot;] = 56000,&lt;br /&gt;
[&amp;quot;Country_data_Nova_Scotia&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_OMA&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_Ohio&amp;quot;] = 4700,&lt;br /&gt;
[&amp;quot;Country_data_Oman&amp;quot;] = 7500,&lt;br /&gt;
[&amp;quot;Country_data_Ontario&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Country_data_Ottoman_Empire&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_PAK&amp;quot;] = 7300,&lt;br /&gt;
[&amp;quot;Country_data_PAN&amp;quot;] = 6000,&lt;br /&gt;
[&amp;quot;Country_data_PAR&amp;quot;] = 9000,&lt;br /&gt;
[&amp;quot;Country_data_PER&amp;quot;] = 11000,&lt;br /&gt;
[&amp;quot;Country_data_PHI&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Country_data_PHL&amp;quot;] = 3000,&lt;br /&gt;
[&amp;quot;Country_data_PNG&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_POL&amp;quot;] = 41000,&lt;br /&gt;
[&amp;quot;Country_data_POR&amp;quot;] = 25000,&lt;br /&gt;
[&amp;quot;Country_data_PRC&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Country_data_PRK&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Country_data_PRT&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Country_data_PUR&amp;quot;] = 7600,&lt;br /&gt;
[&amp;quot;Country_data_Pakistan&amp;quot;] = 23000,&lt;br /&gt;
[&amp;quot;Country_data_Palau&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Country_data_Palestine&amp;quot;] = 5600,&lt;br /&gt;
[&amp;quot;Country_data_Panama&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Country_data_Papua_New_Guinea&amp;quot;] = 7000,&lt;br /&gt;
[&amp;quot;Country_data_Paraguay&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_Pennsylvania&amp;quot;] = 3100,&lt;br /&gt;
[&amp;quot;Country_data_People&#039;s_Republic_of_China&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Country_data_Peru&amp;quot;] = 25000,&lt;br /&gt;
[&amp;quot;Country_data_Philippines&amp;quot;] = 30000,&lt;br /&gt;
[&amp;quot;Country_data_Poland&amp;quot;] = 125000,&lt;br /&gt;
[&amp;quot;Country_data_Portugal&amp;quot;] = 50000,&lt;br /&gt;
[&amp;quot;Country_data_Prussia&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_Puerto_Rico&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Country_data_QAT&amp;quot;] = 6300,&lt;br /&gt;
[&amp;quot;Country_data_Qatar&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_data_Quebec&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Country_data_ROC&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_ROM&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Country_data_ROU&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_RSA&amp;quot;] = 27000,&lt;br /&gt;
[&amp;quot;Country_data_RUS&amp;quot;] = 55000,&lt;br /&gt;
[&amp;quot;Country_data_Republic_of_China&amp;quot;] = 5900,&lt;br /&gt;
[&amp;quot;Country_data_Republic_of_Ireland&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Country_data_Republic_of_the_Congo&amp;quot;] = 6300,&lt;br /&gt;
[&amp;quot;Country_data_Romania&amp;quot;] = 53000,&lt;br /&gt;
[&amp;quot;Country_data_Russia&amp;quot;] = 93000,&lt;br /&gt;
[&amp;quot;Country_data_Russian_Empire&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;Country_data_Rwanda&amp;quot;] = 5400,&lt;br /&gt;
[&amp;quot;Country_data_SAM&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Country_data_SCG&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Country_data_SCO&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_data_SEN&amp;quot;] = 6000,&lt;br /&gt;
[&amp;quot;Country_data_SER&amp;quot;] = 3100,&lt;br /&gt;
[&amp;quot;Country_data_SGP&amp;quot;] = 2000,&lt;br /&gt;
[&amp;quot;Country_data_SIN&amp;quot;] = 6700,&lt;br /&gt;
[&amp;quot;Country_data_SLO&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_SLV&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Country_data_SMR&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Country_data_SPA&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Country_data_SRB&amp;quot;] = 22000,&lt;br /&gt;
[&amp;quot;Country_data_SRI&amp;quot;] = 4400,&lt;br /&gt;
[&amp;quot;Country_data_SUI&amp;quot;] = 35000,&lt;br /&gt;
[&amp;quot;Country_data_SVK&amp;quot;] = 24000,&lt;br /&gt;
[&amp;quot;Country_data_SVN&amp;quot;] = 5400,&lt;br /&gt;
[&amp;quot;Country_data_SWE&amp;quot;] = 48000,&lt;br /&gt;
[&amp;quot;Country_data_SWI&amp;quot;] = 4400,&lt;br /&gt;
[&amp;quot;Country_data_SYR&amp;quot;] = 2900,&lt;br /&gt;
[&amp;quot;Country_data_Saint_Kitts_and_Nevis&amp;quot;] = 4100,&lt;br /&gt;
[&amp;quot;Country_data_Saint_Lucia&amp;quot;] = 4600,&lt;br /&gt;
[&amp;quot;Country_data_Saint_Vincent_and_the_Grenadines&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Country_data_Samoa&amp;quot;] = 6500,&lt;br /&gt;
[&amp;quot;Country_data_San_Marino&amp;quot;] = 6900,&lt;br /&gt;
[&amp;quot;Country_data_Saskatchewan&amp;quot;] = 3600,&lt;br /&gt;
[&amp;quot;Country_data_Saudi_Arabia&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Country_data_Scotland&amp;quot;] = 41000,&lt;br /&gt;
[&amp;quot;Country_data_Senegal&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Country_data_Serbia&amp;quot;] = 43000,&lt;br /&gt;
[&amp;quot;Country_data_Serbia_and_Montenegro&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Country_data_Seychelles&amp;quot;] = 4400,&lt;br /&gt;
[&amp;quot;Country_data_Sierra_Leone&amp;quot;] = 5900,&lt;br /&gt;
[&amp;quot;Country_data_Singapore&amp;quot;] = 22000,&lt;br /&gt;
[&amp;quot;Country_data_Slovakia&amp;quot;] = 40000,&lt;br /&gt;
[&amp;quot;Country_data_Slovenia&amp;quot;] = 32000,&lt;br /&gt;
[&amp;quot;Country_data_Solomon_Islands&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Country_data_Somalia&amp;quot;] = 5000,&lt;br /&gt;
[&amp;quot;Country_data_South_Africa&amp;quot;] = 53000,&lt;br /&gt;
[&amp;quot;Country_data_South_Carolina&amp;quot;] = 3100,&lt;br /&gt;
[&amp;quot;Country_data_South_Korea&amp;quot;] = 50000,&lt;br /&gt;
[&amp;quot;Country_data_South_Sudan&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Country_data_Soviet_Union&amp;quot;] = 27000,&lt;br /&gt;
[&amp;quot;Country_data_Spain&amp;quot;] = 104000,&lt;br /&gt;
[&amp;quot;Country_data_Sri_Lanka&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_Sudan&amp;quot;] = 6500,&lt;br /&gt;
[&amp;quot;Country_data_Suriname&amp;quot;] = 5100,&lt;br /&gt;
[&amp;quot;Country_data_Swaziland&amp;quot;] = 2000,&lt;br /&gt;
[&amp;quot;Country_data_Sweden&amp;quot;] = 80000,&lt;br /&gt;
[&amp;quot;Country_data_Switzerland&amp;quot;] = 64000,&lt;br /&gt;
[&amp;quot;Country_data_Syria&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Country_data_São_Tomé_and_Príncipe&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Country_data_TAN&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_TCH&amp;quot;] = 8900,&lt;br /&gt;
[&amp;quot;Country_data_THA&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Country_data_TJK&amp;quot;] = 2000,&lt;br /&gt;
[&amp;quot;Country_data_TKM&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_TPE&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Country_data_TRI&amp;quot;] = 4500,&lt;br /&gt;
[&amp;quot;Country_data_TUN&amp;quot;] = 8100,&lt;br /&gt;
[&amp;quot;Country_data_TUR&amp;quot;] = 22000,&lt;br /&gt;
[&amp;quot;Country_data_Taiwan&amp;quot;] = 9700,&lt;br /&gt;
[&amp;quot;Country_data_Tajikistan&amp;quot;] = 7200,&lt;br /&gt;
[&amp;quot;Country_data_Tanzania&amp;quot;] = 8800,&lt;br /&gt;
[&amp;quot;Country_data_Texas&amp;quot;] = 5100,&lt;br /&gt;
[&amp;quot;Country_data_Thailand&amp;quot;] = 35000,&lt;br /&gt;
[&amp;quot;Country_data_Togo&amp;quot;] = 5400,&lt;br /&gt;
[&amp;quot;Country_data_Tonga&amp;quot;] = 5500,&lt;br /&gt;
[&amp;quot;Country_data_Trinidad_and_Tobago&amp;quot;] = 12000,&lt;br /&gt;
[&amp;quot;Country_data_Tunisia&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_Turkey&amp;quot;] = 55000,&lt;br /&gt;
[&amp;quot;Country_data_Turkmenistan&amp;quot;] = 6400,&lt;br /&gt;
[&amp;quot;Country_data_Turks_and_Caicos_Islands&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Country_data_Tuvalu&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Country_data_U.S._Virgin_Islands&amp;quot;] = 4400,&lt;br /&gt;
[&amp;quot;Country_data_UAE&amp;quot;] = 7700,&lt;br /&gt;
[&amp;quot;Country_data_UGA&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;Country_data_UK&amp;quot;] = 22000,&lt;br /&gt;
[&amp;quot;Country_data_UKGBI&amp;quot;] = 2300,&lt;br /&gt;
[&amp;quot;Country_data_UKR&amp;quot;] = 30000,&lt;br /&gt;
[&amp;quot;Country_data_URS&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Country_data_URU&amp;quot;] = 13000,&lt;br /&gt;
[&amp;quot;Country_data_US&amp;quot;] = 4800,&lt;br /&gt;
[&amp;quot;Country_data_USA&amp;quot;] = 120000,&lt;br /&gt;
[&amp;quot;Country_data_USSR&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Country_data_UZB&amp;quot;] = 9000,&lt;br /&gt;
[&amp;quot;Country_data_Uganda&amp;quot;] = 9900,&lt;br /&gt;
[&amp;quot;Country_data_Ukraine&amp;quot;] = 51000,&lt;br /&gt;
[&amp;quot;Country_data_United_Arab_Emirates&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_United_Kingdom&amp;quot;] = 76000,&lt;br /&gt;
[&amp;quot;Country_data_United_Kingdom_of_Great_Britain_and_Ireland&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Country_data_United_Nations&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Country_data_United_States&amp;quot;] = 251000,&lt;br /&gt;
[&amp;quot;Country_data_United_States_of_America&amp;quot;] = 5100,&lt;br /&gt;
[&amp;quot;Country_data_Uruguay&amp;quot;] = 24000,&lt;br /&gt;
[&amp;quot;Country_data_Uzbekistan&amp;quot;] = 16000,&lt;br /&gt;
[&amp;quot;Country_data_VEN&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Country_data_VIE&amp;quot;] = 5500,&lt;br /&gt;
[&amp;quot;Country_data_Vanuatu&amp;quot;] = 4400,&lt;br /&gt;
[&amp;quot;Country_data_Venezuela&amp;quot;] = 27000,&lt;br /&gt;
[&amp;quot;Country_data_Vietnam&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Country_data_Virginia&amp;quot;] = 2600,&lt;br /&gt;
[&amp;quot;Country_data_WAL&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_data_Wales&amp;quot;] = 27000,&lt;br /&gt;
[&amp;quot;Country_data_Washington&amp;quot;] = 3200,&lt;br /&gt;
[&amp;quot;Country_data_Washington,_D.C.&amp;quot;] = 2100,&lt;br /&gt;
[&amp;quot;Country_data_Washington_(state)&amp;quot;] = 3400,&lt;br /&gt;
[&amp;quot;Country_data_West_Germany&amp;quot;] = 17000,&lt;br /&gt;
[&amp;quot;Country_data_West_Indies&amp;quot;] = 2200,&lt;br /&gt;
[&amp;quot;Country_data_Wisconsin&amp;quot;] = 5500,&lt;br /&gt;
[&amp;quot;Country_data_YUG&amp;quot;] = 8100,&lt;br /&gt;
[&amp;quot;Country_data_Yemen&amp;quot;] = 6500,&lt;br /&gt;
[&amp;quot;Country_data_Yugoslavia&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_data_ZAF&amp;quot;] = 4000,&lt;br /&gt;
[&amp;quot;Country_data_ZAM&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Country_data_ZIM&amp;quot;] = 7100,&lt;br /&gt;
[&amp;quot;Country_data_Zambia&amp;quot;] = 7900,&lt;br /&gt;
[&amp;quot;Country_data_Zimbabwe&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Country_flagbio&amp;quot;] = 21000,&lt;br /&gt;
[&amp;quot;Country_name&amp;quot;] = 8700,&lt;br /&gt;
[&amp;quot;Country_showdata&amp;quot;] = 5300,&lt;br /&gt;
[&amp;quot;Country_topics&amp;quot;] = 20000,&lt;br /&gt;
[&amp;quot;County&amp;quot;] = 7200,&lt;br /&gt;
[&amp;quot;County_(judet)_of_Romania&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Course_assignment&amp;quot;] = 4300,&lt;br /&gt;
[&amp;quot;Course_details&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Cquote&amp;quot;] = 36000,&lt;br /&gt;
[&amp;quot;Cr&amp;quot;] = 3800,&lt;br /&gt;
[&amp;quot;Create_taxonomy&amp;quot;] = 2400,&lt;br /&gt;
[&amp;quot;Create_taxonomy/link&amp;quot;] = 74000,&lt;br /&gt;
[&amp;quot;Cricinfo&amp;quot;] = 18000,&lt;br /&gt;
[&amp;quot;Cricketarchive&amp;quot;] = 2700,&lt;br /&gt;
[&amp;quot;Crime_opentask&amp;quot;] = 29000,&lt;br /&gt;
[&amp;quot;Cross&amp;quot;] = 19000,&lt;br /&gt;
[&amp;quot;Ct&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Curlie&amp;quot;] = 7100,&lt;br /&gt;
[&amp;quot;Current_events_footer&amp;quot;] = 6000,&lt;br /&gt;
[&amp;quot;Current_events_header&amp;quot;] = 7100,&lt;br /&gt;
[&amp;quot;Currentdate&amp;quot;] = 20000,&lt;br /&gt;
[&amp;quot;Cvt&amp;quot;] = 58000,&lt;br /&gt;
[&amp;quot;Cycling_Archives&amp;quot;] = 5700,&lt;br /&gt;
[&amp;quot;Cycling_archives&amp;quot;] = 3900,&lt;br /&gt;
[&amp;quot;Cycling_team_link&amp;quot;] = 10000,&lt;br /&gt;
[&amp;quot;Module:CFB_schedule&amp;quot;] = 20000,&lt;br /&gt;
[&amp;quot;Module:CallAssert&amp;quot;] = 189000,&lt;br /&gt;
[&amp;quot;Module:CanElecResTopTest&amp;quot;] = 4200,&lt;br /&gt;
[&amp;quot;Module:CanadaByProvinceCatNav&amp;quot;] = 9200,&lt;br /&gt;
[&amp;quot;Module:Cat_main&amp;quot;] = 161000,&lt;br /&gt;
[&amp;quot;Module:Cat_more_if_exists&amp;quot;] = 39000,&lt;br /&gt;
[&amp;quot;Module:Catalog_lookup_link&amp;quot;] = 468000,&lt;br /&gt;
[&amp;quot;Module:Category_described_in_year&amp;quot;] = 5400,&lt;br /&gt;
[&amp;quot;Module:Category_described_in_year/conf&amp;quot;] = 5400,&lt;br /&gt;
[&amp;quot;Module:Category_handler&amp;quot;] = 4050000,&lt;br /&gt;
[&amp;quot;Module:Category_handler/blacklist&amp;quot;] = 4050000,&lt;br /&gt;
[&amp;quot;Module:Category_handler/config&amp;quot;] = 4050000,&lt;br /&gt;
[&amp;quot;Module:Category_handler/data&amp;quot;] = 4050000,&lt;br /&gt;
[&amp;quot;Module:Category_handler/shared&amp;quot;] = 4050000,&lt;br /&gt;
[&amp;quot;Module:Category_see_also&amp;quot;] = 37000,&lt;br /&gt;
[&amp;quot;Module:Celestial_object_quadrangle&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Module:Check_for_clobbered_parameters&amp;quot;] = 164000,&lt;br /&gt;
[&amp;quot;Module:Check_for_deprecated_parameters&amp;quot;] = 388000,&lt;br /&gt;
[&amp;quot;Module:Check_for_unknown_parameters&amp;quot;] = 10900000,&lt;br /&gt;
[&amp;quot;Module:Check_isxn&amp;quot;] = 462000,&lt;br /&gt;
[&amp;quot;Module:Check_winner_by_scores&amp;quot;] = 9900,&lt;br /&gt;
[&amp;quot;Module:Citation/CS1&amp;quot;] = 4610000,&lt;br /&gt;
[&amp;quot;Module:Citation/CS1/COinS&amp;quot;] = 4610000,&lt;br /&gt;
[&amp;quot;Module:Citation/CS1/Configuration&amp;quot;] = 4610000,&lt;br /&gt;
[&amp;quot;Module:Citation/CS1/Date_validation&amp;quot;] = 4610000,&lt;br /&gt;
[&amp;quot;Module:Citation/CS1/Identifiers&amp;quot;] = 4610000,&lt;br /&gt;
[&amp;quot;Module:Citation/CS1/Suggestions&amp;quot;] = 28000,&lt;br /&gt;
[&amp;quot;Module:Citation/CS1/Utilities&amp;quot;] = 4610000,&lt;br /&gt;
[&amp;quot;Module:Citation/CS1/Whitelist&amp;quot;] = 4610000,&lt;br /&gt;
[&amp;quot;Module:Citation/CS1/styles.css&amp;quot;] = 4730000,&lt;br /&gt;
[&amp;quot;Module:Cite_Q&amp;quot;] = 43000,&lt;br /&gt;
[&amp;quot;Module:Cite_iucn&amp;quot;] = 30000,&lt;br /&gt;
[&amp;quot;Module:Clade&amp;quot;] = 5200,&lt;br /&gt;
[&amp;quot;Module:Clickable_button_2&amp;quot;] = 719000,&lt;br /&gt;
[&amp;quot;Module:Collapsible_list&amp;quot;] = 45000,&lt;br /&gt;
[&amp;quot;Module:College_color&amp;quot;] = 106000,&lt;br /&gt;
[&amp;quot;Module:College_color/data&amp;quot;] = 106000,&lt;br /&gt;
[&amp;quot;Module:Color_contrast&amp;quot;] = 431000,&lt;br /&gt;
[&amp;quot;Module:Color_contrast/colors&amp;quot;] = 432000,&lt;br /&gt;
[&amp;quot;Module:Commons_link&amp;quot;] = 89000,&lt;br /&gt;
[&amp;quot;Module:Complex_date&amp;quot;] = 14000,&lt;br /&gt;
[&amp;quot;Module:Convert&amp;quot;] = 1070000,&lt;br /&gt;
[&amp;quot;Module:Convert/data&amp;quot;] = 1070000,&lt;br /&gt;
[&amp;quot;Module:Convert/helper&amp;quot;] = 5700,&lt;br /&gt;
[&amp;quot;Module:Convert/text&amp;quot;] = 1070000,&lt;br /&gt;
[&amp;quot;Module:Convert/wikidata&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Module:Convert/wikidata/data&amp;quot;] = 2500,&lt;br /&gt;
[&amp;quot;Module:ConvertNumeric&amp;quot;] = 22000,&lt;br /&gt;
[&amp;quot;Module:Convert_character_width&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Module:Convert_character_width/data&amp;quot;] = 2800,&lt;br /&gt;
[&amp;quot;Module:Coordinates&amp;quot;] = 1240000,&lt;br /&gt;
[&amp;quot;Module:Copied&amp;quot;] = 15000,&lt;br /&gt;
[&amp;quot;Module:CountryAdjectiveDemonym&amp;quot;] = 38000,&lt;br /&gt;
[&amp;quot;Module:CountryAdjectiveDemonym/Adjectives&amp;quot;] = 38000,&lt;br /&gt;
[&amp;quot;Module:CountryAdjectiveDemonym/Demonyms&amp;quot;] = 38000,&lt;br /&gt;
[&amp;quot;Module:CountryAdjectiveDemonym/The&amp;quot;] = 38000,&lt;br /&gt;
[&amp;quot;Module:CountryData&amp;quot;] = 17000,&lt;br /&gt;
[&amp;quot;Module:Country_adjective&amp;quot;] = 3300,&lt;br /&gt;
[&amp;quot;Module:Country_alias&amp;quot;] = 45000,&lt;br /&gt;
[&amp;quot;Module:Country_alias/data&amp;quot;] = 45000,&lt;br /&gt;
}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Transclusion_count&amp;diff=14478</id>
		<title>Module:Transclusion count</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Transclusion_count&amp;diff=14478"/>
		<updated>2020-10-21T14:17:20Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local p = {}&lt;br /&gt;
&lt;br /&gt;
function p.fetch(frame)&lt;br /&gt;
	local template = nil&lt;br /&gt;
	local return_value = nil&lt;br /&gt;
&lt;br /&gt;
	-- Use demo parameter if it exists, otherswise use current template name&lt;br /&gt;
	local namespace = mw.title.getCurrentTitle().namespace&lt;br /&gt;
	if frame.args[&amp;quot;demo&amp;quot;] and frame.args[&amp;quot;demo&amp;quot;] ~= &amp;quot;&amp;quot; then&lt;br /&gt;
		template = frame.args[&amp;quot;demo&amp;quot;]&lt;br /&gt;
	elseif namespace == 10 then -- Template namespace&lt;br /&gt;
		template = mw.title.getCurrentTitle().text&lt;br /&gt;
	elseif namespace == 828 then -- Module namespace&lt;br /&gt;
		template = (mw.site.namespaces[828].name .. &amp;quot;:&amp;quot; .. mw.title.getCurrentTitle().text)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- If in template or module namespace, look up count in /data&lt;br /&gt;
	if template ~= nil then&lt;br /&gt;
		namespace = mw.title.new(template, &amp;quot;Template&amp;quot;).namespace&lt;br /&gt;
		if namespace == 10 or namespace == 828 then&lt;br /&gt;
			template =  mw.ustring.gsub(template, &amp;quot;/doc$&amp;quot;, &amp;quot;&amp;quot;) -- strip /doc from end&lt;br /&gt;
			local index = mw.ustring.sub(mw.title.new(template).text,1,1)&lt;br /&gt;
			local data = mw.loadData(&#039;Module:Transclusion_count/data/&#039; .. (mw.ustring.find(index, &amp;quot;%a&amp;quot;) and index or &amp;quot;other&amp;quot;))&lt;br /&gt;
			return_value = tonumber(data[mw.ustring.gsub(template, &amp;quot; &amp;quot;, &amp;quot;_&amp;quot;)])&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- If database value doesn&#039;t exist, use value passed to template&lt;br /&gt;
	if return_value == nil and frame.args[1] ~= nil then&lt;br /&gt;
		local arg1=mw.ustring.match(frame.args[1], &#039;[%d,]+&#039;)&lt;br /&gt;
		if arg1 and arg1 ~= &#039;&#039; then&lt;br /&gt;
			return_value = tonumber(frame:callParserFunction(&#039;formatnum&#039;, arg1, &#039;R&#039;))&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return return_value	&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:String&amp;diff=14476</id>
		<title>Module:String</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:String&amp;diff=14476"/>
		<updated>2020-10-21T14:17:20Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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. It is exported for use in other modules&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
strmatch = require(&amp;quot;Module:String&amp;quot;)._match&lt;br /&gt;
sresult = strmatch( s, pattern, start, match, plain, nomatch )&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;
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;
-- This sub-routine is exported for use in other modules&lt;br /&gt;
function str._match( s, pattern, start, match_index, plain_flag, nomatch )&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;
	start = tonumber(start) or 1&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;
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|match|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;
-- This is the entry point for #invoke:String|match&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;
	return str._match( s, pattern, start, match_index, plain_flag, nomatch )&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;
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;
escapePattern&lt;br /&gt;
&lt;br /&gt;
This function escapes special characters from a Lua string pattern. See [1]&lt;br /&gt;
for details on how patterns work.&lt;br /&gt;
&lt;br /&gt;
[1] https://www.mediawiki.org/wiki/Extension:Scribunto/Lua_reference_manual#Patterns&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:String|escapePattern|pattern_string}}&lt;br /&gt;
&lt;br /&gt;
Parameters&lt;br /&gt;
    pattern_string: The pattern string to escape.&lt;br /&gt;
]]&lt;br /&gt;
function str.escapePattern( frame )&lt;br /&gt;
	local pattern_str = frame.args[1]&lt;br /&gt;
	if not pattern_str then&lt;br /&gt;
		return str._error( &#039;No pattern string specified&#039; )&lt;br /&gt;
	end&lt;br /&gt;
	local result = str._escapePattern( pattern_str )&lt;br /&gt;
	return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
count&lt;br /&gt;
This function counts the number of occurrences of one string in another.&lt;br /&gt;
]]&lt;br /&gt;
function str.count(frame)&lt;br /&gt;
	local args = str._getParameters(frame.args, {&#039;source&#039;, &#039;pattern&#039;, &#039;plain&#039;})&lt;br /&gt;
	local source = args.source or &#039;&#039;&lt;br /&gt;
	local pattern = args.pattern or &#039;&#039;&lt;br /&gt;
	local plain = str._getBoolean(args.plain or true)&lt;br /&gt;
	if plain then&lt;br /&gt;
		pattern = str._escapePattern(pattern)&lt;br /&gt;
	end&lt;br /&gt;
	local _, count = mw.ustring.gsub(source, pattern, &#039;&#039;)&lt;br /&gt;
	return count&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
endswith&lt;br /&gt;
This function determines whether a string ends with another string.&lt;br /&gt;
]]&lt;br /&gt;
function str.endswith(frame)&lt;br /&gt;
	local args = str._getParameters(frame.args, {&#039;source&#039;, &#039;pattern&#039;})&lt;br /&gt;
	local source = args.source or &#039;&#039;&lt;br /&gt;
	local pattern = args.pattern or &#039;&#039;&lt;br /&gt;
	if pattern == &#039;&#039; then&lt;br /&gt;
		-- All strings end with the empty string.&lt;br /&gt;
		return &amp;quot;yes&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	if mw.ustring.sub(source, -mw.ustring.len(pattern), -1) == pattern then&lt;br /&gt;
		return &amp;quot;yes&amp;quot;&lt;br /&gt;
	else&lt;br /&gt;
		return &amp;quot;&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
join&lt;br /&gt;
&lt;br /&gt;
Join all non empty arguments together; the first argument is the separator.&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:String|join|sep|one|two|three}}&lt;br /&gt;
]]&lt;br /&gt;
function str.join(frame)&lt;br /&gt;
	local args = {}&lt;br /&gt;
	local sep&lt;br /&gt;
	for _, v in ipairs( frame.args ) do&lt;br /&gt;
		if sep then&lt;br /&gt;
			if v ~= &#039;&#039; then&lt;br /&gt;
				table.insert(args, v)&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			sep = v&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return table.concat( args, sep or &#039;&#039; )&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 _, 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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Shortcut/config&amp;diff=14474</id>
		<title>Module:Shortcut/config</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Shortcut/config&amp;diff=14474"/>
		<updated>2020-10-21T14:17:19Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module holds configuration data for [[Module:Shortcut]].&lt;br /&gt;
&lt;br /&gt;
return {&lt;br /&gt;
&lt;br /&gt;
-- The heading at the top of the shortcut box. It accepts the following parameter:&lt;br /&gt;
-- $1 - the total number of shortcuts. (required)&lt;br /&gt;
[&#039;shortcut-heading&#039;] = &#039;[[Wikipedia:Shortcut|{{PLURAL:$1|Shortcut|Shortcuts}}]]&#039;,&lt;br /&gt;
&lt;br /&gt;
-- The error message to display when a shortcut is invalid (is not a string, or&lt;br /&gt;
-- is the blank string). It accepts the following parameter:&lt;br /&gt;
-- $1 - the number of the shortcut in the argument list. (required)&lt;br /&gt;
[&#039;invalid-shortcut-error&#039;] = &#039;shortcut #$1 was invalid (shortcuts must be &#039; ..&lt;br /&gt;
	&#039;strings of at least one character in length)&#039;,&lt;br /&gt;
&lt;br /&gt;
-- The error message to display when no shortcuts or other displayable content&lt;br /&gt;
-- were specified. (required)&lt;br /&gt;
[&#039;no-content-error&#039;] = &#039;Error: no shortcuts were specified and the &#039; ..&lt;br /&gt;
	mw.text.nowiki(&#039;|msg=&#039;) ..&lt;br /&gt;
	&#039; parameter was not set.&#039;,&lt;br /&gt;
&lt;br /&gt;
-- A category to add when the no-content-error message is displayed. (optional)&lt;br /&gt;
[&#039;no-content-error-category&#039;] = &#039;Shortcut templates with missing parameters&#039;,&lt;br /&gt;
}&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Shortcut&amp;diff=14472</id>
		<title>Module:Shortcut</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Shortcut&amp;diff=14472"/>
		<updated>2020-10-21T14:17:19Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module implements {{shortcut}}.&lt;br /&gt;
&lt;br /&gt;
-- Set constants&lt;br /&gt;
local CONFIG_MODULE = &#039;Module:Shortcut/config&#039;&lt;br /&gt;
&lt;br /&gt;
-- Load required modules&lt;br /&gt;
local checkType = require(&#039;libraryUtil&#039;).checkType&lt;br /&gt;
local yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function message(msg, ...)&lt;br /&gt;
	return mw.message.newRawMessage(msg, ...):plain()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function makeCategoryLink(cat)&lt;br /&gt;
	return string.format(&#039;[[%s:%s]]&#039;, mw.site.namespaces[14].name, cat)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(shortcuts, options, frame, cfg)&lt;br /&gt;
	checkType(&#039;_main&#039;, 1, shortcuts, &#039;table&#039;)&lt;br /&gt;
	checkType(&#039;_main&#039;, 2, options, &#039;table&#039;, true)&lt;br /&gt;
	options = options or {}&lt;br /&gt;
	frame = frame or mw.getCurrentFrame()&lt;br /&gt;
	cfg = cfg or mw.loadData(CONFIG_MODULE)&lt;br /&gt;
	local isCategorized = yesno(options.category) ~= false&lt;br /&gt;
&lt;br /&gt;
	-- Validate shortcuts&lt;br /&gt;
	for i, shortcut in ipairs(shortcuts) do&lt;br /&gt;
		if type(shortcut) ~= &#039;string&#039; or #shortcut &amp;lt; 1 then&lt;br /&gt;
			error(message(cfg[&#039;invalid-shortcut-error&#039;], i), 2)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Make the list items. These are the shortcuts plus any extra lines such&lt;br /&gt;
	-- as options.msg.&lt;br /&gt;
	local listItems = {}&lt;br /&gt;
	for i, shortcut in ipairs(shortcuts) do&lt;br /&gt;
		if yesno(options[&#039;target&#039;]) then&lt;br /&gt;
			listItems[i] = string.format(&amp;quot;[[%s]]&amp;quot;,shortcut)&lt;br /&gt;
		else&lt;br /&gt;
			listItems[i] = frame:expandTemplate{&lt;br /&gt;
				title = &#039;No redirect&#039;,&lt;br /&gt;
				args = {shortcut}&lt;br /&gt;
			}&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	table.insert(listItems, options.msg)&lt;br /&gt;
&lt;br /&gt;
	-- Return an error if we have nothing to display&lt;br /&gt;
	if #listItems &amp;lt; 1 then&lt;br /&gt;
		local msg = cfg[&#039;no-content-error&#039;]&lt;br /&gt;
		msg = string.format(&#039;&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;%s&amp;lt;/strong&amp;gt;&#039;, msg)&lt;br /&gt;
		if isCategorized and cfg[&#039;no-content-error-category&#039;] then&lt;br /&gt;
			msg = msg .. makeCategoryLink(cfg[&#039;no-content-error-category&#039;])&lt;br /&gt;
		end&lt;br /&gt;
		return msg&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local root = mw.html.create()&lt;br /&gt;
	root:wikitext(frame:extensionTag{ name = &#039;templatestyles&#039;, args = { src = &#039;Shortcut/styles.css&#039;} })&lt;br /&gt;
	-- Anchors&lt;br /&gt;
	local anchorDiv = root&lt;br /&gt;
		:tag(&#039;div&#039;)&lt;br /&gt;
			:addClass(&#039;module-shortcutanchordiv&#039;)&lt;br /&gt;
	for i, shortcut in ipairs(shortcuts) do&lt;br /&gt;
		local anchor = mw.uri.anchorEncode(shortcut)&lt;br /&gt;
		anchorDiv:tag(&#039;span&#039;):attr(&#039;id&#039;, anchor)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Shortcut heading&lt;br /&gt;
	local shortcutHeading&lt;br /&gt;
	do&lt;br /&gt;
		local nShortcuts = #shortcuts&lt;br /&gt;
		if nShortcuts &amp;gt; 0 then&lt;br /&gt;
			local headingMsg = options[&#039;shortcut-heading&#039;] or cfg[&#039;shortcut-heading&#039;]&lt;br /&gt;
			shortcutHeading = message(headingMsg, nShortcuts)&lt;br /&gt;
			shortcutHeading = frame:preprocess(shortcutHeading)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Shortcut box&lt;br /&gt;
	local shortcutList = root&lt;br /&gt;
		:tag(&#039;div&#039;)&lt;br /&gt;
			:addClass(&#039;module-shortcutboxplain plainlist noprint&#039;)&lt;br /&gt;
			:attr(&#039;role&#039;, &#039;note&#039;)&lt;br /&gt;
	if shortcutHeading then&lt;br /&gt;
		shortcutList&lt;br /&gt;
			:tag(&#039;div&#039;)&lt;br /&gt;
				:addClass(&#039;module-shortcutlist&#039;)&lt;br /&gt;
				:wikitext(shortcutHeading)&lt;br /&gt;
	end&lt;br /&gt;
	local list = shortcutList:tag(&#039;ul&#039;)&lt;br /&gt;
	for i, item in ipairs(listItems) do&lt;br /&gt;
		list:tag(&#039;li&#039;):wikitext(item)&lt;br /&gt;
	end&lt;br /&gt;
	return tostring(root)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local args = require(&#039;Module:Arguments&#039;).getArgs(frame)&lt;br /&gt;
&lt;br /&gt;
	-- Separate shortcuts from options&lt;br /&gt;
	local shortcuts, options = {}, {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		if type(k) == &#039;number&#039; then&lt;br /&gt;
			shortcuts[k] = v&lt;br /&gt;
		else&lt;br /&gt;
			options[k] = v&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Compress the shortcut array, which may contain nils.&lt;br /&gt;
	local function compressArray(t)&lt;br /&gt;
		local nums, ret = {}, {}&lt;br /&gt;
		for k in pairs(t) do&lt;br /&gt;
			nums[#nums + 1] = k&lt;br /&gt;
		end&lt;br /&gt;
		table.sort(nums)&lt;br /&gt;
		for i, num in ipairs(nums) do&lt;br /&gt;
			ret[i] = t[num]&lt;br /&gt;
		end&lt;br /&gt;
		return ret&lt;br /&gt;
	end&lt;br /&gt;
	shortcuts = compressArray(shortcuts)&lt;br /&gt;
&lt;br /&gt;
	return p._main(shortcuts, options, frame)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Redirect&amp;diff=14470</id>
		<title>Module:Redirect</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Redirect&amp;diff=14470"/>
		<updated>2020-10-21T14:17:18Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module provides functions for getting the target of a redirect page.&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-- Gets a mw.title object, using pcall to avoid generating script errors if we&lt;br /&gt;
-- are over the expensive function count limit (among other possible causes).&lt;br /&gt;
local function getTitle(...)&lt;br /&gt;
	local success, titleObj = pcall(mw.title.new, ...)&lt;br /&gt;
	if success then&lt;br /&gt;
		return titleObj&lt;br /&gt;
	else&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Gets the name of a page that a redirect leads to, or nil if it isn&#039;t a&lt;br /&gt;
-- redirect.&lt;br /&gt;
function p.getTargetFromText(text)&lt;br /&gt;
	local target = string.match(&lt;br /&gt;
		text,&lt;br /&gt;
		&amp;quot;^%s*#[Rr][Ee][Dd][Ii][Rr][Ee][Cc][Tt]%s*:?%s*%[%[([^%[%]|]-)%]%]&amp;quot;&lt;br /&gt;
	) or string.match(&lt;br /&gt;
		text,&lt;br /&gt;
		&amp;quot;^%s*#[Rr][Ee][Dd][Ii][Rr][Ee][Cc][Tt]%s*:?%s*%[%[([^%[%]|]-)|[^%[%]]-%]%]&amp;quot;&lt;br /&gt;
	)&lt;br /&gt;
	return target and mw.uri.decode(target, &#039;PATH&#039;)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Gets the target of a redirect. If the page specified is not a redirect,&lt;br /&gt;
-- returns nil.&lt;br /&gt;
function p.getTarget(page, fulltext)&lt;br /&gt;
	-- Get the title object. Both page names and title objects are allowed&lt;br /&gt;
	-- as input.&lt;br /&gt;
	local titleObj&lt;br /&gt;
	if type(page) == &#039;string&#039; or type(page) == &#039;number&#039; then&lt;br /&gt;
		titleObj = getTitle(page)&lt;br /&gt;
	elseif type(page) == &#039;table&#039; and type(page.getContent) == &#039;function&#039; then&lt;br /&gt;
		titleObj = page&lt;br /&gt;
	else&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&amp;quot;bad argument #1 to &#039;getTarget&#039;&amp;quot;&lt;br /&gt;
				.. &amp;quot; (string, number, or title object expected, got %s)&amp;quot;,&lt;br /&gt;
			type(page)&lt;br /&gt;
		), 2)&lt;br /&gt;
	end&lt;br /&gt;
	if not titleObj or not titleObj.isRedirect then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Find the target by using string matching on the page content.&lt;br /&gt;
	local target = p.getTargetFromText(titleObj:getContent() or &amp;quot;&amp;quot;)&lt;br /&gt;
	if target then&lt;br /&gt;
		local targetTitle = getTitle(target)&lt;br /&gt;
		if targetTitle then&lt;br /&gt;
			if fulltext then&lt;br /&gt;
				return targetTitle.fullText&lt;br /&gt;
			else&lt;br /&gt;
				return targetTitle.prefixedText&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		-- The page is a redirect, but matching failed. This indicates a bug in&lt;br /&gt;
		-- the redirect matching pattern, so throw an error.&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&#039;could not parse redirect on page &amp;quot;%s&amp;quot;&#039;,&lt;br /&gt;
			fulltext and titleObj.fullText or titleObj.prefixedText&lt;br /&gt;
		))&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- Given a single page name determines what page it redirects to and returns the&lt;br /&gt;
-- target page name, or the passed page name when not a redirect. The passed&lt;br /&gt;
-- page name can be given as plain text or as a page link.&lt;br /&gt;
-- &lt;br /&gt;
-- Returns page name as plain text, or when the bracket parameter is given, as a&lt;br /&gt;
-- page link. Returns an error message when page does not exist or the redirect&lt;br /&gt;
-- target cannot be determined for some reason.&lt;br /&gt;
--]]&lt;br /&gt;
function p.luaMain(rname, bracket, fulltext)&lt;br /&gt;
	if type(rname) ~= &amp;quot;string&amp;quot; or not rname:find(&amp;quot;%S&amp;quot;) then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	bracket = bracket and &amp;quot;[[%s]]&amp;quot; or &amp;quot;%s&amp;quot;&lt;br /&gt;
	rname = rname:match(&amp;quot;%[%[(.+)%]%]&amp;quot;) or rname&lt;br /&gt;
	local target = p.getTarget(rname, fulltext)&lt;br /&gt;
	local ret = target or rname&lt;br /&gt;
	ret = getTitle(ret)&lt;br /&gt;
	if ret then&lt;br /&gt;
		if fulltext then&lt;br /&gt;
			ret = ret.fullText&lt;br /&gt;
		else&lt;br /&gt;
			ret = ret.prefixedText&lt;br /&gt;
		end&lt;br /&gt;
		return bracket:format(ret)&lt;br /&gt;
	else&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Provides access to the luaMain function from wikitext.&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local args = require(&#039;Module:Arguments&#039;).getArgs(frame, {frameOnly = true})&lt;br /&gt;
	return p.luaMain(args[1], args.bracket, args.fulltext) or &#039;&#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Returns true if the specified page is a redirect, and false otherwise.&lt;br /&gt;
function p.luaIsRedirect(page)&lt;br /&gt;
	local titleObj = getTitle(page)&lt;br /&gt;
	if not titleObj then&lt;br /&gt;
		return false&lt;br /&gt;
	end&lt;br /&gt;
	if titleObj.isRedirect 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;
-- Provides access to the luaIsRedirect function from wikitext, returning &#039;yes&#039;&lt;br /&gt;
-- if the specified page is a redirect, and the blank string otherwise.&lt;br /&gt;
function p.isRedirect(frame)&lt;br /&gt;
	local args = require(&#039;Module:Arguments&#039;).getArgs(frame, {frameOnly = true})&lt;br /&gt;
	if p.luaIsRedirect(args[1]) then&lt;br /&gt;
		return &#039;yes&#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;
return p&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Protection_banner/config&amp;diff=14468</id>
		<title>Module:Protection banner/config</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Protection_banner/config&amp;diff=14468"/>
		<updated>2020-10-21T14:17:18Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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;
-- ${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, autoreview and upload subtables.&lt;br /&gt;
defaultBanners = {&lt;br /&gt;
	edit = {},&lt;br /&gt;
	move = {},&lt;br /&gt;
	autoreview = {&lt;br /&gt;
		default = {&lt;br /&gt;
			alt = &#039;Page protected with pending changes&#039;,&lt;br /&gt;
			tooltip = &#039;All edits by unregistered and new users are subject to review prior to becoming visible to unregistered users&#039;,&lt;br /&gt;
			image = &#039;Pending-protection-shackle.svg&#039;&lt;br /&gt;
		}&lt;br /&gt;
	},&lt;br /&gt;
	upload = {}&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, autoreview and upload 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 persons&#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;Office-protection-shackle.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;
		ecp = {&lt;br /&gt;
			description = &#039;For articles in topic areas authorized by&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Arbitration Committee|ArbCom]] or&#039;&lt;br /&gt;
				.. &#039; meets the criteria for community use&#039;,&lt;br /&gt;
			tooltip = &#039;This ${PAGETYPE} is extended-confirmed protected&#039;,&lt;br /&gt;
			alt = &#039;Extended-protected ${PAGETYPE}&#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;Office-protection-shackle.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;Office-protection-shackle.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;Move-protection-shackle.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;
	upload = {}&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, autoreview and upload 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;
		extendedconfirmed = &#039;This ${PAGETYPE} is currently under extended confirmed protection&#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;
		default = &#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;
	},&lt;br /&gt;
	upload = {&lt;br /&gt;
		default = &#039;Uploading new versions of this ${PAGETYPE} is currently disabled&#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, autoreview and upload 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;
		extendedconfirmed = {&lt;br /&gt;
			default = &#039;Extended confirmed protection prevents edits from all unregistered editors&#039;&lt;br /&gt;
				.. &#039; and registered users with fewer than 30 days tenure and 500 edits.&#039;&lt;br /&gt;
				.. &#039; The [[Wikipedia:Protection policy#extended|policy on community use]]&#039;&lt;br /&gt;
				.. &#039; specifies that extended confirmed protection can be applied to combat&#039;&lt;br /&gt;
				.. &#039; disruption, if semi-protection has proven to be ineffective.&#039;&lt;br /&gt;
				.. &#039; Extended confirmed protection may also be applied to enforce&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Arbitration Committee|arbitration sanctions]].&#039;&lt;br /&gt;
				.. &#039; Please discuss any changes on the ${TALKPAGE}; you may&#039;&lt;br /&gt;
				.. &#039; ${EDITREQUEST} to ask for uncontroversial changes supported by&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Consensus|consensus]].&#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;
			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;
	upload = {&lt;br /&gt;
		default = {&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 new versions of the file&#039;&lt;br /&gt;
				.. &#039; cannot be uploaded until it is unprotected. You can&#039;&lt;br /&gt;
				.. &#039; request that a new version be uploaded by using a&#039;&lt;br /&gt;
				.. &#039; [[Wikipedia:Edit requests|protected edit request]], or you&#039;&lt;br /&gt;
				.. &#039; can  [[Wikipedia:Requests for page protection|request]]&#039;&lt;br /&gt;
				.. &#039; that the file be unprotected.&#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 protection 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, autoreview and upload 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;
		extendedconfirmed = &#039;extended-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;
	upload = {&lt;br /&gt;
		default = &#039;upload-protected&#039;&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;Full-protection-shackle.svg&#039;,&lt;br /&gt;
		templateeditor = &#039;Template-protection-shackle.svg&#039;,&lt;br /&gt;
		extendedconfirmed = &#039;Extended-protection-shackle.svg&#039;,&lt;br /&gt;
		autoconfirmed = &#039;Semi-protection-shackle.svg&#039;&lt;br /&gt;
	},&lt;br /&gt;
	move = {&lt;br /&gt;
		default = &#039;Move-protection-shackle.svg&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	autoreview = {&lt;br /&gt;
		default = &#039;Pending-protection-shackle.svg&#039;&lt;br /&gt;
	},&lt;br /&gt;
	upload = {&lt;br /&gt;
		default = &#039;Upload-protection-shackle.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, autoreview and upload 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;
		extendedconfirmed = &#039;Wikipedia:Protection policy#extended&#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;
		default = &#039;Wikipedia:Protection policy#pending&#039;&lt;br /&gt;
	},&lt;br /&gt;
	upload = {&lt;br /&gt;
		default = &#039;Wikipedia:Protection policy#upload&#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 fully 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;Wikipedia fully-protected main page files&#039;,&lt;br /&gt;
	[&#039;all|all|all|extendedconfirmed|all&#039;]       = &#039;Wikipedia extended-confirmed-protected pages&#039;,&lt;br /&gt;
	[&#039;all|all|ecp|extendedconfirmed|all&#039;]       = &#039;Wikipedia extended-confirmed-protected pages&#039;,&lt;br /&gt;
	[&#039;all|template|all|all|edit&#039;]               = &#039;Wikipedia fully 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;Wikipedia semi-protected files&#039;,&lt;br /&gt;
	[&#039;all|portal|all|autoconfirmed|edit&#039;]       = &#039;Wikipedia semi-protected portals&#039;,&lt;br /&gt;
	[&#039;all|project|all|autoconfirmed|edit&#039;]      = &#039;Wikipedia semi-protected project pages&#039;,&lt;br /&gt;
	[&#039;all|talk|all|autoconfirmed|edit&#039;]         = &#039;Wikipedia 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|template|all|templateeditor|edit&#039;]    = &#039;Wikipedia template-protected templates&#039;,&lt;br /&gt;
	[&#039;all|template|all|templateeditor|move&#039;]    = &#039;Wikipedia template-protected templates&#039;, -- move-protected&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 fully protected categories&#039;,&lt;br /&gt;
	[&#039;all|file|all|sysop|edit&#039;]                 = &#039;Wikipedia fully-protected files&#039;,&lt;br /&gt;
	[&#039;all|project|all|sysop|edit&#039;]              = &#039;Wikipedia fully-protected project pages&#039;,&lt;br /&gt;
	[&#039;all|talk|all|sysop|edit&#039;]                 = &#039;Wikipedia fully-protected talk pages&#039;,&lt;br /&gt;
	[&#039;all|template|all|extendedconfirmed|edit&#039;] = &#039;Wikipedia extended-confirmed-protected templates&#039;,&lt;br /&gt;
	[&#039;all|template|all|sysop|edit&#039;]             = &#039;Wikipedia fully protected templates&#039;,&lt;br /&gt;
	[&#039;all|user|all|sysop|edit&#039;]                 = &#039;Wikipedia fully protected user and user talk pages&#039;,&lt;br /&gt;
	[&#039;all|module|all|all|edit&#039;]                 = &#039;Wikipedia fully-protected modules&#039;,&lt;br /&gt;
	[&#039;all|module|all|templateeditor|edit&#039;]      = &#039;Wikipedia template-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&#039;,&lt;br /&gt;
	[&#039;all|file|all|all|upload&#039;]                 = &#039;Wikipedia upload-protected files&#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;
	upload = false&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;
	extendedconfirmed = {&#039;sysop&#039;},&lt;br /&gt;
	autoconfirmed = {&#039;reviewer&#039;, &#039;filemover&#039;, &#039;templateeditor&#039;, &#039;extendedconfirmed&#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. However, users can override any of the&lt;br /&gt;
-- arguments.&lt;br /&gt;
wrappers = {&lt;br /&gt;
	[&#039;Template:Pp&#039;]                         = {},&lt;br /&gt;
	[&#039;Template:Pp-extended&#039;]                = {&#039;ecp&#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-pc&#039;]                      = {action = &#039;autoreview&#039;, small = true},&lt;br /&gt;
	[&#039;Template:Pp-pc1&#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;]              = {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-upload&#039;]                  = {action = &#039;upload&#039;},&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 &amp;quot;at&amp;quot; H:i e&#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-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;Full-protection-shackle.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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Protection_banner&amp;diff=14466</id>
		<title>Module:Protection banner</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Protection_banner&amp;diff=14466"/>
		<updated>2020-10-21T14:17:17Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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 effectiveProtectionExpiry = require(&#039;Module:Effective protection expiry&#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;
	if cat then&lt;br /&gt;
		return string.format(&lt;br /&gt;
			&#039;[[%s:%s|%s]]&#039;,&lt;br /&gt;
			mw.site.namespaces[14].name,&lt;br /&gt;
			cat,&lt;br /&gt;
			sort&lt;br /&gt;
		)&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;
	if not lang then&lt;br /&gt;
		lang = mw.language.getContentLanguage()&lt;br /&gt;
	end&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: %s&#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;
-- Given a directed graph formatted as node -&amp;gt; table of direct successors,&lt;br /&gt;
-- get a table of all nodes reachable from a given node (though always&lt;br /&gt;
-- including the given node).&lt;br /&gt;
local function getReachableNodes(graph, 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) -- This always gets the &amp;quot;first&amp;quot; key&lt;br /&gt;
		if k == nil then&lt;br /&gt;
			return retval&lt;br /&gt;
		end&lt;br /&gt;
		toWalk[k] = nil&lt;br /&gt;
		retval[k] = true&lt;br /&gt;
		for _,v in ipairs(graph[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;
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;
	upload = 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: %s&#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;
	local effectiveExpiry = effectiveProtectionExpiry(obj.action, obj.title)&lt;br /&gt;
	if effectiveExpiry == &#039;infinity&#039; then&lt;br /&gt;
		obj.expiry = &#039;indef&#039;&lt;br /&gt;
	elseif effectiveExpiry ~= &#039;unknown&#039; then&lt;br /&gt;
		obj.expiry = validateDate(effectiveExpiry, &#039;expiry date&#039;)&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:isUserScript()&lt;br /&gt;
	-- Whether the page is a user JavaScript or CSS page.&lt;br /&gt;
	local title = self.title&lt;br /&gt;
	return title.namespace == 2 and (&lt;br /&gt;
		title.contentModel == &#039;javascript&#039; or title.contentModel == &#039;css&#039;&lt;br /&gt;
	)&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:shouldShowLock()&lt;br /&gt;
	-- Whether we should output a banner/padlock&lt;br /&gt;
	return self:isProtected() and not self:isUserScript()&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Whether this page needs a protection category.&lt;br /&gt;
Protection.shouldHaveProtectionCategory = Protection.shouldShowLock&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;
	if not self:shouldHaveProtectionCategory() then&lt;br /&gt;
		return &#039;&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local cfg = self._cfg&lt;br /&gt;
	local title = self.title&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 = 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;
&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;
	table.insert(order, table.remove(order, self.reason and cfg.reasonsWithNamespacePriority[self.reason] and 2 or 3))&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:isIncorrect()&lt;br /&gt;
	local expiry = self.expiry&lt;br /&gt;
	return not self:shouldHaveProtectionCategory()&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: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;extendedconfirmed&#039; then&lt;br /&gt;
			requestType = &#039;extended&#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: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.imageWidth = 40&lt;br /&gt;
	obj.imageCaption = 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.imageWidth = 20&lt;br /&gt;
	obj.imageCaption = 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;
	return frame:extensionTag{name = &#039;nowiki&#039;} .. 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;
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&lt;br /&gt;
	-- protection from some other action, then don&#039;t bother displaying anything&lt;br /&gt;
	-- for the other action (except categories).&lt;br /&gt;
	if protectionObj.action == &#039;edit&#039; or&lt;br /&gt;
		args.demolevel or&lt;br /&gt;
		not getReachableNodes(&lt;br /&gt;
			cfg.hierarchy,&lt;br /&gt;
			protectionObj.level&lt;br /&gt;
		)[effectiveProtectionLevel(&#039;edit&#039;, protectionObj.title)]&lt;br /&gt;
	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:shouldShowLock() 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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:No_globals&amp;diff=14464</id>
		<title>Module:No globals</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:No_globals&amp;diff=14464"/>
		<updated>2020-10-21T14:17:17Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Message_box/configuration&amp;diff=14462</id>
		<title>Module:Message box/configuration</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Message_box/configuration&amp;diff=14462"/>
		<updated>2020-10-21T14:17:16Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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;Semi-protection-shackle-keyhole.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;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;
		removalNotice               = &#039;[[Help:Maintenance template removal|Learn how and when to remove this template message]]&#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;Semi-protection-shackle-keyhole.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;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;
		classes              = {&#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;Semi-protection-shackle-keyhole.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;
		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;Semi-protection-shackle-keyhole.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;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;Semi-protection-shackle-keyhole.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;tmbox&#039;},&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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Message_box&amp;diff=14460</id>
		<title>Module:Message box</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Message_box&amp;diff=14460"/>
		<updated>2020-10-21T14:17:16Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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 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;
-- Define constants&lt;br /&gt;
local CONFIG_MODULE = &#039;Module:Message box/configuration&#039;&lt;br /&gt;
local DEMOSPACES = {talk = &#039;tmbox&#039;, image = &#039;imbox&#039;, file = &#039;imbox&#039;, category = &#039;cmbox&#039;, article = &#039;ambox&#039;, main = &#039;ambox&#039;}&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 args.demospace and args.demospace ~= &#039;&#039; then&lt;br /&gt;
			-- implement demospace parameter of mbox&lt;br /&gt;
			local demospace = string.lower(args.demospace)&lt;br /&gt;
			if DEMOSPACES[demospace] then&lt;br /&gt;
				-- use template from DEMOSPACES&lt;br /&gt;
				obj.cfg = cfg[DEMOSPACES[demospace]]&lt;br /&gt;
			elseif string.find( demospace, &#039;talk&#039; ) then&lt;br /&gt;
				-- demo as a talk page&lt;br /&gt;
				obj.cfg = cfg.tmbox&lt;br /&gt;
			else&lt;br /&gt;
				-- default to ombox&lt;br /&gt;
				obj.cfg = cfg.ombox&lt;br /&gt;
			end&lt;br /&gt;
		elseif 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;
	-- For lazy loading of [[Module:Category handler]].&lt;br /&gt;
	obj.hasCategories = false&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.hasCategories = true&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;
	self.id = args.id&lt;br /&gt;
	self.name = args.name&lt;br /&gt;
	if self.name then&lt;br /&gt;
		self:addClass(&#039;box-&#039; .. string.gsub(self.name,&#039; &#039;,&#039;_&#039;))&lt;br /&gt;
	end&lt;br /&gt;
	if yesno(args.plainlinks) ~= false then&lt;br /&gt;
		self:addClass(&#039;plainlinks&#039;)&lt;br /&gt;
	end&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;
		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&lt;br /&gt;
                if self.isSmall then&lt;br /&gt;
                    local talkLink = talkArgIsTalkPage and talk or (talkTitle.prefixedText .. &#039;#&#039; .. talk)&lt;br /&gt;
                    talkText = string.format(&#039;([[%s|talk]])&#039;, talkLink)&lt;br /&gt;
                else&lt;br /&gt;
                    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;
                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 class=&#039;date-container&#039;&amp;gt;&#039;&#039;(&amp;lt;span class=&#039;date&#039;&amp;gt;%s&amp;lt;/span&amp;gt;)&#039;&#039;&amp;lt;/small&amp;gt;&amp;quot;, date)&lt;br /&gt;
		end&lt;br /&gt;
		self.info = args.info&lt;br /&gt;
		if yesno(args.removalnotice) then&lt;br /&gt;
			self.removalNotice = cfg.removalNotice&lt;br /&gt;
		end&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;
	if not self.hasCategories then&lt;br /&gt;
		-- No categories added, no need to pass them to Category handler so,&lt;br /&gt;
		-- if it was invoked, it would return the empty string.&lt;br /&gt;
		-- So we shortcut and return the empty string.&lt;br /&gt;
		return &amp;quot;&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	-- Convert category tables to strings and pass them through&lt;br /&gt;
	-- [[Module:Category handler]].&lt;br /&gt;
	return require(&#039;Module:Category handler&#039;)._main{&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 textCellDiv = textCell:tag(&#039;div&#039;)&lt;br /&gt;
		textCellDiv&lt;br /&gt;
			:addClass(&#039;mbox-text-span&#039;)&lt;br /&gt;
			:wikitext(self.issue or nil)&lt;br /&gt;
		if (self.talk or self.fix) then&lt;br /&gt;
			textCellDiv: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;
		textCellDiv:wikitext(self.date and (&#039; &#039; .. self.date) or nil)&lt;br /&gt;
		if self.info and not self.isSmall then&lt;br /&gt;
			textCellDiv&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;
		if self.removalNotice then&lt;br /&gt;
			textCellDiv:tag(&#039;small&#039;)&lt;br /&gt;
				:addClass(&#039;hide-when-compact&#039;)&lt;br /&gt;
				:tag(&#039;i&#039;)&lt;br /&gt;
					:wikitext(string.format(&amp;quot; (%s)&amp;quot;, self.removalNotice))&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(CONFIG_MODULE))&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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:High-use&amp;diff=14458</id>
		<title>Module:High-use</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:High-use&amp;diff=14458"/>
		<updated>2020-10-21T14:17:15Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local p = {}&lt;br /&gt;
&lt;br /&gt;
local _fetch = require(&#039;Module:Transclusion_count&#039;).fetch&lt;br /&gt;
&lt;br /&gt;
function p.num(frame, count)&lt;br /&gt;
	if count == nil then count = _fetch(frame) end&lt;br /&gt;
	&lt;br /&gt;
	-- Build output string&lt;br /&gt;
	local return_value = &amp;quot;&amp;quot;&lt;br /&gt;
	if count == nil then&lt;br /&gt;
		if frame.args[1] == &amp;quot;risk&amp;quot; then&lt;br /&gt;
			return_value = &amp;quot;a very large number of&amp;quot;&lt;br /&gt;
		else&lt;br /&gt;
			return_value = &amp;quot;many&amp;quot;&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		-- Use 2 significant figures for smaller numbers and 3 for larger ones&lt;br /&gt;
		local sigfig = 2&lt;br /&gt;
		if count &amp;gt;= 100000 then&lt;br /&gt;
			sigfig = 3&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		-- Prepare to round to appropriate number of sigfigs&lt;br /&gt;
		local f = math.floor(math.log10(count)) - sigfig + 1&lt;br /&gt;
		&lt;br /&gt;
		-- Round and insert &amp;quot;approximately&amp;quot; or &amp;quot;+&amp;quot; when appropriate&lt;br /&gt;
		if (frame.args[2] == &amp;quot;yes&amp;quot;) or (mw.ustring.sub(frame.args[1],-1) == &amp;quot;+&amp;quot;) then&lt;br /&gt;
			-- Round down&lt;br /&gt;
			return_value = string.format(&amp;quot;%s+&amp;quot;, mw.getContentLanguage():formatNum(math.floor( (count / 10^(f)) ) * (10^(f))) )&lt;br /&gt;
		else&lt;br /&gt;
			-- Round to nearest&lt;br /&gt;
			return_value = string.format(&amp;quot;approximately&amp;amp;#x20;%s&amp;quot;, mw.getContentLanguage():formatNum(math.floor( (count / 10^(f)) + 0.5) * (10^(f))) )&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		-- Insert percent of pages&lt;br /&gt;
		if frame.args[&amp;quot;all-pages&amp;quot;] and frame.args[&amp;quot;all-pages&amp;quot;] ~= &amp;quot;&amp;quot; then&lt;br /&gt;
			local percent = math.floor( ( (count/frame:callParserFunction(&#039;NUMBEROFPAGES&#039;, &#039;R&#039;) ) * 100) + 0.5)&lt;br /&gt;
			return_value = string.format(&amp;quot;%s&amp;amp;#x20;pages, or roughly %s%% of all&amp;quot;, return_value, percent)&lt;br /&gt;
		end	&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return return_value&lt;br /&gt;
end&lt;br /&gt;
-- Actions if there is a large (greater than or equal to 100,000) transclusion count&lt;br /&gt;
function p.risk(frame)&lt;br /&gt;
	local return_value = &amp;quot;&amp;quot;&lt;br /&gt;
	if frame.args[1] == &amp;quot;risk&amp;quot; then&lt;br /&gt;
		return_value = &amp;quot;risk&amp;quot;&lt;br /&gt;
	else&lt;br /&gt;
		local count = _fetch(frame)&lt;br /&gt;
		if count and count &amp;gt;= 100000 then return_value = &amp;quot;risk&amp;quot; end&lt;br /&gt;
	end&lt;br /&gt;
	return return_value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.text(frame, count)&lt;br /&gt;
	local bot_text = &amp;quot;\n\n----\nTransclusion count updated automatically ([[Template:High-use/doc#Technical details|see documentation]]).&amp;quot;&lt;br /&gt;
	if frame.args[&amp;quot;nobot&amp;quot;] == true then&lt;br /&gt;
		bot_text = &amp;quot;&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if count == nil then count = _fetch(frame) end&lt;br /&gt;
	local return_value = {}&lt;br /&gt;
	&lt;br /&gt;
	local title = mw.title.getCurrentTitle()&lt;br /&gt;
	if title.subpageText == &amp;quot;doc&amp;quot; or title.subpageText == &amp;quot;sandbox&amp;quot; then&lt;br /&gt;
		title = title.basePageTitle&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local templatecount = string.format(&amp;quot;https://templatecount.toolforge.org/index.php?lang=en&amp;amp;namespace=%s&amp;amp;name=%s&amp;quot;,mw.title.getCurrentTitle().namespace,mw.uri.encode(title.text))&lt;br /&gt;
	&lt;br /&gt;
	local used_on_text = string.format(&amp;quot;&#039;&#039;&#039;This %s is used on [%s %s pages]&#039;&#039;&#039;&amp;quot;,&lt;br /&gt;
			(mw.title.getCurrentTitle().namespace == 828 and &amp;quot;Lua module&amp;quot; or &amp;quot;template&amp;quot;),&lt;br /&gt;
			templatecount,&lt;br /&gt;
			p.num(frame, count)&lt;br /&gt;
	)&lt;br /&gt;
	&lt;br /&gt;
	local sandbox_text =  string.format(&amp;quot;%s&#039;s [[%s/sandbox|/sandbox]] or [[%s/testcases|/testcases]] subpages%s &amp;quot;,&lt;br /&gt;
			(mw.title.getCurrentTitle().namespace == 828 and &amp;quot;module&amp;quot; or &amp;quot;template&amp;quot;),&lt;br /&gt;
			title.fullText, title.fullText,&lt;br /&gt;
			(mw.title.getCurrentTitle().namespace == 828 and &amp;quot;.&amp;quot; or &amp;quot;, or in your own [[Wikipedia:Subpages#How to create user subpages|user subpage]].&amp;quot;)&lt;br /&gt;
	)&lt;br /&gt;
	&lt;br /&gt;
	if (frame.args[1] == &amp;quot;risk&amp;quot; or (count and count &amp;gt;= 100000) ) then&lt;br /&gt;
		local info = &amp;quot;&amp;quot; &lt;br /&gt;
		if frame.args[&amp;quot;info&amp;quot;] and frame.args[&amp;quot;info&amp;quot;] ~= &amp;quot;&amp;quot; then&lt;br /&gt;
			info = &amp;quot;&amp;lt;br /&amp;gt;&amp;quot; .. frame.args[&amp;quot;info&amp;quot;]&lt;br /&gt;
		end&lt;br /&gt;
		sandbox_text = string.format(&amp;quot;.%s&amp;lt;br /&amp;gt; To avoid major disruption and server load, any changes should be tested in the %sThe tested changes can be added to this page in a single edit.&amp;amp;#x20;&amp;quot;,&lt;br /&gt;
				info, sandbox_text&lt;br /&gt;
		)&lt;br /&gt;
	else&lt;br /&gt;
		sandbox_text = string.format(&amp;quot; and changes may be widely noticed. Test changes in the %s&amp;quot;,&lt;br /&gt;
				sandbox_text&lt;br /&gt;
		)&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local discussion_text = &amp;quot;Consider discussing changes &amp;quot;&lt;br /&gt;
	if frame.args[&amp;quot;2&amp;quot;] and frame.args[&amp;quot;2&amp;quot;] ~= &amp;quot;&amp;quot; and frame.args[&amp;quot;2&amp;quot;] ~= &amp;quot;yes&amp;quot; then&lt;br /&gt;
		discussion_text = string.format(&amp;quot;%sat [[%s]]&amp;quot;, discussion_text, frame.args[&amp;quot;2&amp;quot;])&lt;br /&gt;
	else&lt;br /&gt;
		discussion_text = string.format(&amp;quot;%son the [[%s|talk page]]&amp;quot;, discussion_text, title.talkPageTitle.fullText )&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return table.concat({used_on_text, sandbox_text, discussion_text, &amp;quot; before implementing them.&amp;quot;, bot_text})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local count = _fetch(frame)&lt;br /&gt;
	local return_value = &amp;quot;&amp;quot;&lt;br /&gt;
	local image = &amp;quot;[[File:Ambox warning yellow.svg|40px|alt=Warning|link=]]&amp;quot;&lt;br /&gt;
	local type_param = &amp;quot;style&amp;quot;&lt;br /&gt;
	if (frame.args[1] == &amp;quot;risk&amp;quot; or (count and count &amp;gt;= 100000) ) then&lt;br /&gt;
		image = &amp;quot;[[File:Ambox warning orange.svg|40px|alt=Warning|link=]]&amp;quot;&lt;br /&gt;
		type_param = &amp;quot;content&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if frame.args[&amp;quot;form&amp;quot;] == &amp;quot;editnotice&amp;quot; then&lt;br /&gt;
		return_value = frame:expandTemplate{&lt;br /&gt;
				title = &#039;editnotice&#039;,&lt;br /&gt;
				args = {&lt;br /&gt;
						[&amp;quot;image&amp;quot;] = image,&lt;br /&gt;
						[&amp;quot;text&amp;quot;] = p.text(frame, count),&lt;br /&gt;
						[&amp;quot;expiry&amp;quot;] = (frame.args[&amp;quot;expiry&amp;quot;] or &amp;quot;&amp;quot;)&lt;br /&gt;
				}&lt;br /&gt;
		}&lt;br /&gt;
	else&lt;br /&gt;
		return_value = frame:expandTemplate{&lt;br /&gt;
				title = &#039;ombox&#039;,&lt;br /&gt;
				args = {&lt;br /&gt;
						[&amp;quot;type&amp;quot;] = type_param,&lt;br /&gt;
						[&amp;quot;image&amp;quot;] = image,&lt;br /&gt;
						[&amp;quot;text&amp;quot;] = p.text(frame, count),&lt;br /&gt;
						[&amp;quot;expiry&amp;quot;] = (frame.args[&amp;quot;expiry&amp;quot;] or &amp;quot;&amp;quot;)&lt;br /&gt;
				}&lt;br /&gt;
		}&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return return_value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:File_link&amp;diff=14456</id>
		<title>Module:File link</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:File_link&amp;diff=14456"/>
		<updated>2020-10-21T14:17:15Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Effective_protection_level&amp;diff=14454</id>
		<title>Module:Effective protection level</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Effective_protection_level&amp;diff=14454"/>
		<updated>2020-10-21T14:17:15Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&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.ext.FlaggedRevs.getStabilitySettings(title)&lt;br /&gt;
		level = level and level.autoreview&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; and action ~= &#039;undelete&#039; then&lt;br /&gt;
		error( &#039;First parameter must be one of edit, move, create, upload, undelete, autoreview&#039;, 2 )&lt;br /&gt;
	end&lt;br /&gt;
	if title.namespace == 8 then -- MediaWiki namespace&lt;br /&gt;
		if title.text:sub(-3) == &#039;.js&#039; or title.text:sub(-4) == &#039;.css&#039; or title.contentModel == &#039;javascript&#039; or title.contentModel == &#039;css&#039; then -- site JS or CSS page&lt;br /&gt;
			return &#039;interfaceadmin&#039;&lt;br /&gt;
		else -- any non-JS/CSS MediaWiki page&lt;br /&gt;
			return &#039;sysop&#039;&lt;br /&gt;
		end&lt;br /&gt;
	elseif title.namespace == 2 and title.isSubpage then&lt;br /&gt;
		if title.contentModel == &#039;javascript&#039; or title.contentModel == &#039;css&#039; then -- user JS or CSS page&lt;br /&gt;
			return &#039;interfaceadmin&#039;&lt;br /&gt;
		elseif title.contentModel == &#039;json&#039; then -- user JSON page&lt;br /&gt;
			return &#039;sysop&#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if action == &#039;undelete&#039; then&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;
		elseif level == &#039;extendedconfirmed&#039; then&lt;br /&gt;
			return &#039;extendedconfirmed&#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;
		if not blacklistentry.params.autoconfirmed then&lt;br /&gt;
			return &#039;templateeditor&#039;&lt;br /&gt;
		elseif level == &#039;extendedconfirmed&#039; then&lt;br /&gt;
			return &#039;extendedconfirmed&#039;&lt;br /&gt;
		else&lt;br /&gt;
			return &#039;autoconfirmed&#039;&lt;br /&gt;
		end&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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Effective_protection_expiry&amp;diff=14452</id>
		<title>Module:Effective protection expiry</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Effective_protection_expiry&amp;diff=14452"/>
		<updated>2020-10-21T14:17:14Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local p = {}&lt;br /&gt;
&lt;br /&gt;
-- Returns the expiry of a restriction of an action on a given title, or unknown if it cannot be known.&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 stabilitySettings = mw.ext.FlaggedRevs.getStabilitySettings(title)&lt;br /&gt;
		return stabilitySettings and stabilitySettings.expiry or &#039;unknown&#039;&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;
	local rawExpiry = mw.getCurrentFrame():callParserFunction(&#039;PROTECTIONEXPIRY&#039;, action, pagename)&lt;br /&gt;
	if rawExpiry == &#039;infinity&#039; then&lt;br /&gt;
		return &#039;infinity&#039;&lt;br /&gt;
	elseif rawExpiry == &#039;&#039; then&lt;br /&gt;
		return &#039;unknown&#039;&lt;br /&gt;
	else&lt;br /&gt;
		local year, month, day, hour, minute, second = rawExpiry:match(&lt;br /&gt;
			&#039;^(%d%d%d%d)(%d%d)(%d%d)(%d%d)(%d%d)(%d%d)$&#039;&lt;br /&gt;
		)&lt;br /&gt;
		if year then&lt;br /&gt;
			return string.format(&lt;br /&gt;
				&#039;%s-%s-%sT%s:%s:%s&#039;,&lt;br /&gt;
				year, month, day, hour, minute, second&lt;br /&gt;
			)&lt;br /&gt;
		else&lt;br /&gt;
			error(&#039;internal error in Module:Effective protection expiry; malformed expiry timestamp&#039;)&lt;br /&gt;
		end&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>ArxioWikiSysop</name></author>
	</entry>
	<entry>
		<id>https://wikitest.baw.de/en/index.php?title=Module:Documentation/config&amp;diff=14450</id>
		<title>Module:Documentation/config</title>
		<link rel="alternate" type="text/html" href="https://wikitest.baw.de/en/index.php?title=Module:Documentation/config&amp;diff=14450"/>
		<updated>2020-10-21T14:17:14Z</updated>

		<summary type="html">&lt;p&gt;ArxioWikiSysop: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;----------------------------------------------------------------------------------------------------&lt;br /&gt;
--&lt;br /&gt;
--                               Configuration for Module:Documentation&lt;br /&gt;
--&lt;br /&gt;
-- Here you can set the values of the parameters and messages used in Module:Documentation to&lt;br /&gt;
-- localise it to your wiki and your language. Unless specified otherwise, values given here&lt;br /&gt;
-- should be string values.&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
local cfg = {} -- Do not edit this line.&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Protection template configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;protection-reason-edit&#039;]&lt;br /&gt;
-- The protection reason for edit-protected templates to pass to&lt;br /&gt;
-- [[Module:Protection banner]].&lt;br /&gt;
cfg[&#039;protection-reason-edit&#039;] = &#039;template&#039;&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Sandbox notice configuration&lt;br /&gt;
--&lt;br /&gt;
-- On sandbox pages the module can display a template notifying users that the current page is a&lt;br /&gt;
-- sandbox, and the location of test cases pages, etc. The module decides whether the page is a&lt;br /&gt;
-- sandbox or not based on the value of cfg[&#039;sandbox-subpage&#039;]. The following settings configure the&lt;br /&gt;
-- messages that the notices contains.&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;sandbox-notice-image&#039;]&lt;br /&gt;
-- The image displayed in the sandbox notice.&lt;br /&gt;
cfg[&#039;sandbox-notice-image&#039;] = &#039;[[Image:Sandbox.svg|50px|alt=|link=]]&#039;&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- cfg[&#039;sandbox-notice-pagetype-template&#039;]&lt;br /&gt;
-- cfg[&#039;sandbox-notice-pagetype-module&#039;]&lt;br /&gt;
-- cfg[&#039;sandbox-notice-pagetype-other&#039;]&lt;br /&gt;
-- The page type of the sandbox page. The message that is displayed depends on the current subject&lt;br /&gt;
-- namespace. This message is used in either cfg[&#039;sandbox-notice-blurb&#039;] or&lt;br /&gt;
-- cfg[&#039;sandbox-notice-diff-blurb&#039;].&lt;br /&gt;
--]]&lt;br /&gt;
cfg[&#039;sandbox-notice-pagetype-template&#039;] = &#039;[[Wikipedia:Template test cases|template sandbox]] page&#039;&lt;br /&gt;
cfg[&#039;sandbox-notice-pagetype-module&#039;] = &#039;[[Wikipedia:Template test cases|module sandbox]] page&#039;&lt;br /&gt;
cfg[&#039;sandbox-notice-pagetype-other&#039;] = &#039;sandbox page&#039;&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- cfg[&#039;sandbox-notice-blurb&#039;]&lt;br /&gt;
-- cfg[&#039;sandbox-notice-diff-blurb&#039;]&lt;br /&gt;
-- cfg[&#039;sandbox-notice-diff-display&#039;]&lt;br /&gt;
-- Either cfg[&#039;sandbox-notice-blurb&#039;] or cfg[&#039;sandbox-notice-diff-blurb&#039;] is the opening sentence&lt;br /&gt;
-- of the sandbox notice. The latter has a diff link, but the former does not. $1 is the page&lt;br /&gt;
-- type, which is either cfg[&#039;sandbox-notice-pagetype-template&#039;],&lt;br /&gt;
-- cfg[&#039;sandbox-notice-pagetype-module&#039;] or cfg[&#039;sandbox-notice-pagetype-other&#039;] depending what&lt;br /&gt;
-- namespace we are in. $2 is a link to the main template page, and $3 is a diff link between&lt;br /&gt;
-- the sandbox and the main template. The display value of the diff link is set by &lt;br /&gt;
-- cfg[&#039;sandbox-notice-compare-link-display&#039;].&lt;br /&gt;
--]]&lt;br /&gt;
cfg[&#039;sandbox-notice-blurb&#039;] = &#039;This is the $1 for $2.&#039;&lt;br /&gt;
cfg[&#039;sandbox-notice-diff-blurb&#039;] = &#039;This is the $1 for $2 ($3).&#039;&lt;br /&gt;
cfg[&#039;sandbox-notice-compare-link-display&#039;] = &#039;diff&#039;&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- cfg[&#039;sandbox-notice-testcases-blurb&#039;]&lt;br /&gt;
-- cfg[&#039;sandbox-notice-testcases-link-display&#039;]&lt;br /&gt;
-- cfg[&#039;sandbox-notice-testcases-run-blurb&#039;]&lt;br /&gt;
-- cfg[&#039;sandbox-notice-testcases-run-link-display&#039;]&lt;br /&gt;
-- cfg[&#039;sandbox-notice-testcases-blurb&#039;] is a sentence notifying the user that there is a test cases page&lt;br /&gt;
-- corresponding to this sandbox that they can edit. $1 is a link to the test cases page.&lt;br /&gt;
-- cfg[&#039;sandbox-notice-testcases-link-display&#039;] is the display value for that link.&lt;br /&gt;
-- cfg[&#039;sandbox-notice-testcases-run-blurb&#039;] is a sentence notifying the user that there is a test cases page&lt;br /&gt;
-- corresponding to this sandbox that they can edit, along with a link to run it. $1 is a link to the test&lt;br /&gt;
-- cases page, and $2 is a link to the page to run it.&lt;br /&gt;
-- cfg[&#039;sandbox-notice-testcases-run-link-display&#039;] is the display value for the link to run the test&lt;br /&gt;
-- cases.&lt;br /&gt;
--]]&lt;br /&gt;
cfg[&#039;sandbox-notice-testcases-blurb&#039;] = &#039;See also the companion subpage for $1.&#039;&lt;br /&gt;
cfg[&#039;sandbox-notice-testcases-link-display&#039;] = &#039;test cases&#039;&lt;br /&gt;
cfg[&#039;sandbox-notice-testcases-run-blurb&#039;] = &#039;See also the companion subpage for $1 ($2).&#039;&lt;br /&gt;
cfg[&#039;sandbox-notice-testcases-run-link-display&#039;] = &#039;run&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;sandbox-category&#039;]&lt;br /&gt;
-- A category to add to all template sandboxes.&lt;br /&gt;
cfg[&#039;sandbox-category&#039;] = &#039;Template sandboxes&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Start box configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;documentation-icon-wikitext&#039;]&lt;br /&gt;
-- The wikitext for the icon shown at the top of the template.&lt;br /&gt;
cfg[&#039;documentation-icon-wikitext&#039;] = &#039;[[File:Test Template Info-Icon - Version (2).svg|50px|link=|alt=]]&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;template-namespace-heading&#039;]&lt;br /&gt;
-- The heading shown in the template namespace.&lt;br /&gt;
cfg[&#039;template-namespace-heading&#039;] = &#039;Template documentation&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;module-namespace-heading&#039;]&lt;br /&gt;
-- The heading shown in the module namespace.&lt;br /&gt;
cfg[&#039;module-namespace-heading&#039;] = &#039;Module documentation&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;file-namespace-heading&#039;]&lt;br /&gt;
-- The heading shown in the file namespace.&lt;br /&gt;
cfg[&#039;file-namespace-heading&#039;] = &#039;Summary&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;other-namespaces-heading&#039;]&lt;br /&gt;
-- The heading shown in other namespaces.&lt;br /&gt;
cfg[&#039;other-namespaces-heading&#039;] = &#039;Documentation&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;view-link-display&#039;]&lt;br /&gt;
-- The text to display for &amp;quot;view&amp;quot; links.&lt;br /&gt;
cfg[&#039;view-link-display&#039;] = &#039;view&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;edit-link-display&#039;]&lt;br /&gt;
-- The text to display for &amp;quot;edit&amp;quot; links.&lt;br /&gt;
cfg[&#039;edit-link-display&#039;] = &#039;edit&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;history-link-display&#039;]&lt;br /&gt;
-- The text to display for &amp;quot;history&amp;quot; links.&lt;br /&gt;
cfg[&#039;history-link-display&#039;] = &#039;history&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;purge-link-display&#039;]&lt;br /&gt;
-- The text to display for &amp;quot;purge&amp;quot; links.&lt;br /&gt;
cfg[&#039;purge-link-display&#039;] = &#039;purge&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;create-link-display&#039;]&lt;br /&gt;
-- The text to display for &amp;quot;create&amp;quot; links.&lt;br /&gt;
cfg[&#039;create-link-display&#039;] = &#039;create&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Link box (end box) configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;transcluded-from-blurb&#039;]&lt;br /&gt;
-- Notice displayed when the docs are transcluded from another page. $1 is a wikilink to that page.&lt;br /&gt;
cfg[&#039;transcluded-from-blurb&#039;] = &#039;The above [[Wikipedia:Template documentation|documentation]] is [[Wikipedia:Transclusion|transcluded]] from $1.&#039;&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- cfg[&#039;create-module-doc-blurb&#039;]&lt;br /&gt;
-- Notice displayed in the module namespace when the documentation subpage does not exist.&lt;br /&gt;
-- $1 is a link to create the documentation page with the preload cfg[&#039;module-preload&#039;] and the&lt;br /&gt;
-- display cfg[&#039;create-link-display&#039;].&lt;br /&gt;
--]]&lt;br /&gt;
cfg[&#039;create-module-doc-blurb&#039;] = &#039;You might want to $1 a documentation page for this [[Wikipedia:Lua|Scribunto module]].&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Experiment blurb configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- cfg[&#039;experiment-blurb-template&#039;]&lt;br /&gt;
-- cfg[&#039;experiment-blurb-module&#039;]&lt;br /&gt;
-- The experiment blurb is the text inviting editors to experiment in sandbox and test cases pages.&lt;br /&gt;
-- It is only shown in the template and module namespaces. With the default English settings, it&lt;br /&gt;
-- might look like this:&lt;br /&gt;
--&lt;br /&gt;
-- Editors can experiment in this template&#039;s sandbox (edit | diff) and testcases (edit) pages.&lt;br /&gt;
--&lt;br /&gt;
-- In this example, &amp;quot;sandbox&amp;quot;, &amp;quot;edit&amp;quot;, &amp;quot;diff&amp;quot;, &amp;quot;testcases&amp;quot;, and &amp;quot;edit&amp;quot; would all be links.&lt;br /&gt;
--&lt;br /&gt;
-- There are two versions, cfg[&#039;experiment-blurb-template&#039;] and cfg[&#039;experiment-blurb-module&#039;], depending&lt;br /&gt;
-- on what namespace we are in.&lt;br /&gt;
-- &lt;br /&gt;
-- Parameters:&lt;br /&gt;
--&lt;br /&gt;
-- $1 is a link to the sandbox page. If the sandbox exists, it is in the following format:&lt;br /&gt;
--&lt;br /&gt;
--     cfg[&#039;sandbox-link-display&#039;] (cfg[&#039;sandbox-edit-link-display&#039;] | cfg[&#039;compare-link-display&#039;])&lt;br /&gt;
-- &lt;br /&gt;
-- If the sandbox doesn&#039;t exist, it is in the format:&lt;br /&gt;
--&lt;br /&gt;
--     cfg[&#039;sandbox-link-display&#039;] (cfg[&#039;sandbox-create-link-display&#039;] | cfg[&#039;mirror-link-display&#039;])&lt;br /&gt;
-- &lt;br /&gt;
-- The link for cfg[&#039;sandbox-create-link-display&#039;] link preloads the page with cfg[&#039;template-sandbox-preload&#039;]&lt;br /&gt;
-- or cfg[&#039;module-sandbox-preload&#039;], depending on the current namespace. The link for cfg[&#039;mirror-link-display&#039;]&lt;br /&gt;
-- loads a default edit summary of cfg[&#039;mirror-edit-summary&#039;].&lt;br /&gt;
--&lt;br /&gt;
-- $2 is a link to the test cases page. If the test cases page exists, it is in the following format:&lt;br /&gt;
--&lt;br /&gt;
--     cfg[&#039;testcases-link-display&#039;] (cfg[&#039;testcases-edit-link-display&#039;] | cfg[&#039;testcases-run-link-display&#039;])&lt;br /&gt;
--&lt;br /&gt;
-- If the test cases page doesn&#039;t exist, it is in the format:&lt;br /&gt;
-- &lt;br /&gt;
--     cfg[&#039;testcases-link-display&#039;] (cfg[&#039;testcases-create-link-display&#039;])&lt;br /&gt;
--&lt;br /&gt;
-- If the test cases page doesn&#039;t exist, the link for cfg[&#039;testcases-create-link-display&#039;] preloads the&lt;br /&gt;
-- page with cfg[&#039;template-testcases-preload&#039;] or cfg[&#039;module-testcases-preload&#039;], depending on the current&lt;br /&gt;
-- namespace.&lt;br /&gt;
--]]&lt;br /&gt;
cfg[&#039;experiment-blurb-template&#039;] = &amp;quot;Editors can experiment in this template&#039;s $1 and $2 pages.&amp;quot;&lt;br /&gt;
cfg[&#039;experiment-blurb-module&#039;] = &amp;quot;Editors can experiment in this module&#039;s $1 and $2 pages.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Sandbox link configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;sandbox-subpage&#039;]&lt;br /&gt;
-- The name of the template subpage typically used for sandboxes.&lt;br /&gt;
cfg[&#039;sandbox-subpage&#039;] = &#039;sandbox&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;template-sandbox-preload&#039;]&lt;br /&gt;
-- Preload file for template sandbox pages.&lt;br /&gt;
cfg[&#039;template-sandbox-preload&#039;] = &#039;Template:Documentation/preload-sandbox&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;module-sandbox-preload&#039;]&lt;br /&gt;
-- Preload file for Lua module sandbox pages.&lt;br /&gt;
cfg[&#039;module-sandbox-preload&#039;] = &#039;Template:Documentation/preload-module-sandbox&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;sandbox-link-display&#039;]&lt;br /&gt;
-- The text to display for &amp;quot;sandbox&amp;quot; links.&lt;br /&gt;
cfg[&#039;sandbox-link-display&#039;] = &#039;sandbox&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;sandbox-edit-link-display&#039;]&lt;br /&gt;
-- The text to display for sandbox &amp;quot;edit&amp;quot; links.&lt;br /&gt;
cfg[&#039;sandbox-edit-link-display&#039;] = &#039;edit&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;sandbox-create-link-display&#039;]&lt;br /&gt;
-- The text to display for sandbox &amp;quot;create&amp;quot; links.&lt;br /&gt;
cfg[&#039;sandbox-create-link-display&#039;] = &#039;create&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;compare-link-display&#039;]&lt;br /&gt;
-- The text to display for &amp;quot;compare&amp;quot; links.&lt;br /&gt;
cfg[&#039;compare-link-display&#039;] = &#039;diff&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;mirror-edit-summary&#039;]&lt;br /&gt;
-- The default edit summary to use when a user clicks the &amp;quot;mirror&amp;quot; link. $1 is a wikilink to the&lt;br /&gt;
-- template page.&lt;br /&gt;
cfg[&#039;mirror-edit-summary&#039;] = &#039;Create sandbox version of $1&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;mirror-link-display&#039;]&lt;br /&gt;
-- The text to display for &amp;quot;mirror&amp;quot; links.&lt;br /&gt;
cfg[&#039;mirror-link-display&#039;] = &#039;mirror&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;mirror-link-preload&#039;]&lt;br /&gt;
-- The page to preload when a user clicks the &amp;quot;mirror&amp;quot; link.&lt;br /&gt;
cfg[&#039;mirror-link-preload&#039;] = &#039;Template:Documentation/mirror&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Test cases link configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;testcases-subpage&#039;]&lt;br /&gt;
-- The name of the template subpage typically used for test cases.&lt;br /&gt;
cfg[&#039;testcases-subpage&#039;] = &#039;testcases&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;template-testcases-preload&#039;]&lt;br /&gt;
-- Preload file for template test cases pages.&lt;br /&gt;
cfg[&#039;template-testcases-preload&#039;] = &#039;Template:Documentation/preload-testcases&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;module-testcases-preload&#039;]&lt;br /&gt;
-- Preload file for Lua module test cases pages.&lt;br /&gt;
cfg[&#039;module-testcases-preload&#039;] = &#039;Template:Documentation/preload-module-testcases&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;testcases-link-display&#039;]&lt;br /&gt;
-- The text to display for &amp;quot;testcases&amp;quot; links.&lt;br /&gt;
cfg[&#039;testcases-link-display&#039;] = &#039;testcases&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;testcases-edit-link-display&#039;]&lt;br /&gt;
-- The text to display for test cases &amp;quot;edit&amp;quot; links.&lt;br /&gt;
cfg[&#039;testcases-edit-link-display&#039;] = &#039;edit&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;testcases-run-link-display&#039;]&lt;br /&gt;
-- The text to display for test cases &amp;quot;run&amp;quot; links.&lt;br /&gt;
cfg[&#039;testcases-run-link-display&#039;] = &#039;run&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;testcases-create-link-display&#039;]&lt;br /&gt;
-- The text to display for test cases &amp;quot;create&amp;quot; links.&lt;br /&gt;
cfg[&#039;testcases-create-link-display&#039;] = &#039;create&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Add categories blurb configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- cfg[&#039;add-categories-blurb&#039;]&lt;br /&gt;
-- Text to direct users to add categories to the /doc subpage. Not used if the &amp;quot;content&amp;quot; or&lt;br /&gt;
-- &amp;quot;docname fed&amp;quot; arguments are set, as then it is not clear where to add the categories. $1 is a&lt;br /&gt;
-- link to the /doc subpage with a display value of cfg[&#039;doc-link-display&#039;].&lt;br /&gt;
--]]&lt;br /&gt;
cfg[&#039;add-categories-blurb&#039;] = &#039;Please add categories to the $1 subpage.&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;doc-link-display&#039;]&lt;br /&gt;
-- The text to display when linking to the /doc subpage.&lt;br /&gt;
cfg[&#039;doc-link-display&#039;] = &#039;/doc&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Subpages link configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- cfg[&#039;subpages-blurb&#039;]&lt;br /&gt;
-- The &amp;quot;Subpages of this template&amp;quot; blurb. $1 is a link to the main template&#039;s subpages with a&lt;br /&gt;
-- display value of cfg[&#039;subpages-link-display&#039;]. In the English version this blurb is simply&lt;br /&gt;
-- the link followed by a period, and the link display provides the actual text.&lt;br /&gt;
--]]&lt;br /&gt;
cfg[&#039;subpages-blurb&#039;] = &#039;$1.&#039;&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
-- cfg[&#039;subpages-link-display&#039;]&lt;br /&gt;
-- The text to display for the &amp;quot;subpages of this page&amp;quot; link. $1 is cfg[&#039;template-pagetype&#039;],&lt;br /&gt;
-- cfg[&#039;module-pagetype&#039;] or cfg[&#039;default-pagetype&#039;], depending on whether the current page is in&lt;br /&gt;
-- the template namespace, the module namespace, or another namespace.&lt;br /&gt;
--]]&lt;br /&gt;
cfg[&#039;subpages-link-display&#039;] = &#039;Subpages of this $1&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;template-pagetype&#039;]&lt;br /&gt;
-- The pagetype to display for template pages.&lt;br /&gt;
cfg[&#039;template-pagetype&#039;] = &#039;template&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;module-pagetype&#039;]&lt;br /&gt;
-- The pagetype to display for Lua module pages.&lt;br /&gt;
cfg[&#039;module-pagetype&#039;] = &#039;module&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;default-pagetype&#039;]&lt;br /&gt;
-- The pagetype to display for pages other than templates or Lua modules.&lt;br /&gt;
cfg[&#039;default-pagetype&#039;] = &#039;page&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Doc link configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;doc-subpage&#039;]&lt;br /&gt;
-- The name of the subpage typically used for documentation pages.&lt;br /&gt;
cfg[&#039;doc-subpage&#039;] = &#039;doc&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;file-docpage-preload&#039;]&lt;br /&gt;
-- Preload file for documentation page in the file namespace.&lt;br /&gt;
cfg[&#039;file-docpage-preload&#039;] = &#039;Template:Documentation/preload-filespace&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;docpage-preload&#039;]&lt;br /&gt;
-- Preload file for template documentation pages in all namespaces.&lt;br /&gt;
cfg[&#039;docpage-preload&#039;] = &#039;Template:Documentation/preload&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;module-preload&#039;]&lt;br /&gt;
-- Preload file for Lua module documentation pages.&lt;br /&gt;
cfg[&#039;module-preload&#039;] = &#039;Template:Documentation/preload-module-doc&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Print version configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;print-subpage&#039;]&lt;br /&gt;
-- The name of the template subpage used for print versions.&lt;br /&gt;
cfg[&#039;print-subpage&#039;] = &#039;Print&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;print-link-display&#039;]&lt;br /&gt;
-- The text to display when linking to the /Print subpage.&lt;br /&gt;
cfg[&#039;print-link-display&#039;] = &#039;/Print&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;print-blurb&#039;]&lt;br /&gt;
-- Text to display if a /Print subpage exists. $1 is a link to the subpage with a display value of cfg[&#039;print-link-display&#039;].&lt;br /&gt;
cfg[&#039;print-blurb&#039;] = &#039;A [[Help:Books/for experts#Improving the book layout|print version]] of this template exists at $1.&#039;&lt;br /&gt;
	.. &#039; If you make a change to this template, please update the print version as well.&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;display-print-category&#039;]&lt;br /&gt;
-- Set to true to enable output of cfg[&#039;print-category&#039;] if a /Print subpage exists.&lt;br /&gt;
-- This should be a boolean value (either true or false).&lt;br /&gt;
cfg[&#039;display-print-category&#039;] = true&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;print-category&#039;]&lt;br /&gt;
-- Category to output if cfg[&#039;display-print-category&#039;] is set to true, and a /Print subpage exists.&lt;br /&gt;
cfg[&#039;print-category&#039;] = &#039;Templates with print versions&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- HTML and CSS configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;main-div-id&#039;]&lt;br /&gt;
-- The &amp;quot;id&amp;quot; attribute of the main HTML &amp;quot;div&amp;quot; tag.&lt;br /&gt;
cfg[&#039;main-div-id&#039;] = &#039;template-documentation&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;main-div-classes&#039;]&lt;br /&gt;
-- The CSS classes added to the main HTML &amp;quot;div&amp;quot; tag.&lt;br /&gt;
cfg[&#039;main-div-classes&#039;] = &#039;template-documentation iezoomfix&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;start-box-linkclasses&#039;]&lt;br /&gt;
-- The CSS classes used for the [view][edit][history] or [create] links in the start box.&lt;br /&gt;
cfg[&#039;start-box-linkclasses&#039;] = &#039;mw-editsection-like plainlinks&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;start-box-link-id&#039;]&lt;br /&gt;
-- The HTML &amp;quot;id&amp;quot; attribute for the links in the start box.&lt;br /&gt;
cfg[&#039;start-box-link-id&#039;] = &#039;doc_editlinks&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- {{fmbox}} template configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;fmbox-id&#039;]&lt;br /&gt;
-- The id sent to the &amp;quot;id&amp;quot; parameter of the {{fmbox}} template.&lt;br /&gt;
cfg[&#039;fmbox-id&#039;] = &#039;documentation-meta-data&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;fmbox-style&#039;]&lt;br /&gt;
-- The value sent to the style parameter of {{fmbox}}.&lt;br /&gt;
cfg[&#039;fmbox-style&#039;] = &#039;background-color: #ecfcf4&#039;&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;fmbox-textstyle&#039;]&lt;br /&gt;
-- The value sent to the &amp;quot;textstyle parameter of {{fmbox}}.&lt;br /&gt;
cfg[&#039;fmbox-textstyle&#039;] = &#039;font-style: italic&#039;&lt;br /&gt;
&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- Tracking category configuration&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;display-strange-usage-category&#039;]&lt;br /&gt;
-- Set to true to enable output of cfg[&#039;strange-usage-category&#039;] if the module is used on a /doc subpage&lt;br /&gt;
-- or a /testcases subpage. This should be a boolean value (either true or false).&lt;br /&gt;
cfg[&#039;display-strange-usage-category&#039;] = true&lt;br /&gt;
&lt;br /&gt;
-- cfg[&#039;strange-usage-category&#039;]&lt;br /&gt;
-- Category to output if cfg[&#039;display-strange-usage-category&#039;] is set to true and the module is used on a&lt;br /&gt;
-- /doc subpage or a /testcases subpage.&lt;br /&gt;
cfg[&#039;strange-usage-category&#039;] = &#039;Wikipedia pages with strange ((documentation)) usage&#039;&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
-- End configuration&lt;br /&gt;
--&lt;br /&gt;
-- Don&#039;t edit anything below this line.&lt;br /&gt;
----------------------------------------------------------------------------------------------------&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
return cfg&lt;/div&gt;</summary>
		<author><name>ArxioWikiSysop</name></author>
	</entry>
</feed>