<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://oddworldlibrary.net/oddenc/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Max</id>
	<title>Oddworld Library - User contributions [en]</title>
	<link rel="self" type="application/atom+xml" href="https://oddworldlibrary.net/oddenc/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Max"/>
	<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/wiki/Special:Contributions/Max"/>
	<updated>2026-04-19T02:01:20Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.39.3</generator>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:The_Oddworld_Library:About&amp;diff=1595</id>
		<title>Template:The Oddworld Library:About</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:The_Oddworld_Library:About&amp;diff=1595"/>
		<updated>2018-10-03T22:05:10Z</updated>

		<summary type="html">&lt;p&gt;Max: Why are underscores being added to the visible text?&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;The Oddworld Library is a comprehensive source of all things Oddworld. Run by [[Xavier_De_Coster|Xavier De Coster]] and [[Wil_Bunce-Edwards|Wil Bunce-Edwards]], it hosts all kinds of media like images, websites, videos, developer diaries and interviews and also a number of articles about the games, their developers, the fandom and the lore. Despite it&#039;s name, it also covers other topics, mostly non-Oddworld projects by [[Oddworld Inhabitants]] and [[Lorne Lanning]], such as [[Citizen Siege]] or [[Xmobb]].&lt;br /&gt;
&lt;br /&gt;
More about the website can be read in it&#039;s respective [[Oddworld_Library|article]].&lt;br /&gt;
&lt;br /&gt;
== Sister sites of The Oddworld Library ==&lt;br /&gt;
;Oddblog ([https://oddworldlibrary.net/oddblog/ Old]/[https://oddworldlibrary.net/blog/ New])&lt;br /&gt;
:OddBlog covered Oddworld news from 2003 to 2014. It is divided between two systems: an archive, that holds all stories made before November 2010, and the newer OddBlog, that holds all stories made since.&lt;br /&gt;
&lt;br /&gt;
;[http://oddworldlibrary.net/toe/Contents?title=index.php The Oddworld Encyclopedia]&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOE&#039;&#039;&#039;’, hosted articles on Oddworld lore written by Wil. &#039;&#039;&#039;All content has been migrated to the wiki.&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
;[https://oddworldlibrary.net/archives/ The Oddworld Archives]&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOA&#039;&#039;&#039;’, archived many different types of media relating to Oddworld. It was divided into many different subsections, each catering to its own type of media.&lt;br /&gt;
&lt;br /&gt;
;[http://oddworldlibrary.net/archives/togg/ The Oddworld Graphics Gallery]&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOGG&#039;&#039;&#039;’, originally archived images only, maintained by Xavier. Since 2010 it has also started hosting videos.&lt;br /&gt;
&lt;br /&gt;
;[https://oddworldlibrary.net/archives/cinema/ The Oddworld Cinema]&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOC&#039;&#039;&#039;’, archived videos only, maintained by Xavier. Since 2010 its content was migrated to TOGG.&lt;br /&gt;
&lt;br /&gt;
;&amp;lt;s&amp;gt;The Oddworld Scriptures&amp;lt;/s&amp;gt;&lt;br /&gt;
:&amp;lt;s&amp;gt;Or ‘&#039;&#039;&#039;TOS&#039;&#039;&#039;’, archived texts only, maintained by Wil. These included press interviews, developer diaries, and texts taken from the [[INsOMNIOUS]] version of [[Oddworld.com]]. This content is in the process of being migrated to the wiki.&amp;lt;/s&amp;gt;&amp;lt;br&amp;gt;Superseded by [https://magogonthemarch.com/ Magog On The March].&lt;br /&gt;
&lt;br /&gt;
;[https://oddworldlibrary.net/archives/web/ Odd Wide Web]&lt;br /&gt;
:Archives a number of different official company and product websites, maintained by Xavier.&lt;br /&gt;
&lt;br /&gt;
;OddTunes&lt;br /&gt;
:Archives a number of different official soundtrack releases and music rips from Oddworld games. Does not have its own web pages.&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:The_Oddworld_Library:About&amp;diff=1594</id>
		<title>Template:The Oddworld Library:About</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:The_Oddworld_Library:About&amp;diff=1594"/>
		<updated>2018-10-03T22:02:32Z</updated>

		<summary type="html">&lt;p&gt;Max: This is how we get ants!&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;The Oddworld Library is a comprehensive source of all things Oddworld. Run by [[Xavier_De_Coster|Xavier De Coster]] and [[Wil_Bunce-Edwards]], it hosts all kinds of media like images, websites, videos, developer diaries and interviews and also a number of articles about the games, their developers, the fandom and the lore. Despite it&#039;s name, it also covers other topics, mostly non-Oddworld projects by [[Oddworld Inhabitants]] and [[Lorne Lanning]], such as [[Citizen Siege]] or [[Xmobb]].&lt;br /&gt;
&lt;br /&gt;
More about the website can be read in it&#039;s respective [[Oddworld_Library|article]].&lt;br /&gt;
&lt;br /&gt;
== Sister sites of The Oddworld Library ==&lt;br /&gt;
;Oddblog ([https://oddworldlibrary.net/oddblog/ Old]/[https://oddworldlibrary.net/blog/ New])&lt;br /&gt;
:OddBlog covered Oddworld news from 2003 to 2014. It is divided between two systems: an archive, that holds all stories made before November 2010, and the newer OddBlog, that holds all stories made since.&lt;br /&gt;
&lt;br /&gt;
;[http://oddworldlibrary.net/toe/Contents?title=index.php The Oddworld Encyclopedia]&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOE&#039;&#039;&#039;’, hosted articles on Oddworld lore written by Wil. &#039;&#039;&#039;All content has been migrated to the wiki.&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
;[https://oddworldlibrary.net/archives/ The Oddworld Archives]&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOA&#039;&#039;&#039;’, archived many different types of media relating to Oddworld. It was divided into many different subsections, each catering to its own type of media.&lt;br /&gt;
&lt;br /&gt;
;[http://oddworldlibrary.net/archives/togg/ The Oddworld Graphics Gallery]&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOGG&#039;&#039;&#039;’, originally archived images only, maintained by Xavier. Since 2010 it has also started hosting videos.&lt;br /&gt;
&lt;br /&gt;
;[https://oddworldlibrary.net/archives/cinema/ The Oddworld Cinema]&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOC&#039;&#039;&#039;’, archived videos only, maintained by Xavier. Since 2010 its content was migrated to TOGG.&lt;br /&gt;
&lt;br /&gt;
;&amp;lt;s&amp;gt;The Oddworld Scriptures&amp;lt;/s&amp;gt;&lt;br /&gt;
:&amp;lt;s&amp;gt;Or ‘&#039;&#039;&#039;TOS&#039;&#039;&#039;’, archived texts only, maintained by Wil. These included press interviews, developer diaries, and texts taken from the [[INsOMNIOUS]] version of [[Oddworld.com]]. This content is in the process of being migrated to the wiki.&amp;lt;/s&amp;gt;&amp;lt;br&amp;gt;Superseded by [https://magogonthemarch.com/ Magog On The March].&lt;br /&gt;
&lt;br /&gt;
;[https://oddworldlibrary.net/archives/web/ Odd Wide Web]&lt;br /&gt;
:Archives a number of different official company and product websites, maintained by Xavier.&lt;br /&gt;
&lt;br /&gt;
;OddTunes&lt;br /&gt;
:Archives a number of different official soundtrack releases and music rips from Oddworld games. Does not have its own web pages.&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Oddworld_Library&amp;diff=1258</id>
		<title>Oddworld Library</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Oddworld_Library&amp;diff=1258"/>
		<updated>2018-04-16T19:19:28Z</updated>

		<summary type="html">&lt;p&gt;Max: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&#039;&#039;&#039;Oddworld Library&#039;&#039;&#039; is an Oddworld [[List of Oddworld fansites|fansite]] created and maintained by [[Wil Bunce-Edwards]] and [[Xavier De Coster]]. It provides an up-to-date archive of media—including images, videos, websites, developer diaries and press interviews—and a number of articles on [[Oddworld]] lore, [[List of Oddworld products|products]] and [[Oddworld fandom|fandom]]. It also covered Oddworld news between 2004 and 2014, including a number of exclusive interviews and media premiers.&lt;br /&gt;
&lt;br /&gt;
Despite its name, Oddworld Library also covers other topics, mostly [[Non-Oddworld projects covered by Oddworld Library|non-Oddworld projects]] by [[Oddworld Inhabitants]] and [[Lorne Lanning]], such as [[Citizen Siege]], and [[Xmobb]].&lt;br /&gt;
&lt;br /&gt;
== History ==&lt;br /&gt;
=== Structure ===&lt;br /&gt;
Oddworld Library has traditionally been divided into three sections&lt;br /&gt;
;OddBlog&lt;br /&gt;
:OddBlog covered Oddworld news from 2003 to 2014. It is divided between two systems: the [/oddlog/ archived OddBlog] holds all stories made before November 2010, and the [/blog/ newer OddBlog] holds all stories made since.&lt;br /&gt;
&lt;br /&gt;
;The Oddworld Encyclopedia&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOE&#039;&#039;&#039;’, hosted articles on Oddworld lore written by Wil. All content has been migrated to the wiki.&lt;br /&gt;
&lt;br /&gt;
;The Oddworld Archives&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOA&#039;&#039;&#039;’, archived many different types of media relating to Oddworld. It was divided into many different subsections, each catering to its own type of media.&lt;br /&gt;
&lt;br /&gt;
;The Oddworld Graphics Gallery&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOGG&#039;&#039;&#039;’, originally archived images only, maintained by Xavier. Since 2010 it has also started hosting videos.&lt;br /&gt;
&lt;br /&gt;
;The Oddworld Cinema&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOC&#039;&#039;&#039;’, archived videos only, maintained by Xavier. Since 2010 its content was migrated to TOGG.&lt;br /&gt;
&lt;br /&gt;
;The Oddworld Scriptures&lt;br /&gt;
:Or ‘&#039;&#039;&#039;TOS&#039;&#039;&#039;’, archived texts only, maintained by Wil. These included press interviews, developer diaries, and texts taken from the [[INsOMNIOUS]] version of [[Oddworld.com]]. This content is in the process of being migrated to the wiki.&lt;br /&gt;
&lt;br /&gt;
;Odd Wide Web&lt;br /&gt;
:Archives a number of different official company and product websites, maintained by Xavier.&lt;br /&gt;
&lt;br /&gt;
;OddTunes&lt;br /&gt;
:Archives a number of different official soundtrack releases and music rips from Oddworld games. Does not have its own web pages.&lt;br /&gt;
&lt;br /&gt;
== History ==&lt;br /&gt;
=== Conception ===&lt;br /&gt;
Oddworld Library originated as four separate projects: OddBlog, The Oddworld Encyclopedia, OddBlog, The Oddworld Graphics Gallery and The Oddworld Archives. The first two were created by [[Wil Bunce-Edwards]], and the second two by [[Xavier De Coster]].&lt;br /&gt;
&lt;br /&gt;
Wil first began working on an Oddworld fansite in 2000. His first attempt was a webpage on the early webhosting service Xoom, which he called ‘&#039;&#039;&#039;The Kennels&#039;&#039;&#039;’. This early incarnation presented visitors with a guided tour of the eponymous Kennels (essentially a zoo of [[List of Oddworld species|Oddworld creatures]] known at the time) led by a conjoined-twin Glukkon named Glasp.&amp;lt;ref name=&amp;quot;namedKennels&amp;quot;/&amp;gt; By 2001, the project changed to one more encyclopedic in tone called ‘&#039;&#039;&#039;The Scrabacombs&#039;&#039;&#039;’,&amp;lt;ref name=&amp;quot;namedScrabacombs&amp;quot;/&amp;gt; but by 2002 this was again renamed to ‘The Oddworld Encyclopedia’ to reflect Wil’s nickname on the Oddworld Forums.&amp;lt;ref name=&amp;quot;renamedEncyclopedia&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Wil created OddBlog on uJournal on 7th August 2003, originally as a personal blog where he would post personal thoughts and updates to the Oddworld Encyclopedia project, leaving actual Oddworld news for an un-yet-unreleased part of the Encyclopedia named the ‘&#039;&#039;&#039;News Station&#039;&#039;&#039;’.&amp;lt;ref name=&amp;quot;oddblogFirstPost&amp;quot;/&amp;gt; However, under the advice of Xavier, he began posting Oddworld development and community news on OddBlog. On 6th December, Xavier began posting on OddBlog, originally on a temporary basis while Wil was absent,&amp;lt;ref name=&amp;quot;oddblogXavTemporary&amp;quot;/&amp;gt; but on 16th Dec, Wil announced that Xavier was now a permanent reporter.&amp;lt;ref name=&amp;quot;oddblogXavPermanent&amp;quot;/&amp;gt; Xavier had previously been a reporter of Oddworld news on [[Oddworld Maniac]], [[Oddworld News]] and [[Oddworld-Web]]. OddBlog migrated from uJournal to Blogger in January 2004.&amp;lt;ref name=&amp;quot;oddblogBlogger&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Wil, Xav, and a third member of the Oddworld Forums, Oddsville, who had previously owned the fansite [[Oddville]], began making plans to unite their fansites into one, calling themselves the ‘&#039;&#039;&#039;Shaman Network&#039;&#039;&#039;’: All three would share OddBlog, Wil would be in charge of The Oddworld Encyclopedia, and Xavier would create an Oddworld image gallery to take over his management of the [[Picture Request Thread]] on the [[Oddworld Forums]]; Oddsville would take responsibility for the fourth part of the Network, a collection of Oddworld press interviews that at the time was named ‘The Oddworld Archives’. However, Oddsville’s involvement in the group diminished and Xavier took over the Archives. Nevertheless, Wil and Xavier persisted in their plan to combine sites, and they eventually settled on the name ‘The Oddworld Library’.&lt;br /&gt;
&lt;br /&gt;
=== Launch ===&lt;br /&gt;
Although OddBlog had always been publicly accessible, it was formally launched in February 2004 with the slogan &amp;lt;q&amp;gt;bringing you true bijoux of Oddworld news&amp;lt;/q&amp;gt; when it was first announced on the Oddworld Forums and the link was publicly shared.&amp;lt;ref name=&amp;quot;oddblogLaunch&amp;quot;/&amp;gt;. Xavier created his image gallery, called ‘&#039;&#039;&#039;The Oddworld Graphics Gallery&#039;&#039;&#039;’ (or &#039;&#039;&#039;TOGG&#039;&#039;&#039;), and launched it in February 2005,&amp;lt;ref name=&amp;quot;toggLaunch&amp;quot;/&amp;gt; which was followed in September by The Oddworld Archives.&amp;lt;ref name=&amp;quot;toaLaunch&amp;quot;/&amp;gt; Despite officially being part of The Oddworld Library, both of Xavier&#039;s sites were originally hosted on [[Alcar]]’s fansite, [[Oddworld Universe]], but after that went down in February 2006,&amp;lt;ref name=&amp;quot;universeDown&amp;quot;/&amp;gt; TOGG and the Archives moved to the Library’s server within the month.&amp;lt;ref name=&amp;quot;toggReturn&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;toaReturn&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
The Oddworld Library was officially launched on 1st April 2006 with the opening of The Oddworld Encyclopedia.&amp;lt;ref name=&amp;quot;libraryLaunch&amp;quot;/&amp;gt; The first articles on the Encyclopedia were actually a number of [[April Fool&#039;s Day|joke articles]] written for April Fool’s Day. These were replaced the following day with 18 genuine articles, collectively branded as ‘[[Wave One]]’, with a ‘[[Wave Two]]’ of 15 additional articles being uploaded on 13th April.&lt;br /&gt;
&lt;br /&gt;
=== First Two Years ===&lt;br /&gt;
In October 2006, The Oddworld Archives were taken down and the name reused as an umbrella for TOGG and the Library&#039;s newest section, an archive of Oddworld videos called ‘&#039;&#039;&#039;The Oddworld Cinema&#039;&#039;&#039;’. At the same time, the site was also added to with ‘OddBlog Specials’ where exclusive stories and interviews could be highlighted, the Bulletin Board where site updates would be posted, and syndication feeds for both OddBlog and the Bulletin Board. These simultaneous updates were branded as The Oddworld Library’s first relaunch.&amp;lt;ref name=&amp;quot;libraryRelaunch&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
The Oddworld Forums became a sponsor of the Oddworld Library in January 2008 by adding a link to the fansite at the top of every page, alongside links to the fansites of its owners, [[Abe Babe]]’s [[Oddworld-Web]] and [[Alcar]]’s [[Oddworld Universe]].&amp;lt;ref name=&amp;quot;librarySponsor&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Second Anniversary ===&lt;br /&gt;
The Oddworld Library celebrated its second anniversary since its official launch on 1st April 2008. To mark the occasion, its archive of press interviews returned in a new section of The Oddworld Archives, called ‘&#039;&#039;&#039;The Oddworld Scriptures&#039;&#039;&#039;’, developed by Wil. In addition, although only 1 new article had been published on The Oddworld Encyclopedia since its first month, TOE was updated with 8 new article, 3 navigational pages and 1 updated article. This updated article on [[Fleeches]] was the first to use a reference list of cited sources, and came with a button to hide the inline citations if visitors found them annoying. Wil referred to these updates as &amp;lt;q&amp;gt;the start of a period of increased attention&amp;lt;/q&amp;gt; on TOE.&amp;lt;ref name=&amp;quot;library2ndAnniversary&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Third Year ===&lt;br /&gt;
In July 2008, two social network accounts were opened for The Oddworld Library: an [https://www.youtube.com/user/TheOddworldCinema Oddworld Cinema YouTube channel] and an [https://twitter.com/OddworldLibrary Oddworld Library Twitter account].&amp;lt;ref name=&amp;quot;cinemaYouTubeOWF&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;cinemaYouTubeOB&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;libraryTwitter&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== References ==&lt;br /&gt;
&amp;lt;references&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;namedKennels&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil&#039;&#039;&#039; &amp;lt;nowiki&amp;gt;[billy_squeek]&amp;lt;/nowiki&amp;gt; &#039;&#039;&#039;(2 July 2000)&#039;&#039;&#039;. ‘[http://games.groups.yahoo.com/group/exoddusclub/message/2451 My Webpage]’. Exoddus Club. Yahoo! Groups.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;namedScrabacombs&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (22 April 2001)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=2722 Coming Soon - The Scrabacombs]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;renamedEncyclopedia&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (7 April 2002)&#039;&#039;&#039;. [http://www.oddworldforums.net/showthread.php?p=58789#post58789 Post 10] in ‘There&#039;s more than one Shrink!?’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;oddblogFirstPost&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (17 August 2003)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/oddblog/2003/08/OddBlog_created OddBlog created]’. OddBlog. Oddworld Library.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;oddblogXavTemporary&amp;quot;/&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (6 December 2003)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/oddblog/2003/12/Xav_joins_OddBlog Xav joins OddBlog]’. OddBlog. Oddworld Library.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;oddblogXavPermanent&amp;quot;/&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (16 December 2003)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/oddblog/2003/12/Avatars_added Avatars added]’. OddBlog. Oddworld Library.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;oddblogBlogger&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (22 January 2004)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/oddblog/2004/01/OddBlog_2 OddBlog 2·0]’. OddBlog. Oddworld Library.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;oddblogLaunch&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (1 February 2004)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=9598 OddBlog]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;toggLaunch&amp;quot;&amp;gt;&#039;&#039;&#039;De Coster, Xavier (28 February 2005)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=11577 TOGG - Grand opening!]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;toaLaunch&amp;quot;&amp;gt;&#039;&#039;&#039;atusiya@ (2 September 2005)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=12699 Xavier &#039;s The Oddworld Archives !!]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;universeDown&amp;quot;&amp;gt;&#039;&#039;&#039;Oddworld Forums members (20–22 February 2006)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=13436 What happened????]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;toggReturn&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (12 March 2006)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=13533 The Oddworld Graphics Galliry Returns!]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;toaReturn&amp;quot;&amp;gt;&#039;&#039;&#039;De Coster, Xavier (5 March 2006)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=13500 The Oddworld Archives are back]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;libraryLaunch&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (1 April 2006)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=13663 The Oddworld Library - grand opening]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;libraryRelaunch&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (26 October 2006)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=14578 The Oddworld Library Relaunched]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;librarySponsor&amp;quot;&amp;gt;&#039;&#039;&#039;Alcar (15 January 2008)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=16485 TOL Sponsorship &amp;amp; Staff Changes]’. Forums Suggestions &amp;amp; Help. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;library2ndAnniversary&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (1 April 2008)&#039;&#039;&#039;. ‘[http://www.oddworldforums.net/showthread.php?t=16809 The TOL Thread]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;cinemaYouTubeOWF&amp;quot;&amp;gt;&#039;&#039;&#039;De Coster, Xavier (1 July 2008)&#039;&#039;&#039;. [http://www.oddworldforums.net/showthread.php?p=354850#post354850 Post 16] in ‘The TOL Thread’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;cinemaYouTubeOB&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (2 July 2008)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/oddblog/2008/07/The_Oddworld_Cinema_on_YouTube The Oddworld Cinema on YouTube]’. OddBlog. Oddworld Library.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;libraryTwitter&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (16 July 2008)&#039;&#039;&#039;. [http://www.oddworldforums.net/showthread.php?p=354850#post354850 Post 22] in ‘The TOL Thread’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;/references&amp;gt;&lt;br /&gt;
[[Category:Oddworld Library]]&lt;br /&gt;
[[Category:Oddworld fansites]]&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Str_endswith&amp;diff=1257</id>
		<title>Module:Str endswith</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Str_endswith&amp;diff=1257"/>
		<updated>2018-04-08T13:35:38Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module implements {{str endswith}}.&lt;br /&gt;
&lt;br /&gt;
local TRUE_STRING = &#039;yes&#039;&lt;br /&gt;
local FALSE_STRING = &#039;&#039;&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function trim(s)&lt;br /&gt;
	return s:match(&#039;^%s*(.-)%s*$&#039;)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	local args = frame:getParent().args&lt;br /&gt;
	local s = args[1]&lt;br /&gt;
	local pattern = args[2]&lt;br /&gt;
	if not s or not pattern then&lt;br /&gt;
		-- TRUE_STRING is not the natural choice here, but is needed for&lt;br /&gt;
		-- backwards compatibility.&lt;br /&gt;
		return TRUE_STRING&lt;br /&gt;
	end&lt;br /&gt;
	s = trim(s)&lt;br /&gt;
	pattern = trim(pattern)&lt;br /&gt;
	if pattern == &#039;&#039; then&lt;br /&gt;
		-- All strings end with the empty string.&lt;br /&gt;
		return TRUE_STRING&lt;br /&gt;
	end&lt;br /&gt;
	if mw.ustring.sub(s, 0 - mw.ustring.len(pattern), -1) == pattern then&lt;br /&gt;
		return TRUE_STRING&lt;br /&gt;
	else&lt;br /&gt;
		return FALSE_STRING&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Math&amp;diff=1255</id>
		<title>Module:Math</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Math&amp;diff=1255"/>
		<updated>2018-04-08T13:35:37Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--[[&lt;br /&gt;
&lt;br /&gt;
This module provides a number of basic mathematical operations.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local yesno, getArgs -- lazily initialized&lt;br /&gt;
&lt;br /&gt;
local p = {} -- Holds functions to be returned from #invoke, and functions to make available to other Lua modules.&lt;br /&gt;
local wrap = {} -- Holds wrapper functions that process arguments from #invoke. These act as intemediary between functions meant for #invoke and functions meant for Lua.&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper functions used to avoid redundant code.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function err(msg)&lt;br /&gt;
	-- Generates wikitext error messages.&lt;br /&gt;
	return mw.ustring.format(&#039;&amp;lt;strong class=&amp;quot;error&amp;quot;&amp;gt;Formatting error: %s&amp;lt;/strong&amp;gt;&#039;, msg)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function unpackNumberArgs(args)&lt;br /&gt;
	-- Returns an unpacked list of arguments specified with numerical keys.&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		if type(k) == &#039;number&#039; then&lt;br /&gt;
			table.insert(ret, v)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return unpack(ret)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function makeArgArray(...)&lt;br /&gt;
	-- Makes an array of arguments from a list of arguments that might include nils.&lt;br /&gt;
	local args = {...} -- Table of arguments. It might contain nils or non-number values, so we can&#039;t use ipairs.&lt;br /&gt;
	local nums = {} -- Stores the numbers of valid numerical arguments.&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		v = p._cleanNumber(v)&lt;br /&gt;
		if v then&lt;br /&gt;
			nums[#nums + 1] = k&lt;br /&gt;
			args[k] = v&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	table.sort(nums)&lt;br /&gt;
	for i, num in ipairs(nums) do&lt;br /&gt;
		ret[#ret + 1] = args[num]&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function fold(func, ...)&lt;br /&gt;
	-- Use a function on all supplied arguments, and return the result. The function must accept two numbers as parameters,&lt;br /&gt;
	-- and must return a number as an output. This number is then supplied as input to the next function call.&lt;br /&gt;
	local vals = makeArgArray(...)	&lt;br /&gt;
	local count = #vals -- The number of valid arguments&lt;br /&gt;
	if count == 0 then return&lt;br /&gt;
		-- Exit if we have no valid args, otherwise removing the first arg would cause an error.&lt;br /&gt;
		nil, 0&lt;br /&gt;
	end &lt;br /&gt;
	local ret = table.remove(vals, 1)&lt;br /&gt;
	for _, val in ipairs(vals) do&lt;br /&gt;
		ret = func(ret, val)&lt;br /&gt;
	end&lt;br /&gt;
	return ret, count&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Fold arguments by selectively choosing values (func should return when to choose the current &amp;quot;dominant&amp;quot; value).&lt;br /&gt;
]]&lt;br /&gt;
local function binary_fold(func, ...)&lt;br /&gt;
	local value = fold((function(a, b) if func(a, b) then return a else return b end end), ...)&lt;br /&gt;
	return value&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
random&lt;br /&gt;
&lt;br /&gt;
Generate a random number&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke: Math | random }}&lt;br /&gt;
{{#invoke: Math | random | maximum value }}&lt;br /&gt;
{{#invoke: Math | random | minimum value | maximum value }}&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.random(args)&lt;br /&gt;
	local first = p._cleanNumber(args[1])&lt;br /&gt;
	local second = p._cleanNumber(args[2])&lt;br /&gt;
	return p._random(first, second)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._random(first, second)&lt;br /&gt;
	math.randomseed(mw.site.stats.edits + mw.site.stats.pages + os.time() + math.floor(os.clock() * 1000000000))&lt;br /&gt;
	-- math.random will throw an error if given an explicit nil parameter, so we need to use if statements to check the params.&lt;br /&gt;
	if first and second then&lt;br /&gt;
		if first &amp;lt;= second then -- math.random doesn&#039;t allow the first number to be greater than the second.&lt;br /&gt;
			return math.random(first, second)&lt;br /&gt;
		end&lt;br /&gt;
	elseif first then&lt;br /&gt;
		return math.random(first)&lt;br /&gt;
	else&lt;br /&gt;
		return math.random()&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
order&lt;br /&gt;
&lt;br /&gt;
Determine order of magnitude of a number&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke: Math | order | value }}&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.order(args)&lt;br /&gt;
	local input_string = (args[1] or args.x or &#039;0&#039;);&lt;br /&gt;
	local input_number = p._cleanNumber(input_string);&lt;br /&gt;
	if input_number == nil then&lt;br /&gt;
		return err(&#039;order of magnitude input appears non-numeric&#039;)&lt;br /&gt;
	else&lt;br /&gt;
		return p._order(input_number)&lt;br /&gt;
	end    &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._order(x)&lt;br /&gt;
	if x == 0 then return 0 end&lt;br /&gt;
	return math.floor(math.log10(math.abs(x)))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision&lt;br /&gt;
&lt;br /&gt;
Detemines the precision of a number using the string representation&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{ #invoke: Math | precision | value }}&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.precision(args)&lt;br /&gt;
	local input_string = (args[1] or args.x or &#039;0&#039;);&lt;br /&gt;
	local trap_fraction = args.check_fraction;&lt;br /&gt;
	local input_number;&lt;br /&gt;
&lt;br /&gt;
	if not yesno then&lt;br /&gt;
		yesno = require(&#039;Module:Yesno&#039;)&lt;br /&gt;
	end&lt;br /&gt;
	if yesno(trap_fraction, true) then -- Returns true for all input except nil, false, &amp;quot;no&amp;quot;, &amp;quot;n&amp;quot;, &amp;quot;0&amp;quot; and a few others. See [[Module:Yesno]].&lt;br /&gt;
		local pos = string.find(input_string, &#039;/&#039;, 1, true);&lt;br /&gt;
		if pos ~= nil then&lt;br /&gt;
			if string.find(input_string, &#039;/&#039;, pos + 1, true) == nil then&lt;br /&gt;
				local denominator = string.sub(input_string, pos+1, -1);&lt;br /&gt;
				local denom_value = tonumber(denominator);&lt;br /&gt;
				if denom_value ~= nil then&lt;br /&gt;
					return math.log10(denom_value);&lt;br /&gt;
				end&lt;br /&gt;
			end                        &lt;br /&gt;
		end&lt;br /&gt;
	end    &lt;br /&gt;
&lt;br /&gt;
	input_number, input_string = p._cleanNumber(input_string);&lt;br /&gt;
	if input_string == nil then&lt;br /&gt;
		return err(&#039;precision input appears non-numeric&#039;)&lt;br /&gt;
	else&lt;br /&gt;
		return p._precision(input_string)&lt;br /&gt;
	end    &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._precision(x)&lt;br /&gt;
	if type(x) == &#039;number&#039; then&lt;br /&gt;
		x = tostring(x)&lt;br /&gt;
	end&lt;br /&gt;
	x = string.upper(x)&lt;br /&gt;
&lt;br /&gt;
	local decimal = x:find(&#039;%.&#039;)&lt;br /&gt;
	local exponent_pos = x:find(&#039;E&#039;)&lt;br /&gt;
	local result = 0;&lt;br /&gt;
&lt;br /&gt;
	if exponent_pos ~= nil then&lt;br /&gt;
		local exponent = string.sub(x, exponent_pos + 1)&lt;br /&gt;
		x = string.sub(x, 1, exponent_pos - 1)&lt;br /&gt;
		result = result - tonumber(exponent)&lt;br /&gt;
	end    &lt;br /&gt;
&lt;br /&gt;
	if decimal ~= nil then&lt;br /&gt;
		result = result + string.len(x) - decimal&lt;br /&gt;
		return result&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local pos = string.len(x);&lt;br /&gt;
	while x:byte(pos) == string.byte(&#039;0&#039;) do&lt;br /&gt;
		pos = pos - 1&lt;br /&gt;
		result = result - 1&lt;br /&gt;
		if pos &amp;lt;= 0 then&lt;br /&gt;
			return 0&lt;br /&gt;
		end&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;
--[[&lt;br /&gt;
max&lt;br /&gt;
&lt;br /&gt;
Finds the maximum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math| max | value1 | value2 | ... }}&lt;br /&gt;
&lt;br /&gt;
Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.max(args)&lt;br /&gt;
	return p._max(unpackNumberArgs(args))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._max(...)&lt;br /&gt;
	local max_value = binary_fold((function(a, b) return a &amp;gt; b end), ...)&lt;br /&gt;
	if max_value then&lt;br /&gt;
		return max_value&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
min &lt;br /&gt;
&lt;br /&gt;
Finds the minimum argument&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math| min | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:Math| min }}&lt;br /&gt;
&lt;br /&gt;
When used with no arguments, it takes its input from the parent&lt;br /&gt;
frame.  Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.min(args)&lt;br /&gt;
	return p._min(unpackNumberArgs(args))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._min(...)&lt;br /&gt;
	local min_value = binary_fold((function(a, b) return a &amp;lt; b end), ...)&lt;br /&gt;
	if min_value then&lt;br /&gt;
		return min_value&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
average &lt;br /&gt;
&lt;br /&gt;
Finds the average&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math| average | value1 | value2 | ... }}&lt;br /&gt;
OR&lt;br /&gt;
{{#invoke:Math| average }}&lt;br /&gt;
&lt;br /&gt;
Note, any values that do not evaluate to numbers are ignored.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.average(args)&lt;br /&gt;
	return p._average(unpackNumberArgs(args))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._average(...)&lt;br /&gt;
	local sum, count = fold((function(a, b) return a + b end), ...)&lt;br /&gt;
	if not sum then&lt;br /&gt;
		return 0&lt;br /&gt;
	else&lt;br /&gt;
		return sum / count&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
round&lt;br /&gt;
&lt;br /&gt;
Rounds a number to specified precision&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math | round | value | precision }}&lt;br /&gt;
&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
function wrap.round(args)&lt;br /&gt;
	local value = p._cleanNumber(args[1] or args.value or 0)&lt;br /&gt;
	local precision = p._cleanNumber(args[2] or args.precision or 0)&lt;br /&gt;
	if value == nil or precision == nil then&lt;br /&gt;
		return err(&#039;round input appears non-numeric&#039;)&lt;br /&gt;
	else&lt;br /&gt;
		return p._round(value, precision)&lt;br /&gt;
	end    &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._round(value, precision)&lt;br /&gt;
	local rescale = math.pow(10, precision or 0);&lt;br /&gt;
	return math.floor(value * rescale + 0.5) / rescale;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
mod&lt;br /&gt;
&lt;br /&gt;
Implements the modulo operator&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math | mod | x | y }}&lt;br /&gt;
&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
function wrap.mod(args)&lt;br /&gt;
	local x = p._cleanNumber(args[1])&lt;br /&gt;
	local y = p._cleanNumber(args[2])&lt;br /&gt;
	if not x then&lt;br /&gt;
		return err(&#039;first argument to mod appears non-numeric&#039;)&lt;br /&gt;
	elseif not y then&lt;br /&gt;
		return err(&#039;second argument to mod appears non-numeric&#039;)&lt;br /&gt;
	else&lt;br /&gt;
		return p._mod(x, y)&lt;br /&gt;
	end    &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._mod(x, y)&lt;br /&gt;
	local ret = x % y&lt;br /&gt;
	if not (0 &amp;lt;= ret and ret &amp;lt; y) then&lt;br /&gt;
		ret = 0&lt;br /&gt;
	end&lt;br /&gt;
	return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
gcd&lt;br /&gt;
&lt;br /&gt;
Calculates the greatest common divisor of multiple numbers&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke:Math | gcd | value 1 | value 2 | value 3 | ... }}&lt;br /&gt;
--]]&lt;br /&gt;
&lt;br /&gt;
function wrap.gcd(args)&lt;br /&gt;
	return p._gcd(unpackNumberArgs(args))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._gcd(...)&lt;br /&gt;
	local function findGcd(a, b)&lt;br /&gt;
		local r = b&lt;br /&gt;
		local oldr = a&lt;br /&gt;
		while r ~= 0 do&lt;br /&gt;
			local quotient = math.floor(oldr / r)&lt;br /&gt;
			oldr, r = r, oldr - quotient * r&lt;br /&gt;
		end&lt;br /&gt;
		if oldr &amp;lt; 0 then&lt;br /&gt;
			oldr = oldr * -1&lt;br /&gt;
		end&lt;br /&gt;
		return oldr&lt;br /&gt;
	end&lt;br /&gt;
	local result, count = fold(findGcd, ...)&lt;br /&gt;
	return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
precision_format&lt;br /&gt;
&lt;br /&gt;
Rounds a number to the specified precision and formats according to rules &lt;br /&gt;
originally used for {{template:Rnd}}.  Output is a string.&lt;br /&gt;
&lt;br /&gt;
Usage:&lt;br /&gt;
{{#invoke: Math | precision_format | number | precision }}&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function wrap.precision_format(args)&lt;br /&gt;
	local value_string = args[1] or 0&lt;br /&gt;
	local precision = args[2] or 0&lt;br /&gt;
	return p._precision_format(value_string, precision)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._precision_format(value_string, precision)&lt;br /&gt;
	-- For access to Mediawiki built-in formatter.&lt;br /&gt;
	local lang = mw.getContentLanguage();&lt;br /&gt;
&lt;br /&gt;
	local value&lt;br /&gt;
	value, value_string = p._cleanNumber(value_string)&lt;br /&gt;
	precision = p._cleanNumber(precision)&lt;br /&gt;
&lt;br /&gt;
	-- Check for non-numeric input&lt;br /&gt;
	if value == nil or precision == nil then&lt;br /&gt;
		return err(&#039;invalid input when rounding&#039;)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local current_precision = p._precision(value)&lt;br /&gt;
	local order = p._order(value)&lt;br /&gt;
&lt;br /&gt;
	-- Due to round-off effects it is neccesary to limit the returned precision under&lt;br /&gt;
	-- some circumstances because the terminal digits will be inaccurately reported.&lt;br /&gt;
	if order + precision &amp;gt;= 14 then&lt;br /&gt;
		orig_precision = p._precision(value_string)&lt;br /&gt;
		if order + orig_precision &amp;gt;= 14 then&lt;br /&gt;
			precision = 13 - order;        &lt;br /&gt;
		end        &lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- If rounding off, truncate extra digits&lt;br /&gt;
	if precision &amp;lt; current_precision then&lt;br /&gt;
		value = p._round(value, precision)&lt;br /&gt;
		current_precision = p._precision(value)&lt;br /&gt;
	end    &lt;br /&gt;
&lt;br /&gt;
	local formatted_num = lang:formatNum(math.abs(value))&lt;br /&gt;
	local sign&lt;br /&gt;
&lt;br /&gt;
	-- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
	if value &amp;lt; 0 then&lt;br /&gt;
		sign = &#039;−&#039;&lt;br /&gt;
	else&lt;br /&gt;
		sign = &#039;&#039;&lt;br /&gt;
	end    &lt;br /&gt;
&lt;br /&gt;
	-- Handle cases requiring scientific notation&lt;br /&gt;
	if string.find(formatted_num, &#039;E&#039;, 1, true) ~= nil or math.abs(order) &amp;gt;= 9 then&lt;br /&gt;
		value = value * math.pow(10, -order)&lt;br /&gt;
		current_precision = current_precision + order&lt;br /&gt;
		precision = precision + order&lt;br /&gt;
		formatted_num = lang:formatNum(math.abs(value))&lt;br /&gt;
	else&lt;br /&gt;
		order = 0;        &lt;br /&gt;
	end&lt;br /&gt;
	formatted_num = sign .. formatted_num&lt;br /&gt;
&lt;br /&gt;
	-- Pad with zeros, if needed    &lt;br /&gt;
	if current_precision &amp;lt; precision then&lt;br /&gt;
		local padding&lt;br /&gt;
		if current_precision &amp;lt;= 0 then&lt;br /&gt;
			if precision &amp;gt; 0 then&lt;br /&gt;
				local zero_sep = lang:formatNum(1.1)&lt;br /&gt;
				formatted_num = formatted_num .. zero_sep:sub(2,2)&lt;br /&gt;
&lt;br /&gt;
				padding = precision&lt;br /&gt;
				if padding &amp;gt; 20 then&lt;br /&gt;
					padding = 20&lt;br /&gt;
				end&lt;br /&gt;
&lt;br /&gt;
				formatted_num = formatted_num .. string.rep(&#039;0&#039;, padding)&lt;br /&gt;
			end            &lt;br /&gt;
		else                   &lt;br /&gt;
			padding = precision - current_precision&lt;br /&gt;
			if padding &amp;gt; 20 then&lt;br /&gt;
				padding = 20&lt;br /&gt;
			end&lt;br /&gt;
			formatted_num = formatted_num .. string.rep(&#039;0&#039;, padding)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add exponential notation, if necessary.&lt;br /&gt;
	if order ~= 0 then&lt;br /&gt;
		-- Use proper unary minus sign rather than ASCII default&lt;br /&gt;
		if order &amp;lt; 0 then&lt;br /&gt;
			order = &#039;−&#039; .. lang:formatNum(math.abs(order))&lt;br /&gt;
		else&lt;br /&gt;
			order = lang:formatNum(order)&lt;br /&gt;
		end    &lt;br /&gt;
&lt;br /&gt;
		formatted_num = formatted_num .. &#039;&amp;lt;span style=&amp;quot;margin:0 .15em 0 .25em&amp;quot;&amp;gt;×&amp;lt;/span&amp;gt;10&amp;lt;sup&amp;gt;&#039; .. order .. &#039;&amp;lt;/sup&amp;gt;&#039;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return formatted_num&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Helper function that interprets the input numerically.  If the &lt;br /&gt;
input does not appear to be a number, attempts evaluating it as&lt;br /&gt;
a parser functions expression.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function p._cleanNumber(number_string)&lt;br /&gt;
	if type(number_string) == &#039;number&#039; then&lt;br /&gt;
		-- We were passed a number, so we don&#039;t need to do any processing.&lt;br /&gt;
		return number_string, tostring(number_string)&lt;br /&gt;
	elseif type(number_string) ~= &#039;string&#039; or not number_string:find(&#039;%S&#039;) then&lt;br /&gt;
		-- We were passed a non-string or a blank string, so exit.&lt;br /&gt;
		return nil, nil;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Attempt basic conversion&lt;br /&gt;
	local number = tonumber(number_string)&lt;br /&gt;
&lt;br /&gt;
	-- If failed, attempt to evaluate input as an expression&lt;br /&gt;
	if number == nil then&lt;br /&gt;
		local success, result = pcall(mw.ext.ParserFunctions.expr, number_string)&lt;br /&gt;
		if success then&lt;br /&gt;
			number = tonumber(result)&lt;br /&gt;
			number_string = tostring(number)&lt;br /&gt;
		else&lt;br /&gt;
			number = nil&lt;br /&gt;
			number_string = nil&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		number_string = number_string:match(&amp;quot;^%s*(.-)%s*$&amp;quot;) -- String is valid but may contain padding, clean it.&lt;br /&gt;
		number_string = number_string:match(&amp;quot;^%+(.*)$&amp;quot;) or number_string -- Trim any leading + signs.&lt;br /&gt;
		if number_string:find(&#039;^%-?0[xX]&#039;) then&lt;br /&gt;
			-- Number is using 0xnnn notation to indicate base 16; use the number that Lua detected instead.&lt;br /&gt;
			number_string = tostring(number)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return number, number_string&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
Wrapper function that does basic argument processing. This ensures that all functions from #invoke can use either the current&lt;br /&gt;
frame or the parent frame, and it also trims whitespace for all arguments and removes blank arguments.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local mt = { __index = function(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 wrap[k](getArgs(frame))  -- Argument processing is left to Module:Arguments. Whitespace is trimmed and blank arguments are removed.&lt;br /&gt;
	end&lt;br /&gt;
end }&lt;br /&gt;
&lt;br /&gt;
return setmetatable(p, mt)&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Infobox&amp;diff=1253</id>
		<title>Module:Infobox</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Infobox&amp;diff=1253"/>
		<updated>2018-04-08T13:35:37Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;--&lt;br /&gt;
-- This module implements {{Infobox}}&lt;br /&gt;
--&lt;br /&gt;
 &lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local navbar = require(&#039;Module:Navbar&#039;)._navbar&lt;br /&gt;
&lt;br /&gt;
local args = {}&lt;br /&gt;
local origArgs&lt;br /&gt;
local root&lt;br /&gt;
&lt;br /&gt;
local function notempty( s ) return s and s:match( &#039;%S&#039; ) end&lt;br /&gt;
&lt;br /&gt;
local function fixChildBoxes(sval, tt)&lt;br /&gt;
	if notempty(sval) then&lt;br /&gt;
		local marker = &#039;&amp;lt;span class=special_infobox_marker&amp;gt;&#039;&lt;br /&gt;
		local s = sval&lt;br /&gt;
		s = mw.ustring.gsub(s, &#039;(&amp;lt;%s*[Tt][Rr])&#039;, marker .. &#039;%1&#039;)&lt;br /&gt;
		s = mw.ustring.gsub(s, &#039;(&amp;lt;/[Tt][Rr]%s*&amp;gt;)&#039;, &#039;%1&#039; .. marker)&lt;br /&gt;
		if s:match(marker) then&lt;br /&gt;
			s = mw.ustring.gsub(s, marker .. &#039;%s*&#039; .. marker, &#039;&#039;)&lt;br /&gt;
			s = mw.ustring.gsub(s, &#039;([\r\n]|-[^\r\n]*[\r\n])%s*&#039; .. marker, &#039;%1&#039;)&lt;br /&gt;
			s = mw.ustring.gsub(s, marker .. &#039;%s*([\r\n]|-)&#039;, &#039;%1&#039;)&lt;br /&gt;
			s = mw.ustring.gsub(s, &#039;(&amp;lt;/[Cc][Aa][Pp][Tt][Ii][Oo][Nn]%s*&amp;gt;%s*)&#039; .. marker, &#039;%1&#039;)&lt;br /&gt;
			s = mw.ustring.gsub(s, &#039;(&amp;lt;%s*[Tt][Aa][Bb][Ll][Ee][^&amp;lt;&amp;gt;]*&amp;gt;%s*)&#039; .. marker, &#039;%1&#039;)&lt;br /&gt;
			s = mw.ustring.gsub(s, &#039;^(%{|[^\r\n]*[\r\n]%s*)&#039; .. marker, &#039;%1&#039;)&lt;br /&gt;
			s = mw.ustring.gsub(s, &#039;([\r\n]%{|[^\r\n]*[\r\n]%s*)&#039; .. marker, &#039;%1&#039;)&lt;br /&gt;
			s = mw.ustring.gsub(s,  marker .. &#039;(%s*&amp;lt;/[Tt][Aa][Bb][Ll][Ee]%s*&amp;gt;)&#039;, &#039;%1&#039;)&lt;br /&gt;
			s = mw.ustring.gsub(s,  marker .. &#039;(%s*\n|%})&#039;, &#039;%1&#039;)&lt;br /&gt;
		end&lt;br /&gt;
		if s:match(marker) then&lt;br /&gt;
			local subcells = mw.text.split(s, marker)&lt;br /&gt;
			s = &#039;&#039;&lt;br /&gt;
			for k = 1, #subcells do&lt;br /&gt;
				if k == 1 then&lt;br /&gt;
					s = s .. subcells[k] .. &#039;&amp;lt;/&#039; .. tt .. &#039;&amp;gt;&amp;lt;/tr&amp;gt;&#039;&lt;br /&gt;
				elseif k == #subcells then&lt;br /&gt;
					local rowstyle = &#039; style=&amp;quot;display:none&amp;quot;&#039;&lt;br /&gt;
					if notempty(subcells[k]) then rowstyle = &#039;&#039;	end&lt;br /&gt;
					s = s .. &#039;&amp;lt;tr&#039; .. rowstyle ..&#039;&amp;gt;&amp;lt;&#039; .. tt .. &#039; colspan=2&amp;gt;\n&#039; .. subcells[k]&lt;br /&gt;
				elseif notempty(subcells[k]) then&lt;br /&gt;
					if (k % 2) == 0 then&lt;br /&gt;
						s = s .. subcells[k]&lt;br /&gt;
					else&lt;br /&gt;
						s = s .. &#039;&amp;lt;tr&amp;gt;&amp;lt;&#039; .. tt .. &#039; colspan=2&amp;gt;\n&#039; .. subcells[k] .. &#039;&amp;lt;/&#039; .. tt .. &#039;&amp;gt;&amp;lt;/tr&amp;gt;&#039;&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		return s&lt;br /&gt;
	else&lt;br /&gt;
		return sval&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 the values of two tables, as a sequence.&lt;br /&gt;
    local vals = {}&lt;br /&gt;
    for k, v in pairs(t1) do&lt;br /&gt;
        vals[v] = true&lt;br /&gt;
    end&lt;br /&gt;
    for k, v in pairs(t2) do&lt;br /&gt;
        vals[v] = true&lt;br /&gt;
    end&lt;br /&gt;
    local ret = {}&lt;br /&gt;
    for k, v in pairs(vals) do&lt;br /&gt;
        table.insert(ret, k)&lt;br /&gt;
    end&lt;br /&gt;
    return ret&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function getArgNums(prefix)&lt;br /&gt;
    -- Returns a table containing the numbers of the arguments that exist&lt;br /&gt;
    -- for the specified prefix. For example, if the prefix was &#039;data&#039;, and&lt;br /&gt;
    -- &#039;data1&#039;, &#039;data2&#039;, and &#039;data5&#039; exist, it would return {1, 2, 5}.&lt;br /&gt;
    local nums = {}&lt;br /&gt;
    for k, v in pairs(args) do&lt;br /&gt;
        local num = tostring(k):match(&#039;^&#039; .. prefix .. &#039;([1-9]%d*)$&#039;)&lt;br /&gt;
        if num then table.insert(nums, tonumber(num)) 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;
local function addRow(rowArgs)&lt;br /&gt;
    -- Adds a row to the infobox, with either a header cell&lt;br /&gt;
    -- or a label/data cell combination.&lt;br /&gt;
    if rowArgs.header then&lt;br /&gt;
        root&lt;br /&gt;
            :tag(&#039;tr&#039;)&lt;br /&gt;
                :addClass(rowArgs.rowclass)&lt;br /&gt;
                :cssText(rowArgs.rowstyle)&lt;br /&gt;
                :attr(&#039;id&#039;, rowArgs.rowid)&lt;br /&gt;
                :tag(&#039;th&#039;)&lt;br /&gt;
                    :attr(&#039;colspan&#039;, 2)&lt;br /&gt;
                    :attr(&#039;id&#039;, rowArgs.headerid)&lt;br /&gt;
                    :addClass(rowArgs.class)&lt;br /&gt;
                    :addClass(args.headerclass)&lt;br /&gt;
                    :css(&#039;text-align&#039;, &#039;center&#039;)&lt;br /&gt;
                    :cssText(args.headerstyle)&lt;br /&gt;
                    :cssText(rowArgs.rowcellstyle)&lt;br /&gt;
                    :wikitext(fixChildBoxes(rowArgs.header, &#039;th&#039;))&lt;br /&gt;
    elseif rowArgs.data then&lt;br /&gt;
        local row = root:tag(&#039;tr&#039;)&lt;br /&gt;
        row:addClass(rowArgs.rowclass)&lt;br /&gt;
        row:cssText(rowArgs.rowstyle)&lt;br /&gt;
        row:attr(&#039;id&#039;, rowArgs.rowid)&lt;br /&gt;
        if rowArgs.label then&lt;br /&gt;
            row&lt;br /&gt;
                :tag(&#039;th&#039;)&lt;br /&gt;
                    :attr(&#039;scope&#039;, &#039;row&#039;)&lt;br /&gt;
                    :attr(&#039;id&#039;, rowArgs.labelid)&lt;br /&gt;
                    :cssText(args.labelstyle)&lt;br /&gt;
                    :cssText(rowArgs.rowcellstyle)&lt;br /&gt;
                    :wikitext(rowArgs.label)&lt;br /&gt;
                    :done()&lt;br /&gt;
        end&lt;br /&gt;
        &lt;br /&gt;
        local dataCell = row:tag(&#039;td&#039;)&lt;br /&gt;
        if not rowArgs.label then &lt;br /&gt;
            dataCell&lt;br /&gt;
                :attr(&#039;colspan&#039;, 2)&lt;br /&gt;
                :css(&#039;text-align&#039;, &#039;center&#039;) &lt;br /&gt;
        end&lt;br /&gt;
        dataCell&lt;br /&gt;
            :attr(&#039;id&#039;, rowArgs.dataid)&lt;br /&gt;
            :addClass(rowArgs.class)&lt;br /&gt;
            :cssText(rowArgs.datastyle)&lt;br /&gt;
            :cssText(rowArgs.rowcellstyle)&lt;br /&gt;
            :newline()&lt;br /&gt;
            :wikitext(fixChildBoxes(rowArgs.data, &#039;td&#039;))&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderTitle()&lt;br /&gt;
    if not args.title then return end&lt;br /&gt;
&lt;br /&gt;
    root&lt;br /&gt;
        :tag(&#039;caption&#039;)&lt;br /&gt;
            :addClass(args.titleclass)&lt;br /&gt;
            :cssText(args.titlestyle)&lt;br /&gt;
            :wikitext(args.title)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderAboveRow()&lt;br /&gt;
    if not args.above then return end&lt;br /&gt;
    &lt;br /&gt;
    root&lt;br /&gt;
        :tag(&#039;tr&#039;)&lt;br /&gt;
            :tag(&#039;th&#039;)&lt;br /&gt;
                :attr(&#039;colspan&#039;, 2)&lt;br /&gt;
                :addClass(args.aboveclass)&lt;br /&gt;
                :css(&#039;text-align&#039;, &#039;center&#039;)&lt;br /&gt;
                :css(&#039;font-size&#039;, &#039;125%&#039;)&lt;br /&gt;
                :css(&#039;font-weight&#039;, &#039;bold&#039;)&lt;br /&gt;
                :cssText(args.abovestyle)&lt;br /&gt;
                :wikitext(fixChildBoxes(args.above,&#039;th&#039;))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderBelowRow()&lt;br /&gt;
    if not args.below then return end&lt;br /&gt;
    &lt;br /&gt;
    root&lt;br /&gt;
        :tag(&#039;tr&#039;)&lt;br /&gt;
            :tag(&#039;td&#039;)&lt;br /&gt;
                :attr(&#039;colspan&#039;, &#039;2&#039;)&lt;br /&gt;
                :addClass(args.belowclass)&lt;br /&gt;
                :css(&#039;text-align&#039;, &#039;center&#039;)&lt;br /&gt;
                :cssText(args.belowstyle)&lt;br /&gt;
                :newline()&lt;br /&gt;
                :wikitext(fixChildBoxes(args.below,&#039;td&#039;))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderSubheaders()&lt;br /&gt;
    if args.subheader then&lt;br /&gt;
        args.subheader1 = args.subheader&lt;br /&gt;
    end&lt;br /&gt;
    if args.subheaderrowclass then&lt;br /&gt;
        args.subheaderrowclass1 = args.subheaderrowclass&lt;br /&gt;
    end&lt;br /&gt;
    local subheadernums = getArgNums(&#039;subheader&#039;)&lt;br /&gt;
    for k, num in ipairs(subheadernums) do&lt;br /&gt;
        addRow({&lt;br /&gt;
            data = args[&#039;subheader&#039; .. tostring(num)],&lt;br /&gt;
            datastyle = args.subheaderstyle or args[&#039;subheaderstyle&#039; .. tostring(num)],&lt;br /&gt;
            class = args.subheaderclass,&lt;br /&gt;
            rowclass = args[&#039;subheaderrowclass&#039; .. tostring(num)]&lt;br /&gt;
        })&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderImages()&lt;br /&gt;
    if args.image then&lt;br /&gt;
        args.image1 = args.image&lt;br /&gt;
    end&lt;br /&gt;
    if args.caption then&lt;br /&gt;
        args.caption1 = args.caption&lt;br /&gt;
    end&lt;br /&gt;
    local imagenums = getArgNums(&#039;image&#039;)&lt;br /&gt;
    for k, num in ipairs(imagenums) do&lt;br /&gt;
        local caption = args[&#039;caption&#039; .. tostring(num)]&lt;br /&gt;
        local data = mw.html.create():wikitext(args[&#039;image&#039; .. tostring(num)])&lt;br /&gt;
        if caption then&lt;br /&gt;
            data&lt;br /&gt;
                :tag(&#039;div&#039;)&lt;br /&gt;
                    :cssText(args.captionstyle)&lt;br /&gt;
                    :wikitext(caption)&lt;br /&gt;
        end&lt;br /&gt;
        addRow({&lt;br /&gt;
            data = tostring(data),&lt;br /&gt;
            datastyle = args.imagestyle,&lt;br /&gt;
            class = args.imageclass,&lt;br /&gt;
            rowclass = args[&#039;imagerowclass&#039; .. tostring(num)]&lt;br /&gt;
        })&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderRows()&lt;br /&gt;
    -- Gets the union of the header and data argument numbers,&lt;br /&gt;
    -- and renders them all in order using addRow.&lt;br /&gt;
    local rownums = union(getArgNums(&#039;header&#039;), getArgNums(&#039;data&#039;))&lt;br /&gt;
    table.sort(rownums)&lt;br /&gt;
    for k, num in ipairs(rownums) do&lt;br /&gt;
        addRow({&lt;br /&gt;
            header = args[&#039;header&#039; .. tostring(num)],&lt;br /&gt;
            label = args[&#039;label&#039; .. tostring(num)],&lt;br /&gt;
            data = args[&#039;data&#039; .. tostring(num)],&lt;br /&gt;
            datastyle = args.datastyle,&lt;br /&gt;
            class = args[&#039;class&#039; .. tostring(num)],&lt;br /&gt;
            rowclass = args[&#039;rowclass&#039; .. tostring(num)],&lt;br /&gt;
            rowstyle = args[&#039;rowstyle&#039; .. tostring(num)],&lt;br /&gt;
            rowcellstyle = args[&#039;rowcellstyle&#039; .. tostring(num)],&lt;br /&gt;
            dataid = args[&#039;dataid&#039; .. tostring(num)],&lt;br /&gt;
            labelid = args[&#039;labelid&#039; .. tostring(num)],&lt;br /&gt;
            headerid = args[&#039;headerid&#039; .. tostring(num)],&lt;br /&gt;
            rowid = args[&#039;rowid&#039; .. tostring(num)]&lt;br /&gt;
        })&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderNavBar()&lt;br /&gt;
    if not args.name then return end&lt;br /&gt;
    &lt;br /&gt;
    root&lt;br /&gt;
        :tag(&#039;tr&#039;)&lt;br /&gt;
            :tag(&#039;td&#039;)&lt;br /&gt;
                :attr(&#039;colspan&#039;, &#039;2&#039;)&lt;br /&gt;
                :css(&#039;text-align&#039;, &#039;right&#039;)&lt;br /&gt;
                :wikitext(navbar{&lt;br /&gt;
                    args.name,&lt;br /&gt;
                    mini = 1,&lt;br /&gt;
                })&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderItalicTitle()&lt;br /&gt;
    local italicTitle = args[&#039;italic title&#039;] and mw.ustring.lower(args[&#039;italic title&#039;])&lt;br /&gt;
    if italicTitle == &#039;&#039; or italicTitle == &#039;force&#039; or italicTitle == &#039;yes&#039; then&lt;br /&gt;
        root:wikitext(mw.getCurrentFrame():expandTemplate({title = &#039;italic title&#039;}))&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function renderTrackingCategories()&lt;br /&gt;
    if args.decat ~= &#039;yes&#039; then&lt;br /&gt;
        if #(getArgNums(&#039;data&#039;)) == 0 and mw.title.getCurrentTitle().namespace == 0 then&lt;br /&gt;
            root:wikitext(&#039;[[Category:Articles which use infobox templates with no data rows]]&#039;)&lt;br /&gt;
        end&lt;br /&gt;
        if args.child == &#039;yes&#039; and args.title then&lt;br /&gt;
            root:wikitext(&#039;[[Category:Pages which use embedded infobox templates with the title parameter]]&#039;)&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function _infobox()&lt;br /&gt;
    -- Specify the overall layout of the infobox, with special settings&lt;br /&gt;
    -- if the infobox is used as a &#039;child&#039; inside another infobox.&lt;br /&gt;
    if args.child ~= &#039;yes&#039; then&lt;br /&gt;
        root = mw.html.create(&#039;table&#039;)&lt;br /&gt;
        &lt;br /&gt;
        root&lt;br /&gt;
            :addClass((args.subbox ~= &#039;yes&#039;) and &#039;infobox&#039; or nil)&lt;br /&gt;
            :addClass(args.bodyclass)&lt;br /&gt;
            &lt;br /&gt;
            if args.subbox == &#039;yes&#039; then&lt;br /&gt;
                root&lt;br /&gt;
                    :css(&#039;padding&#039;, &#039;0&#039;)&lt;br /&gt;
                    :css(&#039;border&#039;, &#039;none&#039;)&lt;br /&gt;
                    :css(&#039;margin&#039;, &#039;-3px&#039;)&lt;br /&gt;
                    :css(&#039;width&#039;, &#039;auto&#039;)&lt;br /&gt;
                    :css(&#039;min-width&#039;, &#039;100%&#039;)&lt;br /&gt;
                    :css(&#039;font-size&#039;, &#039;100%&#039;)&lt;br /&gt;
                    :css(&#039;clear&#039;, &#039;none&#039;)&lt;br /&gt;
                    :css(&#039;float&#039;, &#039;none&#039;)&lt;br /&gt;
                    :css(&#039;background-color&#039;, &#039;transparent&#039;)&lt;br /&gt;
            else&lt;br /&gt;
                root&lt;br /&gt;
                    :css(&#039;width&#039;, &#039;22em&#039;)&lt;br /&gt;
            end&lt;br /&gt;
        root&lt;br /&gt;
            :cssText(args.bodystyle)&lt;br /&gt;
    &lt;br /&gt;
        renderTitle()&lt;br /&gt;
        renderAboveRow()&lt;br /&gt;
    else&lt;br /&gt;
        root = mw.html.create()&lt;br /&gt;
        &lt;br /&gt;
        root&lt;br /&gt;
            :wikitext(args.title)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    renderSubheaders()&lt;br /&gt;
    renderImages() &lt;br /&gt;
    renderRows() &lt;br /&gt;
    renderBelowRow()  &lt;br /&gt;
    renderNavBar()&lt;br /&gt;
    renderItalicTitle()&lt;br /&gt;
    renderTrackingCategories()&lt;br /&gt;
    &lt;br /&gt;
    return tostring(root)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function preprocessSingleArg(argName)&lt;br /&gt;
    -- If the argument exists and isn&#039;t blank, add it to the argument table.&lt;br /&gt;
    -- Blank arguments are treated as nil to match the behaviour of ParserFunctions.&lt;br /&gt;
    if origArgs[argName] and origArgs[argName] ~= &#039;&#039; then&lt;br /&gt;
        args[argName] = origArgs[argName]&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function preprocessArgs(prefixTable, step)&lt;br /&gt;
    -- Assign the parameters with the given prefixes to the args table, in order, in batches&lt;br /&gt;
    -- of the step size specified. This is to prevent references etc. from appearing in the&lt;br /&gt;
    -- wrong order. The prefixTable should be an array containing tables, each of which has&lt;br /&gt;
    -- two possible fields, a &amp;quot;prefix&amp;quot; string and a &amp;quot;depend&amp;quot; table. The function always parses&lt;br /&gt;
    -- parameters containing the &amp;quot;prefix&amp;quot; string, but only parses parameters in the &amp;quot;depend&amp;quot;&lt;br /&gt;
    -- table if the prefix parameter is present and non-blank.&lt;br /&gt;
    if type(prefixTable) ~= &#039;table&#039; then&lt;br /&gt;
        error(&amp;quot;Non-table value detected for the prefix table&amp;quot;, 2)&lt;br /&gt;
    end&lt;br /&gt;
    if type(step) ~= &#039;number&#039; then&lt;br /&gt;
        error(&amp;quot;Invalid step value detected&amp;quot;, 2)&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- Get arguments without a number suffix, and check for bad input.&lt;br /&gt;
    for i,v in ipairs(prefixTable) do&lt;br /&gt;
        if type(v) ~= &#039;table&#039; or type(v.prefix) ~= &amp;quot;string&amp;quot; or (v.depend and type(v.depend) ~= &#039;table&#039;) then&lt;br /&gt;
            error(&#039;Invalid input detected to preprocessArgs prefix table&#039;, 2)&lt;br /&gt;
        end&lt;br /&gt;
        preprocessSingleArg(v.prefix)&lt;br /&gt;
        -- Only parse the depend parameter if the prefix parameter is present and not blank.&lt;br /&gt;
        if args[v.prefix] and v.depend then&lt;br /&gt;
            for j, dependValue in ipairs(v.depend) do&lt;br /&gt;
                if type(dependValue) ~= &#039;string&#039; then&lt;br /&gt;
                    error(&#039;Invalid &amp;quot;depend&amp;quot; parameter value detected in preprocessArgs&#039;)&lt;br /&gt;
                end&lt;br /&gt;
                preprocessSingleArg(dependValue)&lt;br /&gt;
            end&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    -- Get arguments with number suffixes.&lt;br /&gt;
    local a = 1 -- Counter variable.&lt;br /&gt;
    local moreArgumentsExist = true&lt;br /&gt;
    while moreArgumentsExist == true do&lt;br /&gt;
        moreArgumentsExist = false&lt;br /&gt;
        for i = a, a + step - 1 do&lt;br /&gt;
            for j,v in ipairs(prefixTable) do&lt;br /&gt;
                local prefixArgName = v.prefix .. tostring(i)&lt;br /&gt;
                if origArgs[prefixArgName] then&lt;br /&gt;
                    moreArgumentsExist = true -- Do another loop if any arguments are found, even blank ones.&lt;br /&gt;
                    preprocessSingleArg(prefixArgName)&lt;br /&gt;
                end&lt;br /&gt;
                -- Process the depend table if the prefix argument is present and not blank, or&lt;br /&gt;
                -- we are processing &amp;quot;prefix1&amp;quot; and &amp;quot;prefix&amp;quot; is present and not blank, and&lt;br /&gt;
                -- if the depend table is present.&lt;br /&gt;
                if v.depend and (args[prefixArgName] or (i == 1 and args[v.prefix])) then&lt;br /&gt;
                    for j,dependValue in ipairs(v.depend) do&lt;br /&gt;
                        local dependArgName = dependValue .. tostring(i)&lt;br /&gt;
                        preprocessSingleArg(dependArgName)&lt;br /&gt;
                    end&lt;br /&gt;
                end&lt;br /&gt;
            end&lt;br /&gt;
        end&lt;br /&gt;
        a = a + step&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
 &lt;br /&gt;
function p.infobox(frame)&lt;br /&gt;
    -- If called via #invoke, use the args passed into the invoking template.&lt;br /&gt;
    -- Otherwise, for testing purposes, assume args are being passed directly in.&lt;br /&gt;
    if frame == mw.getCurrentFrame() then&lt;br /&gt;
        origArgs = frame:getParent().args&lt;br /&gt;
    else&lt;br /&gt;
        origArgs = frame&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- Parse the data parameters in the same order that the old {{infobox}} did, so that&lt;br /&gt;
    -- references etc. will display in the expected places. Parameters that depend on&lt;br /&gt;
    -- another parameter are only processed if that parameter is present, to avoid&lt;br /&gt;
    -- phantom references appearing in article reference lists.&lt;br /&gt;
    preprocessSingleArg(&#039;child&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;bodyclass&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;subbox&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;bodystyle&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;title&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;titleclass&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;titlestyle&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;above&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;aboveclass&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;abovestyle&#039;)&lt;br /&gt;
    preprocessArgs({&lt;br /&gt;
        {prefix = &#039;subheader&#039;, depend = {&#039;subheaderstyle&#039;, &#039;subheaderrowclass&#039;}}&lt;br /&gt;
    }, 10)&lt;br /&gt;
    preprocessSingleArg(&#039;subheaderstyle&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;subheaderclass&#039;)&lt;br /&gt;
    preprocessArgs({&lt;br /&gt;
        {prefix = &#039;image&#039;, depend = {&#039;caption&#039;, &#039;imagerowclass&#039;}}&lt;br /&gt;
    }, 10)&lt;br /&gt;
    preprocessSingleArg(&#039;captionstyle&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;imagestyle&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;imageclass&#039;)&lt;br /&gt;
    preprocessArgs({&lt;br /&gt;
        {prefix = &#039;header&#039;},&lt;br /&gt;
        {prefix = &#039;data&#039;, depend = {&#039;label&#039;}},&lt;br /&gt;
        {prefix = &#039;rowclass&#039;},&lt;br /&gt;
        {prefix = &#039;rowstyle&#039;},&lt;br /&gt;
        {prefix = &#039;rowcellstyle&#039;},&lt;br /&gt;
        {prefix = &#039;class&#039;},&lt;br /&gt;
        {prefix = &#039;dataid&#039;},&lt;br /&gt;
        {prefix = &#039;labelid&#039;},&lt;br /&gt;
        {prefix = &#039;headerid&#039;},&lt;br /&gt;
        {prefix = &#039;rowid&#039;}&lt;br /&gt;
    }, 50)&lt;br /&gt;
    preprocessSingleArg(&#039;headerclass&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;headerstyle&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;labelstyle&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;datastyle&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;below&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;belowclass&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;belowstyle&#039;)&lt;br /&gt;
    preprocessSingleArg(&#039;name&#039;)&lt;br /&gt;
    args[&#039;italic title&#039;] = origArgs[&#039;italic title&#039;] -- different behaviour if blank or absent&lt;br /&gt;
    preprocessSingleArg(&#039;decat&#039;)&lt;br /&gt;
 &lt;br /&gt;
    return _infobox()&lt;br /&gt;
end&lt;br /&gt;
 &lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Tlsp&amp;diff=1251</id>
		<title>Template:Tlsp</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Tlsp&amp;diff=1251"/>
		<updated>2018-04-08T13:35:35Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{[[Wikipedia:Substitution|subst]]:[[{{ns:Template}}:{{{1|Tlsp}}}|{{{1|Tlsp}}}]]{{#if:{{{2|}}}|&amp;amp;#124;{{{2}}}}}{{#if:{{{3|}}}|&amp;amp;#124;{{{3}}}}}{{#if:{{{4|}}}|&amp;amp;#124;{{{4}}}}}{{#if:{{{5|}}}|&amp;amp;#124;{{{5}}}}}{{#if:{{{6|}}}|&amp;amp;#124;{{{6}}}}}{{#if:{{{subst|}}}|&amp;amp;#124;subst={{{subst}}}}}}}{{#if:{{{7|}}}|{{error|{{tl|tlsp}} only supports up to 5 template parameters}}}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:TemplateDataHeader&amp;diff=1249</id>
		<title>Template:TemplateDataHeader</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:TemplateDataHeader&amp;diff=1249"/>
		<updated>2018-04-08T13:35:34Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Template:TemplateData header]]&lt;br /&gt;
{{R from move}}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Str_left&amp;diff=1247</id>
		<title>Template:Str left</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Str_left&amp;diff=1247"/>
		<updated>2018-04-08T13:35:34Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;{{safesubst:padleft:|{{{2|1}}}|{{{1}}}}}&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>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Str_endswith&amp;diff=1245</id>
		<title>Template:Str endswith</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Str_endswith&amp;diff=1245"/>
		<updated>2018-04-08T13:35:34Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{#invoke:Str endswith|main}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Str_crop&amp;diff=1243</id>
		<title>Template:Str crop</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Str_crop&amp;diff=1243"/>
		<updated>2018-04-08T13:35:34Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;{{safesubst:#invoke:String | sub | s={{{1|}}} | 1 | {{safesubst:#expr: -{{{2|1}}} - 1}} | ignore_errors=true }}&amp;lt;/includeonly&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Significant_figures/rnd&amp;diff=1241</id>
		<title>Template:Significant figures/rnd</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Significant_figures/rnd&amp;diff=1241"/>
		<updated>2018-04-08T13:35:33Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;{{rnd|{{{1}}}|{{{2}}}-{{{3}}}-1}}&amp;lt;/includeonly&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{doc|content=&lt;br /&gt;
A rounding subtemplate, it calls {{tl|rnd}}.&lt;br /&gt;
&lt;br /&gt;
Examples:&lt;br /&gt;
*{{xpd5op3p3p3c|d=||||||sigfig/rnd|123.456|||7|||2}}&lt;br /&gt;
*{{xpd5op3p3p3c|d=||||||sigfig/rnd|123.456|||6|||2}}&lt;br /&gt;
*{{xpd5op3p3p3c|d=||||||sigfig/rnd|123.456|||5|||2}}&lt;br /&gt;
*{{xpd5op3p3p3c|d=||||||sigfig/rnd|123.456|||4|||2}}&lt;br /&gt;
*{{xpd5op3p3p3c|d=||||||sigfig/rnd|123.456|||3|||2}}&lt;br /&gt;
*{{xpd5op3p3p3c|d=||||||sigfig/rnd|123.456|||2|||2}}&lt;br /&gt;
*{{xpd5op3p3p3c|d=||||||sigfig/rnd|123.456|||1|||2}}&lt;br /&gt;
*{{xpd5op3p3p3c|d=||||||sigfig/rnd|123.456|||0|||2}}&lt;br /&gt;
&lt;br /&gt;
[[Category:Subtemplates of template sigfig|rnd]]&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Significant_figures&amp;diff=1239</id>
		<title>Template:Significant figures</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Significant_figures&amp;diff=1239"/>
		<updated>2018-04-08T13:35:33Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{#ifeq:{{{1&amp;lt;noinclude&amp;gt;|0&amp;lt;/noinclude&amp;gt;}}}|0&lt;br /&gt;
 |0&lt;br /&gt;
 |{{significant figures/{{#if:{{{2|}}}&lt;br /&gt;
   |rnd&lt;br /&gt;
   |sum&lt;br /&gt;
  }}&lt;br /&gt;
  |1={{formatnum:{{{1}}}|R}}&lt;br /&gt;
  |2={{{2}}}&lt;br /&gt;
  |3={{Order of magnitude|{{formatnum:{{{1}}}|R}}}}&lt;br /&gt;
 }}&lt;br /&gt;
}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Sigfig&amp;diff=1237</id>
		<title>Template:Sigfig</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Sigfig&amp;diff=1237"/>
		<updated>2018-04-08T13:35:33Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Template:Significant figures]]&lt;br /&gt;
&lt;br /&gt;
{{Redirect category shell|&lt;br /&gt;
{{R from move}}&lt;br /&gt;
{{R from template shortcut}}&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Rnd&amp;diff=1235</id>
		<title>Template:Rnd</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Rnd&amp;diff=1235"/>
		<updated>2018-04-08T13:35:33Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;{{#iferror:{{#expr:{{{2|0}}}}} |&lt;br /&gt;
  [[Category:Pages with bad rounding precision]]{{hid|Bad rounding here}}&amp;lt;!--&lt;br /&gt;
  --&amp;gt;{{#invoke:Math|precision_format| {{{1}}} | 1-{{order of magnitude|{{{1}}}}} }}|&lt;br /&gt;
  {{#invoke:Math|precision_format| {{{1}}} | {{{2|0}}}}}}}&amp;lt;/includeonly&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Para&amp;diff=1233</id>
		<title>Template:Para</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Para&amp;diff=1233"/>
		<updated>2018-04-08T13:35:33Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;code class=&amp;quot;nowrap&amp;quot; {{#if:{{{plain|}}}|style=&amp;quot;border:none;background-color:inherit;color:inherit;&amp;quot;}}&amp;gt;&amp;amp;#124;{{#if:{{{1|}}}|{{{1}}}&amp;amp;#61;}}{{{2|}}}&amp;lt;/code&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{Documentation}}&lt;br /&gt;
&amp;lt;!--Categories and interwikis go near the bottom of the /doc subpage.--&amp;gt;&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Order_of_magnitude&amp;diff=1231</id>
		<title>Template:Order of magnitude</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Order_of_magnitude&amp;diff=1231"/>
		<updated>2018-04-08T13:35:32Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;includeonly&amp;gt;{{{{{|safesubst:}}}#ifexpr:{{{1|0}}}=0&lt;br /&gt;
   |{{{{{|safesubst:}}}#ifexpr:abs{{{1|0}}}1=1&lt;br /&gt;
      |0&lt;br /&gt;
      |{{{{{|safesubst:}}}#expr:floor((ln(abs{{{1}}}1)/ln10)+1)}}&lt;br /&gt;
    }}&lt;br /&gt;
   |{{#expr:floor((ln(abs({{{1|0}}}) )/ln 10)+1E((abs{{{1|0}}}&amp;gt;1E100 or abs{{{1|0}}}&amp;lt;1E-100)-14))}}&lt;br /&gt;
}}&amp;lt;/includeonly&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Lorem_ipsum&amp;diff=1229</id>
		<title>Template:Lorem ipsum</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Lorem_ipsum&amp;diff=1229"/>
		<updated>2018-04-08T13:35:32Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;0|{{{2|}}}{{{{{|safesubst:}}}#ifeq:{{{link|{{{4}}}}}}|yes|[[Lorem ipsum]]|Lorem ipsum}} dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.{{{3|}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;1|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{2|}}}Curabitur pretium tincidunt lacus. Nulla gravida orci a odio. Nullam varius, turpis et commodo pharetra, est eros bibendum elit, nec luctus magna felis sollicitudin mauris. Integer in mauris eu nibh euismod gravida. Duis ac tellus et risus vulputate vehicula. Donec lobortis risus a elit. Etiam tempor. Ut ullamcorper, ligula eu tempor congue, eros est euismod turpis, id tincidunt sapien risus a quam. Maecenas fermentum consequat mi. Donec fermentum. Pellentesque malesuada nulla a mi. Duis sapien sem, aliquet nec, commodo eget, consequat quis, neque. Aliquam faucibus, elit ut dictum aliquet, felis nisl adipiscing sapien, sed malesuada diam lacus eget erat. Cras mollis scelerisque nunc. Nullam arcu. Aliquam consequat. Curabitur augue lorem, dapibus quis, laoreet et, pretium ac, nisi. Aenean magna nisl, mollis quis, molestie eu, feugiat in, orci. In hac habitasse platea dictumst.{{{3|}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;2|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{2|}}}Fusce convallis, mauris imperdiet gravida bibendum, nisl turpis suscipit mauris, sed placerat ipsum urna sed risus. In convallis tellus a mauris. Curabitur non elit ut libero tristique sodales. Mauris a lacus. Donec mattis semper leo. In hac habitasse platea dictumst. Vivamus facilisis diam at odio. Mauris dictum, nisi eget consequat elementum, lacus ligula molestie metus, non feugiat orci magna ac sem. Donec turpis. Donec vitae metus. Morbi tristique neque eu mauris. Quisque gravida ipsum non sapien. Proin turpis lacus, scelerisque vitae, elementum at, lobortis ac, quam. Aliquam dictum eleifend risus. In hac habitasse platea dictumst. Etiam sit amet diam. Suspendisse odio. Suspendisse nunc. In semper bibendum libero.{{{3|}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;3|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{2|}}}Proin nonummy, lacus eget pulvinar lacinia, pede felis dignissim leo, vitae tristique magna lacus sit amet eros. Nullam ornare. Praesent odio ligula, dapibus sed, tincidunt eget, dictum ac, nibh. Nam quis lacus. Nunc eleifend molestie velit. Morbi lobortis quam eu velit. Donec euismod vestibulum massa. Donec non lectus. Aliquam commodo lacus sit amet nulla. Cras dignissim elit et augue. Nullam non diam. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. In hac habitasse platea dictumst. Aenean vestibulum. Sed lobortis elit quis lectus. Nunc sed lacus at augue bibendum dapibus.{{{3|}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;4|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{2|}}}Aliquam vehicula sem ut pede. Cras purus lectus, egestas eu, vehicula at, imperdiet sed, nibh. Morbi consectetuer luctus felis. Donec vitae nisi. Aliquam tincidunt feugiat elit. Duis sed elit ut turpis ullamcorper feugiat. Praesent pretium, mauris sed fermentum hendrerit, nulla lorem iaculis magna, pulvinar scelerisque urna tellus a justo. Suspendisse pulvinar massa in metus. Duis quis quam. Proin justo. Curabitur ac sapien. Nam erat. Praesent ut quam.{{{3|}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;5|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{2|}}}Vivamus commodo, augue et laoreet euismod, sem sapien tempor dolor, ac egestas sem ligula quis lacus. Donec vestibulum tortor ac lacus. Sed posuere vestibulum nisl. Curabitur eleifend fermentum justo. Nullam imperdiet. Integer sit amet mauris imperdiet risus sollicitudin rutrum. Ut vitae turpis. Nulla facilisi. Quisque tortor velit, scelerisque et, facilisis vel, tempor sed, urna. Vivamus nulla elit, vestibulum eget, semper et, scelerisque eget, lacus. Pellentesque viverra purus. Quisque elit. Donec ut dolor.{{{3|}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;6|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{2|}}}Duis volutpat elit et erat. In at nulla at nisl condimentum aliquet. Quisque elementum pharetra lacus. Nunc gravida arcu eget nunc. Nulla iaculis egestas magna. Aliquam erat volutpat. Sed pellentesque orci. Etiam lacus lorem, iaculis sit amet, pharetra quis, imperdiet sit amet, lectus. Integer quis elit ac mi aliquam pretium. Nullam mauris orci, porttitor eget, sollicitudin non, vulputate id, risus. Donec varius enim nec sem. Nam aliquam lacinia enim. Quisque eget lorem eu purus dignissim ultricies. Fusce porttitor hendrerit ante. Mauris urna diam, cursus id, mattis eget, tempus sit amet, risus. Curabitur eu felis. Sed eu mi. Nullam lectus mauris, luctus a, mattis ac, tempus non, leo. Cras mi nulla, rhoncus id, laoreet ut, ultricies id, odio.{{{3|}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;7|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{2|}}}Donec imperdiet. Vestibulum auctor tortor at orci. Integer semper, nisi eget suscipit eleifend, erat nisl hendrerit justo, eget vestibulum lorem justo ac leo. Integer sem velit, pharetra in, fringilla eu, fermentum id, felis. Vestibulum sed felis. In elit. Praesent et pede vel ante dapibus condimentum. Donec magna. Quisque id risus. Mauris vulputate pellentesque leo. Duis vulputate, ligula at venenatis tincidunt, orci nunc interdum leo, ac egestas elit sem ut lacus. Etiam non diam quis arcu egestas commodo. Curabitur nec massa ac massa gravida condimentum. Aenean id libero. Pellentesque vitae tellus. Fusce lectus est, accumsan ac, bibendum sed, porta eget, augue. Etiam faucibus. Quisque tempus purus eu ante.{{{3|}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;8|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{2|}}}Vestibulum sapien nisl, ornare auctor, consectetuer quis, posuere tristique, odio. Fusce ultrices ullamcorper odio. Ut augue nulla, interdum at, adipiscing non, tristique eget, neque. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Ut pede est, condimentum id, scelerisque ac, malesuada non, quam. Proin eu ligula ac sapien suscipit blandit. Suspendisse euismod. Ut accumsan, neque id gravida luctus, arcu pede sodales felis, vel blandit massa arcu eget ligula. Aenean sed turpis. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Donec sem eros, ornare ut, commodo eu, tempor nec, risus. Donec laoreet dapibus ligula. Praesent orci leo, bibendum nec, ornare et, nonummy in, elit. Donec interdum feugiat leo. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Pellentesque feugiat ullamcorper ipsum. Donec convallis tincidunt urna.{{{3|}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;9|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{2|}}}Suspendisse et orci et arcu porttitor pellentesque. Sed lacus nunc, fermentum vel, vehicula in, imperdiet eget, urna. Nam consectetuer euismod nunc. Nulla dignissim posuere nulla. Integer iaculis lacinia massa. Nullam sapien augue, condimentum vel, venenatis id, rhoncus pellentesque, sapien. Donec sed ipsum ultrices turpis consectetuer imperdiet. Duis et ipsum ac nisl laoreet commodo. Mauris eu est. Suspendisse id turpis quis orci euismod consequat. Donec tellus mi, luctus sit amet, ultrices a, convallis eu, lorem. Proin faucibus convallis elit. Maecenas rhoncus arcu at arcu. Proin libero. Proin adipiscing. In quis lorem vitae elit consectetuer pretium. Nullam ligula urna, adipiscing nec, iaculis ut, elementum non, turpis. Fusce pulvinar.{{{3|}}}}}}}}}}}}}}}}}}}}}{{{{{|safesubst:}}}#ifexpr:{{{1|1}}}&amp;gt;10|{{{{{|safesubst:}}}#ifeq:x{{{3|}}}x|x x||{{{{{|safesubst:}}}#if:{{{2|}}}||&amp;lt;nowiki&amp;gt;&amp;lt;/nowiki&amp;gt;}}}}&lt;br /&gt;
&lt;br /&gt;
{{{{{|safesubst:}}}Lorem ipsum/more|{{{{{|safesubst:}}}#expr:{{{1|1}}}-10}}|{{{2|}}}|{{{3|}}}}}}}{{{{{|safesubst:}}}#ifeq:{{{cat|}}}|no||{{Template:Main other|[[Category:Wikipedia articles containing placeholders]]}}}}}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{Documentation}}&lt;br /&gt;
&amp;lt;!-- PLEASE ADD CATEGORIES TO THE /doc SUBPAGE, AND INTERWIKIS TO WIKIDATA, THANKS --&amp;gt;&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Infobox&amp;diff=1227</id>
		<title>Template:Infobox</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Infobox&amp;diff=1227"/>
		<updated>2018-04-08T13:35:31Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{#invoke:Infobox|infobox}}&amp;lt;includeonly&amp;gt;{{#ifeq:{{NAMESPACE}}|Template|{{#ifeq:{{str left|{{SUBPAGENAME}}|7}}|Infobox|[[Category:Infobox templates|{{remove first word|{{SUBPAGENAME}}}}]]}}}}&amp;lt;/includeonly&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;!-- Categories go in the /doc subpage, and interwikis go in Wikidata. --&amp;gt;&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:High-use/num&amp;diff=1225</id>
		<title>Template:High-use/num</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:High-use/num&amp;diff=1225"/>
		<updated>2018-04-08T13:35:31Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{#iferror:{{#expr:0+{{{1}}}*1}}|many|approximately {{sigfig|{{{1}}}|2}}}}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:High-use&amp;diff=1223</id>
		<title>Template:High-use</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:High-use&amp;diff=1223"/>
		<updated>2018-04-08T13:35:31Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Ombox&lt;br /&gt;
| type  = style&lt;br /&gt;
| image = [[File:Ambox warning yellow.svg|40px|alt=Warning|link=]]&lt;br /&gt;
| text  = &lt;br /&gt;
&#039;&#039;&#039;This {{#switch:{{NAMESPACE}}|Module=Lua module|#default=template}} is used on [https://tools.wmflabs.org/templatecount/index.php?lang=en&amp;amp;namespace={{NAMESPACENUMBER:{{FULLPAGENAME}}}}&amp;amp;name={{urlencode:{{&lt;br /&gt;
#switch: {{SUBPAGENAME}}&lt;br /&gt;
| doc | sandbox = {{BASEPAGENAME}}&lt;br /&gt;
| #default      = {{PAGENAME}}&lt;br /&gt;
}}}} {{High-use/num|1={{formatnum:{{#ifeq:{{str endswith|{{{1}}}|+}}|yes|{{str crop|{{{1}}}|1}}|{{{1}}}}}|R}}}} pages]&#039;&#039;&#039;, so changes to it will be widely noticed. Please test any changes in the {{#switch:{{NAMESPACE}}|Module=module&#039;s|#default=template&#039;s}} [[{{#switch: {{SUBPAGENAME}}&lt;br /&gt;
    | doc | sandbox = {{SUBJECTSPACE}}:{{BASEPAGENAME}}&lt;br /&gt;
    | #default =      {{SUBJECTPAGENAME}}&lt;br /&gt;
   }}/sandbox|/sandbox]] or [[{{#switch: {{SUBPAGENAME}}&lt;br /&gt;
    | doc | sandbox = {{SUBJECTSPACE}}:{{BASEPAGENAME}}&lt;br /&gt;
    | #default =      {{SUBJECTPAGENAME}}&lt;br /&gt;
   }}/testcases|/testcases]] subpages{{#switch:{{NAMESPACE}}|Module=.|#default=, or in your own [[Wikipedia:Subpages#How to create user subpages|user subpage]].}} Please consider discussing changes {{#if:{{{2|}}}|at [[{{{2}}}]]|on the [[{{#switch: {{SUBPAGENAME}}&lt;br /&gt;
    | doc | sandbox = {{TALKSPACE}}:{{BASEPAGENAME}}&lt;br /&gt;
    | #default =      {{TALKPAGENAME}}&lt;br /&gt;
   }}|talk page]]}} before implementing them.&lt;br /&gt;
}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{Documentation}}&lt;br /&gt;
&amp;lt;!-- Add categories to the /doc subpage; interwiki links go to Wikidata, thank you! --&amp;gt;&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Collapse_Templates&amp;diff=1221</id>
		<title>Template:Collapse Templates</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Collapse_Templates&amp;diff=1221"/>
		<updated>2018-04-08T13:35:30Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Infobox&lt;br /&gt;
| bodyclass = nowrap&lt;br /&gt;
| bodystyle = width:auto;padding-bottom:0.6em;line-height:1.25em;&lt;br /&gt;
| abovestyle = font-size:inherit;&lt;br /&gt;
| above = &amp;lt;u&amp;gt;Collapse Templates&amp;lt;/u&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
| labelstyle = margin:0;padding:0 0.3em 0;text-align:center;font-weight:normal;&lt;br /&gt;
| datastyle = margin:0;padding:0 0.5em 0 0;&lt;br /&gt;
&lt;br /&gt;
|header1 = Basic Collapse&lt;br /&gt;
 | label2 = {{tl|Collapse top}}&lt;br /&gt;
 |  data2 = Top&lt;br /&gt;
 |header3 = &lt;br /&gt;
 | label3 = {{tl|Collapse bottom}}  &lt;br /&gt;
 |  data3 = Bottom&lt;br /&gt;
 |header4 = &lt;br /&gt;
 | label4 = {{tl|Collapse}}   &lt;br /&gt;
 |  data4 = Both &lt;br /&gt;
 |header5 = Discussion Collapse&lt;br /&gt;
 | label6 = {{tl|Discussion top}} &lt;br /&gt;
 |  data6 = Top&lt;br /&gt;
 |header6 = &lt;br /&gt;
 | label7 = {{tl|Discussion bottom}} &lt;br /&gt;
 |  data7 = Bottom&lt;br /&gt;
 |header8 =&lt;br /&gt;
 | label8 = {{tl|Hidden archive top}}  &lt;br /&gt;
 |  data8 = Top&lt;br /&gt;
 |header9 = &lt;br /&gt;
 | label9 = {{tl|Hidden archive bottom}} &lt;br /&gt;
 |  data9 = Bottom&lt;br /&gt;
 |header10 = Hidden Collapse&lt;br /&gt;
 | label11 = {{tl|Hidden begin}} &lt;br /&gt;
 |  data11 = Top&lt;br /&gt;
 |header12 =&lt;br /&gt;
 | label12 = {{tl|Hidden end}}  &lt;br /&gt;
 |  data12 = Bottom&lt;br /&gt;
 |header13 = &lt;br /&gt;
 | label13 = {{tl|Hidden}} &lt;br /&gt;
 |  data13 = Both&lt;br /&gt;
 |header14 = Collapsible List&lt;br /&gt;
 | label15 = {{tl|Collapsible list}} &lt;br /&gt;
 |  data15 = Both&lt;br /&gt;
 |header16 = &lt;br /&gt;
 | label16 = {{tl|Drop down list}}&lt;br /&gt;
 |  data16 = Both&lt;br /&gt;
}}&lt;br /&gt;
&amp;lt;noinclude&amp;gt;{{documentation|content=&lt;br /&gt;
Used by all collapse templates to show a navbox.}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Collapse/doc&amp;diff=1219</id>
		<title>Template:Collapse/doc</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Collapse/doc&amp;diff=1219"/>
		<updated>2018-04-08T13:35:30Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Documentation subpage}}&lt;br /&gt;
{{High-use|2,900+}}&lt;br /&gt;
&lt;br /&gt;
{{Template:Collapse Templates}}&lt;br /&gt;
&lt;br /&gt;
The {{tlx|collapse|&amp;lt;nowiki&amp;gt;folding text&amp;lt;/nowiki&amp;gt;}} template is used for placing collapse boxes around &#039;&#039;short&#039;&#039; discussions and bits of discussions. To fold &#039;&#039;long&#039;&#039; discussion threads, use {{tlx|Collapse top}}&amp;lt;code&amp;gt;... lots of text ...&amp;lt;/code&amp;gt;{{tlx|Collapse bottom}}.&lt;br /&gt;
&lt;br /&gt;
This template should only be used in accordance with the [[Wikipedia:refactoring]] guideline; it should never be used to end a discussion over the objections of other editors, except in cases of unambiguous disruptive editing.&lt;br /&gt;
&lt;br /&gt;
Do not hide content in articles. This violates the [[WP:Manual of Style#Scrolling lists and collapsible content]] and [[WP:Accessibility]] guidelines.&lt;br /&gt;
&lt;br /&gt;
== Usage ==&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;&#039;&#039;Note: {{Tl|Collapse}} needs to be [[Wikipedia:Substitution|substed]] in order for the time stamp functionality to work properly.&#039;&#039;&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
{{Tlx|Collapse|1&amp;amp;#61;&amp;lt;var&amp;gt;Discussion text to be put into box.&amp;lt;/var&amp;gt;|2&amp;amp;#61;&amp;lt;var&amp;gt;Optional custom heading&amp;lt;/var&amp;gt;}}&lt;br /&gt;
&lt;br /&gt;
It is definitely safest to use the named {{para|1}} and {{para|2}} parameters, because otherwise any &amp;quot;=&amp;quot; character will break the template.&lt;br /&gt;
&lt;br /&gt;
=== The &amp;lt;code&amp;gt;bg&amp;lt;/code&amp;gt; parameter ===&lt;br /&gt;
&lt;br /&gt;
The &amp;lt;code&amp;gt;bg&amp;lt;/code&amp;gt; parameter is optional. It changes the background color. Use [[Web color]] values (e.g. &amp;lt;code&amp;gt;#F0F2F5&amp;lt;/code&amp;gt;).&lt;br /&gt;
&lt;br /&gt;
;Example:&lt;br /&gt;
 &lt;br /&gt;
&amp;lt;code&amp;gt;{&amp;lt;nowiki /&amp;gt;{Collapse|1=&amp;lt;var&amp;gt;Discussion text to be put into box.&amp;lt;/var&amp;gt;|bg=#F0F2F5}&amp;lt;nowiki /&amp;gt;}&amp;lt;/code&amp;gt; creates:&lt;br /&gt;
&lt;br /&gt;
{{Collapse|1=Discussion text to be put into box.|bg=#F0F2F5}}&lt;br /&gt;
&lt;br /&gt;
=== The &amp;lt;code&amp;gt;padding&amp;lt;/code&amp;gt; parameter ===&lt;br /&gt;
The &amp;lt;code&amp;gt;padding&amp;lt;/code&amp;gt; parameter adjusts the amount of cell padding (defaults to &amp;lt;code&amp;gt;8px&amp;lt;/code&amp;gt;):&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;{&amp;lt;nowiki /&amp;gt;{Collapse|1=&amp;lt;var&amp;gt;Discussion text to be put into box.&amp;lt;/var&amp;gt;|padding=20px}&amp;lt;nowiki /&amp;gt;}&amp;lt;/code&amp;gt; creates the following (expand the box to see the border padding effect):&lt;br /&gt;
&lt;br /&gt;
{{Collapse|1=Discussion text to be put into box.|padding=20px}}&lt;br /&gt;
&lt;br /&gt;
=== The &amp;lt;code&amp;gt;float&amp;lt;/code&amp;gt; parameter ===&lt;br /&gt;
The &amp;lt;code&amp;gt;float&amp;lt;/code&amp;gt; parameter allows the collapsed content to float to the left, right, or center of the page (defaults to &amp;lt;code&amp;gt;none&amp;lt;/code&amp;gt; with &amp;lt;code&amp;gt;width = 100%&amp;lt;/code&amp;gt;):&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{&amp;lt;/nowiki&amp;gt;Collapse|1=&amp;lt;var&amp;gt;Discussion text to be put into box.&amp;lt;/var&amp;gt;|float=center&amp;lt;nowiki&amp;gt;}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; creates the following:&lt;br /&gt;
&lt;br /&gt;
{{Collapse|1=Discussion text to be put into box.|float=center}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{&amp;lt;/nowiki&amp;gt;Collapse|1=&amp;lt;var&amp;gt;Discussion text to be put into box.&amp;lt;/var&amp;gt;|float=center|width=30em&amp;lt;nowiki&amp;gt;}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; creates the following:&lt;br /&gt;
&lt;br /&gt;
{{Collapse|1=Discussion text to be put into box.|float=center|width=30em}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{&amp;lt;/nowiki&amp;gt;Collapse|1=&amp;lt;var&amp;gt;Discussion text to be put into box.&amp;lt;/var&amp;gt;|float=left|width=30em&amp;lt;nowiki&amp;gt;}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; creates the following:&lt;br /&gt;
&lt;br /&gt;
{{Collapse|1=Discussion text to be put into box.|float=left|width=30em}}&lt;br /&gt;
{{clear}}&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{&amp;lt;/nowiki&amp;gt;Collapse|1=&amp;lt;var&amp;gt;Discussion text to be put into box.&amp;lt;/var&amp;gt;|float=right|width=30em&amp;lt;nowiki&amp;gt;}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; creates the following:&lt;br /&gt;
&lt;br /&gt;
{{Collapse|1=Discussion text to be put into box.|float=right|width=30em}}&lt;br /&gt;
{{clear}}&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;{{&amp;lt;/nowiki&amp;gt;Collapse|1=&amp;lt;var&amp;gt;Discussion text to be put into box.&amp;lt;/var&amp;gt;|float=none|width=30em&amp;lt;nowiki&amp;gt;}}&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; creates the following:&lt;br /&gt;
&lt;br /&gt;
{{Collapse|1=Discussion text to be put into box.|float=none|width=30em}}&lt;br /&gt;
&lt;br /&gt;
=== Around header text ===&lt;br /&gt;
&lt;br /&gt;
When used with a section of text, include the section header in the collapsed portion of text. For example, given:&lt;br /&gt;
&lt;br /&gt;
{| style=&amp;quot;background-color: lavender&amp;quot;&lt;br /&gt;
| Example text|&amp;amp;#x3d;&amp;amp;#x3d; [[Help:Section|Heading]] &amp;amp;#x3d;&amp;amp;#x3d;&amp;lt;br /&amp;gt;{{Lorem ipsum}}&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Replace with:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;{{Tlsp|Collapse|1&amp;amp;#61;{{Lorem ipsum}}|2&amp;amp;#61;[[Help:Section|Heading]]}}&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===The &amp;lt;code&amp;gt;expand&amp;lt;/code&amp;gt; parameter===&lt;br /&gt;
Simply add {{para|expand|yes}} to have the box show up in expanded form with a &amp;quot;hide&amp;quot; link, instead of collapsed form with a &amp;quot;show&amp;quot; link. Other options: {{para|expand|}} &amp;lt;code&amp;gt;yes, y, expand, expanded, uncollapse, uncollapsed&amp;lt;/code&amp;gt;. Note: {{para|expand|no}} will fold the box (default).&lt;br /&gt;
&lt;br /&gt;
===The &amp;lt;code&amp;gt;clear&amp;lt;/code&amp;gt; parameter===&lt;br /&gt;
In some situations you may not want the default &amp;lt;code&amp;gt;clear: both;&amp;lt;/code&amp;gt; CSS to apply, which puts the collapse box below any left- or right-floated content within the same HTML block. In this case, you can use {{para|clear|none}}, {{para|clear|right}}, or {{para|clear|left}}, as needed.&lt;br /&gt;
&lt;br /&gt;
===When content includes tables===&lt;br /&gt;
This template frequently breaks when used around content that consists of or includes [[Help:Table|wikitables]].  Such content can be made collapsible by using the {{tlx|collapse top}} and {{tlx|collapse bottom}} templates instead of {{tlx|collapse}}. &lt;br /&gt;
&lt;br /&gt;
If you want to collapse only the table and not other content, you can do this using wikitable parameters. See the [[Help:Collapsing#Collapsing tables by default|Collapsing tables]] guide for help.&lt;br /&gt;
&lt;br /&gt;
==TemplateData==&lt;br /&gt;
{{TemplateDataHeader}}&lt;br /&gt;
&amp;lt;templatedata&amp;gt;&lt;br /&gt;
{&lt;br /&gt;
	&amp;quot;description&amp;quot;: &amp;quot;Creates a collapsible box that allows its content to be hidden or revealed on user&#039;s command. It is used to reduce clutter.&amp;quot;,&lt;br /&gt;
	&amp;quot;params&amp;quot;: {&lt;br /&gt;
		&amp;quot;1&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Contents&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;Contents of the box&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;content&amp;quot;,&lt;br /&gt;
			&amp;quot;required&amp;quot;: true&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;2&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Title&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;Text of title bar. Defaults to \&amp;quot;Extended contents\&amp;quot;.&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;string&amp;quot;,&lt;br /&gt;
			&amp;quot;suggested&amp;quot;: true,&lt;br /&gt;
			&amp;quot;aliases&amp;quot;: [&lt;br /&gt;
				&amp;quot;title&amp;quot;,&lt;br /&gt;
				&amp;quot;heading&amp;quot;,&lt;br /&gt;
				&amp;quot;header&amp;quot;&lt;br /&gt;
			],&lt;br /&gt;
			&amp;quot;default&amp;quot;: &amp;quot;Extended content&amp;quot;&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;expand&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Expanded by default?&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;Setting to \&amp;quot;yes, y, expand, uncollapse\&amp;quot;) will cause the box to show its contents by default. Any other value (and omitting this parameter) causes the box to be collapsed by default (its contents hidden).&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;string&amp;quot;,&lt;br /&gt;
			&amp;quot;default&amp;quot;: &amp;quot;yes&amp;quot;&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;border&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Border width&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;Width of the outermost border. Accepts a number (e.g. 2) followed immediately with a CSS-compatible unit of measurement. (e.g. \&amp;quot;px\&amp;quot;) Example: 2px.&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;string&amp;quot;,&lt;br /&gt;
			&amp;quot;default&amp;quot;: &amp;quot;1px&amp;quot;&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;bg&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Title bar&#039;s color&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;Color of the title bar. Can be set any valid CSS color value but please take care that text would remain black.&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;string&amp;quot;,&lt;br /&gt;
			&amp;quot;aliases&amp;quot;: [&lt;br /&gt;
				&amp;quot;background&amp;quot;&lt;br /&gt;
			],&lt;br /&gt;
			&amp;quot;default&amp;quot;: &amp;quot;#CFC&amp;quot;&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;padding&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Padding&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;Width of the padding, the empty space between border and the contents. Accepts a number (e.g. 2) followed immediately with a CSS-compatible unit of measurement. (e.g. \&amp;quot;px\&amp;quot;) Example: 2px.&amp;quot;,&lt;br /&gt;
			&amp;quot;default&amp;quot;: &amp;quot;8px&amp;quot;&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;bg1&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Outer background&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;Color of the space between the inner and outer border. Can be set to any valid CSS color.&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;string&amp;quot;,&lt;br /&gt;
			&amp;quot;default&amp;quot;: &amp;quot;transparent&amp;quot;&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;b-color&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Outer border color&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;Color of the outer border. Can be any valid CSS color.&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;string&amp;quot;,&lt;br /&gt;
			&amp;quot;default&amp;quot;: &amp;quot;silver&amp;quot;&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;width&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Collapse box width.&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;The width of the entire collapsed box.&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;string&amp;quot;,&lt;br /&gt;
			&amp;quot;default&amp;quot;: &amp;quot;100%&amp;quot;&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;center&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Center-align title&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;If set to any value, the title will be centered.&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;string&amp;quot;&lt;br /&gt;
		},&lt;br /&gt;
		&amp;quot;fc&amp;quot;: {&lt;br /&gt;
			&amp;quot;label&amp;quot;: &amp;quot;Font color&amp;quot;,&lt;br /&gt;
			&amp;quot;description&amp;quot;: &amp;quot;Font color for the title. Also sets the color of the [show]/[hide] link. Can be any valid CSS color&amp;quot;,&lt;br /&gt;
			&amp;quot;type&amp;quot;: &amp;quot;string&amp;quot;&lt;br /&gt;
		}&lt;br /&gt;
	}&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/templatedata&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Re-using at other wikis ==&lt;br /&gt;
This template depends upon having rules for the three classes (collapsible, uncollapsed, and collapsed) in the appropriate CSS files, and some related JavaScript installed. This template transcludes {{tl|main other}} and {{tl|lorem ipsum}}, which should also be imported at the same time.&lt;br /&gt;
&lt;br /&gt;
For MediaWiki versions ≥ 1.18, this template can simply be exported and then imported into another MediaWiki installation. Changes to the source code that will need to be made are:&lt;br /&gt;
:* &amp;lt;code&amp;gt;class=&amp;quot;collapsible&amp;lt;/code&amp;gt; needs to be changed to &amp;lt;code&amp;gt;class=&amp;quot;mw-collapsible&amp;lt;/code&amp;gt; (probably because the class had apparently been deprecated since &#039;&#039;MediaWiki v1.20&#039;&#039;).&lt;br /&gt;
:* &amp;lt;code&amp;gt;|#default=collapsed}}&amp;lt;/code&amp;gt; changed to &amp;lt;code&amp;gt;|#default=mw-collapsed}}&amp;lt;/code&amp;gt;.&lt;br /&gt;
:* Some additional changes to the source code will need to be made in order for this template to become usable on the Main/Article (ns:0) [[mw:Help:Namespaces|namespace]].&lt;br /&gt;
&lt;br /&gt;
The toggle text can be edited at external Wiki&#039;s [[MediaWiki:Collapsible-expand]] and [[MediaWiki:Collapsible-collapse]] pages. Further information at [[mw:ResourceLoader/Modules#jquery.makeCollapsible|jquery.makeCollapsible module]].&lt;br /&gt;
&lt;br /&gt;
== See also ==&lt;br /&gt;
* {{Tl|collapse top}}&lt;br /&gt;
* {{Tl|collapse bottom}}&lt;br /&gt;
* {{tl|discussion top}}&lt;br /&gt;
* {{tl|archive top}}&lt;br /&gt;
* {{tl|hidden archive top}}&lt;br /&gt;
&lt;br /&gt;
&amp;lt;includeonly&amp;gt;&lt;br /&gt;
&amp;lt;!-- CATEGORIES AND INTERWIKIS HERE, THANKS --&amp;gt;&lt;br /&gt;
[[Category:Archival templates|{{PAGENAME}}]]&lt;br /&gt;
[[Category:Collapse templates|{{PAGENAME}}]]&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/includeonly&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Collapse&amp;diff=1217</id>
		<title>Template:Collapse</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Collapse&amp;diff=1217"/>
		<updated>2018-04-08T13:35:29Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{| &amp;lt;!-- Template:Collapse --&amp;gt; class=&amp;quot;mw-collapsible {{#switch:{{lc:{{{expand|no}}}}}|uncollapse|uncollapsed|expand|expanded|yes|y=mw-uncollapsed|#default=mw-collapsed}}&amp;quot; style=&amp;quot;{{{{{|safesubst:}}}#ifeq:{{NAMESPACEE}}|{{ns:0}}|display: none;}}background-color: {{{bg1|transparent}}}; text-align: left; border: {{{border|1px}}} solid {{{b-color|silver}}}; {{{{{|safesubst:}}}#switch:{{{float|}}}&lt;br /&gt;
| left = margin:0.2em 0.5em 0.2em 0; width:{{{{{|safesubst:}}}#if:{{{width|}}}|{{{width}}}|auto}}; float: left; clear: {{{clear|left}}}&lt;br /&gt;
| right = margin:0.2em 0 0.2em 0.5em; width:{{{{{|safesubst:}}}#if:{{{width|}}}|{{{width}}}|auto}}; float: right; clear: {{{clear|right}}}&lt;br /&gt;
| none = margin:0.2em 0; width:{{{{{|safesubst:}}}#if:{{{width|}}}|{{{width}}}|auto}}; clear: {{{clear|none}}}&lt;br /&gt;
| center | centre = margin:0.2em auto; width:{{{{{|safesubst:}}}#if:{{{width|}}}|{{{width}}}|auto}}; clear: {{{clear|both}}}&lt;br /&gt;
| #default = margin: 0.2em auto auto; width:{{{{{|safesubst:}}}#if:{{{width|}}}|{{{width}}}|100%}}; clear: {{{clear|both}}}&lt;br /&gt;
}}; padding: 1px;&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! style=&amp;quot;background-color: {{{background|{{{bg|#F0F2F5}}}}}}; font-size:87%; padding:0.2em 0.3em; text-align: {{{{{|safesubst:}}}#if:{{{left|}}}|left|{{{{{|safesubst:}}}#if:{{{center|}}}|center|left}}}}; {{{{{|safesubst:}}}#if:{{{fc|}}}|color: {{{fc}}};|}}&amp;quot; | &amp;lt;span style=&amp;quot;font-size: 115%;&amp;quot;&amp;gt;{{{2|{{{title|{{{heading|{{{header|Extended content}}}}}}}}}}}}&amp;lt;/span&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;border: solid {{{border2|1px silver}}}; padding: {{{padding|8px}}}; background-color: {{{bg2|white}}};&amp;quot; |&lt;br /&gt;
&amp;lt;div&amp;gt;{{{1&amp;lt;noinclude&amp;gt;|{{lorem ipsum|3}}&amp;lt;/noinclude&amp;gt;}}}&amp;lt;/div&amp;gt;&lt;br /&gt;
|}{{{{{|safesubst:}}}#ifeq:{{NAMESPACEE}}|{{ns:0}}|&amp;lt;span class=&amp;quot;error noprint&amp;quot;&amp;gt;[[Template:collapse]] is not available for use in articles (see [[MOS:COLLAPSE]]).&amp;lt;/span&amp;gt;}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{Documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=List_of_Oddworld_characters&amp;diff=1213</id>
		<title>List of Oddworld characters</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=List_of_Oddworld_characters&amp;diff=1213"/>
		<updated>2018-04-07T17:32:54Z</updated>

		<summary type="html">&lt;p&gt;Max: Added Fong Foo&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Character&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Species&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; class=&amp;quot;unsortable&amp;quot; | Description&lt;br /&gt;
|-&lt;br /&gt;
| [[Abraham Lure]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Alf]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Buddy]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Toby]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Soots]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Stumpy]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Weirdos]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Sam]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Big Face]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Shaman]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Ed]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Asset 98]] || [[Mudokon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Molluck]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Aslik]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Dripik]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Phleg]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Brewmaster]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Margaret]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Lulu]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Sask]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Chester Payne]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Tex]] || [[Glukkon]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Skillya]] || [[Slig]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Crig]] || [[Slig]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Wildum]] || [[Slig]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Albino Slig]] || [[Slig]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Newscaster]] || [[Slig]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Valet Slig]] || [[Slig]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Fong Foo]] || [[Slig]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Latamire Munch]] || [[Gabbit]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Raisin]] || [[Elderling]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Stranger]] || [[Steef]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Sekto]] || [[Oktigi]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Shrykull]] || Deity ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Fangus Klot]] || [[Fangustanian]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Squeek]] || Unknown ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Nod]] || Unknown ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Humphrey]] || [[Vykkers]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Irwin]] || [[Vykkers]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Headley]] || [[Vykkers]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Doc]] || [[Vykkers]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Blisterz Booty]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Boilz Booty]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Filthy Hands Floyd]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Looten Duke]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Jo&#039; Mamma]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Meagley McGraw]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Tiny]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Scuz]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Packrat Palooka]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[X&#039;Plosives McGee]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Elboze Freely]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Lefty Lugnutz]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Fatty McBoomBoom]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[D. Caste Raider]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Cleever McMince]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Nilsworth ‘Pokey’ O’Shafster]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Mortimar Bang]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Shorty]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Snapps Manic]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Gunter ‘Sparky’ VonFahrenheiten]] || [[Outlaw]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Larry Flinger]] || Unknown ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Fats Fuggler]] || Unknown ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Uncle Turkey Toes]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Billyboy]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Eugene Ius]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Professor Dimple]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Farmer Beeks]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Martha May Beeks]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Suzy Ray Beeks]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Billy Bob Warthog]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Bawhnee Sue McUgly]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Cornjaws]] || [[Clakker]] ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Skycart Joe]] || [[Clakker]] ||&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=List_of_Oddworld_species&amp;diff=1212</id>
		<title>List of Oddworld species</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=List_of_Oddworld_species&amp;diff=1212"/>
		<updated>2018-04-07T17:31:26Z</updated>

		<summary type="html">&lt;p&gt;Max: Added Devil Vine, Unidentified creatures, and Unnamed wildlife; turned species names into singular&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Species&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Faction&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Type&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; class=&amp;quot;unsortable&amp;quot; | Description&lt;br /&gt;
|-&lt;br /&gt;
| [[1%er]] || Civilized || Race || Bikers, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Bat]] || Wildlife || Wild || &lt;br /&gt;
|-&lt;br /&gt;
| [[Bee]] || Wildlife || Wild || &lt;br /&gt;
|-&lt;br /&gt;
| [[Bird]] || Wildlife || Wild || &lt;br /&gt;
|-&lt;br /&gt;
| [[Bolamite]] || Wildlife || Wild || Live Ammo&lt;br /&gt;
|-&lt;br /&gt;
| [[Boombat]] || Wildlife || Wild || Live Ammo&lt;br /&gt;
|-&lt;br /&gt;
| [[Chippunk]] || Wildlife || Wild || Live Ammo&lt;br /&gt;
|-&lt;br /&gt;
| [[Chronicler]] || Civilized || Race || Accountants, lawyers, stock brokers, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Clakker]] || Civilized || Race || Townsfolk&lt;br /&gt;
|-&lt;br /&gt;
| [[Devil Vine]] || Plant || Wild || Live Ammo, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Elderling]] || Native || Race || Prophets, advisors&lt;br /&gt;
|-&lt;br /&gt;
| [[Elums]] || Native || Domesticated || Steeds, meat&lt;br /&gt;
|-&lt;br /&gt;
| [[Fangustanian]] || Native || Race || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Fleech]] || Wildlife || Wild || Pets&lt;br /&gt;
|-&lt;br /&gt;
| [[Frogger]] || Wildlife || Wild || Sacred, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Frogger|Frogger symbiote]] || Wildlife || Wild || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Fuzzle]] || Wildlife || Wild || Lab animals, pets, meat, Live Ammo&lt;br /&gt;
|-&lt;br /&gt;
| [[Gabbit]] || Native || Race || Replacement lungs, various consumer products&lt;br /&gt;
|-&lt;br /&gt;
| [[Garbage truck creature]] || Wildlife || Domesticated || Garbage truck, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Gloktigi]] || Civilized || Race || Elite security&lt;br /&gt;
|-&lt;br /&gt;
| [[Glukkon]] || Civilized || Race || Business executives&lt;br /&gt;
|-&lt;br /&gt;
| [[Grubb]] || Native || Race || &lt;br /&gt;
|-&lt;br /&gt;
| [[Guardian]] || Native || Wild || Defence, sacred, extinct&lt;br /&gt;
|-&lt;br /&gt;
| [[Heyhey]] || Civilized || Race || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Hint Fly]] || Wildlife || Wild || &lt;br /&gt;
|-&lt;br /&gt;
| [[Intern]] || Civilized || Race || Lab assistants, security&lt;br /&gt;
|-&lt;br /&gt;
| [[Khanzumer]] || Civilized || Race || Consumers, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Kinto]] || Wildlife || Wild || Slaves, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Kinto|Kinto slaver]] || Civilized || Race || Slavers, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Lusk]] || Unknown || Race || Marauders, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Meech]] || Wildlife || Wild || Meat, sacred, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Meep]] || Native || Domesticated || Meat&lt;br /&gt;
|-&lt;br /&gt;
| [[Meetle]]/Mug || Wildlife || Domesticated || Transport, tanks, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Mudflub]] || Wildlife || Wild || Blubber, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Mudokon]] || Native || Race || Slave labour&lt;br /&gt;
|-&lt;br /&gt;
| [[Musklum]] || Unknown || Race || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Oktigi]] || Civilized || Race || Business executives&lt;br /&gt;
|-&lt;br /&gt;
| [[Opinionite]] || Civilized || Race || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Outlaw]] || Outlaws || Race || Outlaws&lt;br /&gt;
|-&lt;br /&gt;
| [[Paramite]] || Wildlife || Wild || Meat, sacred&lt;br /&gt;
|-&lt;br /&gt;
| [[Pokeypine]] || Wildlife || Wild || Live Ammo, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Priest]] || Civilized || Race || Priests, unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Rat]] || Wildlife || Wild || Avatars&lt;br /&gt;
|-&lt;br /&gt;
| [[Scoot]]/Worry Fish || Wildlife || Wild || &lt;br /&gt;
|-&lt;br /&gt;
| [[Scrab]] || Wildlife || Wild || Meat, sacred&lt;br /&gt;
|-&lt;br /&gt;
| [[Scuba Toad]] || Native || Race || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Sea Rex]] || Wildlife || Wild || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Skeeter]] || Wildlife || Wild || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Sleg]] || Wildlife || Wild || Pets, security&lt;br /&gt;
|-&lt;br /&gt;
| [[Slig]] || Civilized || Race || Security, personal assistants&lt;br /&gt;
|-&lt;br /&gt;
| [[Slog]] || Civilized || Domesticated || Security&lt;br /&gt;
|-&lt;br /&gt;
| [[Slurg]] || Wildlife || Wild || &lt;br /&gt;
|-&lt;br /&gt;
| [[Sniper Wasp]] || Wildlife || Wild || Live Ammo&lt;br /&gt;
|-&lt;br /&gt;
| [[Spider]] || Wildlife || Wild || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[SpooceShrub]] || Plant || Wild || Spooce&lt;br /&gt;
|-&lt;br /&gt;
| [[Stang]] || Wildlife || Wild || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Steef]] || Native || Race || &lt;br /&gt;
|-&lt;br /&gt;
| [[Stingbee]] || Wildlife || Wild || Live Ammo&lt;br /&gt;
|-&lt;br /&gt;
| [[Stunk]] || Wildlife || Wild || Live Ammo&lt;br /&gt;
|-&lt;br /&gt;
| [[Thudslug]] || Wildlife || Wild || Live Ammo&lt;br /&gt;
|-&lt;br /&gt;
| [[Unidentified creatures]] || Wildlife || Wild ||&lt;br /&gt;
|-&lt;br /&gt;
| [[Unnamed wilflife]] || Wildlife || Wild || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Vamp]] || Civilized || Race || Unused&lt;br /&gt;
|-&lt;br /&gt;
| [[Vykker]] || Civilized || Race || Doctors, researchers&lt;br /&gt;
|-&lt;br /&gt;
| [[Wolvark]] || Civilized || Race || Security&lt;br /&gt;
|-&lt;br /&gt;
| [[Zappfly]] || Wildlife || Wild || Live Ammo&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Devil_Vine&amp;diff=1211</id>
		<title>Devil Vine</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Devil_Vine&amp;diff=1211"/>
		<updated>2018-04-07T17:18:37Z</updated>

		<summary type="html">&lt;p&gt;Max: Created page with &amp;quot;A &amp;#039;&amp;#039;&amp;#039;Devil Vine&amp;#039;&amp;#039;&amp;#039; is a plant that was designed for &amp;#039;&amp;#039;Stranger’s Wrath&amp;#039;&amp;#039; as a type of Live Ammo.  According to concept art, Stranger wou...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;A &#039;&#039;&#039;Devil Vine&#039;&#039;&#039; is a [[List of Oddworld species|plant]] that was designed for &#039;&#039;[[Stranger’s Wrath]]&#039;&#039; as a type of [[Live Ammo]].&lt;br /&gt;
&lt;br /&gt;
According to concept art, Stranger would have fired an animated seed that would grow into a sentient plant. This plant would then reach towards nearby enemies and restrain them in cocoons. &lt;br /&gt;
&lt;br /&gt;
== Appearances ==&lt;br /&gt;
Concept art for the Devil Vine appears in one of the unlockable images in &#039;&#039;[[Stranger’s Wrath HD]]&#039;&#039; for [[PlayStation]] 4 and PlayStation Vita.&lt;br /&gt;
&lt;br /&gt;
== References ==&lt;br /&gt;
# &#039;&#039;&#039;Just Add Water (21/12/2011)&#039;&#039;&#039;. ‘Extras’, &#039;&#039;Oddworld: Stranger’s Wrath HD&#039;&#039;, PlayStation 4. Oddworld Inhabitants.&lt;br /&gt;
# &#039;&#039;&#039;Just Add Water (19/12/2012)&#039;&#039;&#039;. ‘Extras’, &#039;&#039;Oddworld: Stranger’s Wrath HD&#039;&#039;, PlayStation Vita. Oddworld Inhabitants.&lt;br /&gt;
[[Category:Unused species]]&lt;br /&gt;
[[Category:Live Ammo]]&lt;br /&gt;
[[Category:Plants]]&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Pokeypine&amp;diff=1210</id>
		<title>Pokeypine</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Pokeypine&amp;diff=1210"/>
		<updated>2018-04-07T15:50:44Z</updated>

		<summary type="html">&lt;p&gt;Max: Created page with &amp;quot;A &amp;#039;&amp;#039;&amp;#039;Pokeypine&amp;#039;&amp;#039;&amp;#039; is a creature that was designed for &amp;#039;&amp;#039;Stranger’s Wrath&amp;#039;&amp;#039; as a type of Live Ammo.  According to Wil Bunce-Edwards,...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;A &#039;&#039;&#039;Pokeypine&#039;&#039;&#039; is a [[List of Oddworld species|creature]] that was designed for &#039;&#039;[[Stranger’s Wrath]]&#039;&#039; as a type of [[Live Ammo]].&lt;br /&gt;
&lt;br /&gt;
According to [[Wil Bunce-Edwards]], the Pokeypine was dropped early in development and was usually refered to as ‘porcupine’ in filenames.&lt;br /&gt;
&lt;br /&gt;
== Appearances ==&lt;br /&gt;
A concept sketch, render of a 3D model, and a cartoon icon of a Pokeypine appear in one of the unlockable images in &#039;&#039;[[Stranger’s Wrath HD]]&#039;&#039; for [[PlayStation]] 4 and PlayStation Vita. The cartoon icon was used as Wil’s avatar on the [[Oddworld Forums]] for a while.&amp;lt;ref name=&amp;quot;wilAvatar&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== References ==&lt;br /&gt;
&amp;lt;references&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;wilAvatar&amp;quot;&amp;gt;&#039;&#039;&#039;Bunce-Edwards, Wil (14/05/2012)&#039;&#039;&#039;. [http://www.oddworldforums.net/showthread.php?p=540795#post540795 Post #755] in ‘Oddworld Questions &amp;amp; Answers VIII’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;/references&amp;gt;&lt;br /&gt;
[[Category:Unused species]]&lt;br /&gt;
[[Category:Live Ammo]]&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Max_the_Mug&amp;diff=1209</id>
		<title>Max the Mug</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Max_the_Mug&amp;diff=1209"/>
		<updated>2018-04-07T15:40:58Z</updated>

		<summary type="html">&lt;p&gt;Max: Max moved page Max the Mug to Wil Bunce-Edwards: No longer using the screen name Max&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Wil Bunce-Edwards]]&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Wil_Bunce-Edwards&amp;diff=1208</id>
		<title>Wil Bunce-Edwards</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Wil_Bunce-Edwards&amp;diff=1208"/>
		<updated>2018-04-07T15:40:57Z</updated>

		<summary type="html">&lt;p&gt;Max: Max moved page Max the Mug to Wil Bunce-Edwards: No longer using the screen name Max&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[File:Maxoddtour4.jpg|thumb|Max the Mug at [[OddTour#OddTour_4 | OddTour 4b]]]]&lt;br /&gt;
&#039;&#039;&#039;William Bunce-Edwards&#039;&#039;&#039; (born 7 October 1987), also known by his screen name &#039;&#039;&#039;Max the Mug&#039;&#039;&#039;, is the Studio Coordinator of [[Just Add Water]] and long-term [[Oddworld fan]]. Along with [[Xavier De Coster]] he co-owns [[Oddworld Library]] and along with [[Nathan Rose]] he co-administrates the [[Oddworld Forums]].&lt;br /&gt;
&lt;br /&gt;
== Oddworld fan ==&lt;br /&gt;
Bunce-Edwards got an original PlayStation on Christmas Day 1997, and on Boxing Day 1997 played the &#039;&#039;[[Oddworld: Abe’s Oddysee]]&#039;&#039; demo on the demo disc that came with it; he got the full game in the summer of 1998.&amp;lt;ref name=&amp;quot;fom&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;elderberries&amp;quot;/&amp;gt; It wasn’t until he recognized [[Mudokons]] in a magazine he was flicking through that he realized he was a true fan.&amp;lt;ref name=&amp;quot;fom&amp;quot;/&amp;gt; He joined the GT Interactive Software message boards in 1998 with the username &#039;&#039;&#039;skELUMton&#039;&#039;&#039; to ask what a [[Greeter]] looked like (getting &#039;&#039;[[Abe’s Exoddus]]&#039;&#039; on Easter Sunday 1999), but along with the other regular posters moved to the [[Exoddus Club]] when activity on the GTIS boards died down, joining as &#039;&#039;&#039;billy_squeek&#039;&#039;&#039; on 12 February 2000.&amp;lt;ref name=&amp;quot;toexoddusclub&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;ecmemlist&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Bunce-Edwards first came to the attention of [[Oddworld Inhabitants]] when he emailed [[Alf]] with a collated list of errors regarding the [[Oddworld Map]] and was in return made [[Fan of the Month]] February–March 2003 on the official Oddworld website.&amp;lt;ref name=&amp;quot;fom&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;firstmail&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;beforefom&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;heresfom&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;aboutfom&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;afterfom&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Bunce-Edwards has attended several [[OddTours]]: OddTour 2 in Amsterdam, 2004;&amp;lt;ref name=&amp;quot;oddtour2&amp;quot;/&amp;gt; OddTours 3a and 3b in London, 2008;&amp;lt;ref name=&amp;quot;oddtour3&amp;quot;/&amp;gt; and OddTours 4a and 4b in London, 2010.&amp;lt;ref name=&amp;quot;oddtour4&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Oddworld Forums ===&lt;br /&gt;
Bunce-Edwards joined the [[Oddworld Forums]] as &#039;&#039;&#039;Max the Meetle&#039;&#039;&#039; on 4 June 2000&amp;lt;ref name=&amp;quot;ezboardprofile&amp;quot;/&amp;gt;, changing his screen name to &#039;&#039;&#039;Max the Mug&#039;&#039;&#039; when the Forums moved to Ultimate Bulletin Board.&amp;lt;ref name=&amp;quot;newname&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Bunce-Edwards began being called ‘The Oddworld Dictionary’ and ‘The Oddworld Encyclopedia’ at least as far back as April 2001&amp;lt;ref name=&amp;quot;dannyDictionary&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;maxEnc&amp;quot;/&amp;gt;, although because the original ezboard Oddworld Forums are not well preserved the terms could pre-date this. The latter nickname became the more popular and longer lasting, being made Bunce-Edwards’s custom title around September 2002&amp;lt;ref name=&amp;quot;khanzStatus&amp;quot;/&amp;gt; and remaining in use until June 2004,&amp;lt;ref name=&amp;quot;xavSekEnc&amp;quot;/&amp;gt; after which the term was used in discussions exclusively referring to his [[Oddworld Encyclopædia|fansite]]. However, his custom status remained ‘Oddworld Encyclopædia’ until at least May 2006,&amp;lt;ref name=&amp;quot;pedstatus&amp;quot;/&amp;gt; and ‘The Oddworld Encyclopædist’ until at least May 2008.&amp;lt;ref name=&amp;quot;paedist&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Key Oddworld Forums features to which Bunce-Edwards has contributed include the current &#039;&#039;[[Stranger’s Wrath]]&#039;&#039;-themed titles&amp;lt;ref name=&amp;quot;swtitles&amp;quot;/&amp;gt;, the current Oddworld-themed reputation levels&amp;lt;ref name=&amp;quot;replevels&amp;quot;/&amp;gt; and the current Forum rules.&amp;lt;ref name=&amp;quot;rules&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Member of staff ====&lt;br /&gt;
Bunce-Edwards stopped posting on the Oddworld Forums in August 2002 in favour of [[The Glass Asylum]],&amp;lt;ref name=&amp;quot;farewell&amp;quot;/&amp;gt; but returned the following month&amp;lt;ref name=&amp;quot;owfreturn&amp;quot;/&amp;gt; having missed the Forums-wide moderator elections that saw [[Xavier De Coster]] join the moderation team;&amp;lt;ref name=&amp;quot;start2002elecs&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;end2002elecs&amp;quot;/&amp;gt; he was elected moderator of [[General Oddworld Discussion]] (and by extension the [[Spoiler Forum]]) by public election the following year.&amp;lt;ref name=&amp;quot;start2003elecs&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;end2003elecs&amp;quot;/&amp;gt; He retired from moderatorship in July 2005&amp;lt;ref name=&amp;quot;endofmod&amp;quot;/&amp;gt; only to return as a Super Moderator of Zulag One in February 2007&amp;lt;ref name=&amp;quot;smod&amp;quot;/&amp;gt; and be promoted to administrator in January 2008 to complement the Oddworld Library’s new sponsorship by the Oddworld Forums.&amp;lt;ref name=&amp;quot;admin&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|+ Sortable table&lt;br /&gt;
|-&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Role&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Forum(s)&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Appointment&lt;br /&gt;
! scope=&amp;quot;col&amp;quot; | Retirement&lt;br /&gt;
|-&lt;br /&gt;
| [[Moderator]] || [[General Oddworld Discussion]] || 16 September 2003 || 15 July 2005&lt;br /&gt;
|-&lt;br /&gt;
| [[Moderator]] || [[Spoiler Forum]] || 19 June 2004? || 15 July 2005&lt;br /&gt;
|-&lt;br /&gt;
| [[Super Moderator]] || [[Zulag One]] || 1 February 2007 || &#039;&#039;Still active&#039;&#039;&lt;br /&gt;
|-&lt;br /&gt;
| [[Oddworld Administrator]] || N/A || 15 January 2008 || &#039;&#039;Still active&#039;&#039;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
==== Annual Oddworld Forums Poster Awards ====&lt;br /&gt;
Bunce-Edwards has won the following Poster Awards in the following years:&lt;br /&gt;
&lt;br /&gt;
; [[Member With The Best Oddworld Knowledge]]&lt;br /&gt;
: [[1st Annual Oddworld Forums Poster Awards|2003]]–[[8th Annual Oddworld Forums Poster Awards|2010]]&lt;br /&gt;
; [[Best Advice Giver]]&lt;br /&gt;
: [[2nd Annual Oddworld Forums Poster Awards|2004]], [[4th Annual Oddworld Forums Poster Awards|2006]]&lt;br /&gt;
; [[Best Veteran|Best Old Dude]]&lt;br /&gt;
: [[2nd Annual Oddworld Forums Poster Awards|2004]]&lt;br /&gt;
; [[Most Meaningful Poster]]&lt;br /&gt;
: [[2nd Annual Oddworld Forums Poster Awards|2004]]–[[4th Annual Oddworld Forums Poster Awards|2006]]&lt;br /&gt;
; [[Most Dedicated Member]]&lt;br /&gt;
: [[5th Annual Oddworld Forums Poster Awards|2007]]&lt;br /&gt;
; [[Most Valuably Poster (MVP)]]&lt;br /&gt;
: [[5th Annual Oddworld Forums Poster Awards|2007]], [[8th Annual Oddworld Forums Poster Awards|2010]]&lt;br /&gt;
; [[Most Liked]]&lt;br /&gt;
: [[7th Annual Oddworld Forums Poster Awards|2009]]&lt;br /&gt;
; [[Oddworld Forums Unofficial Mascot]]&lt;br /&gt;
: [[7th Annual Oddworld Forums Poster Awards|2009]]&lt;br /&gt;
&lt;br /&gt;
=== Oddworld Library ===&lt;br /&gt;
Bunce-Edwards’s first attempt at a fansite was a 2000 webpage on Xoom called ‘The Kennels’. It took the form of a conjoined twin [[Glukkon]] called Glasp taking the reader on a tour around the Kennels, which hosted one of each [[Oddworld species|Oddworld creature]] known at the time.&amp;lt;ref name=&amp;quot;kennels&amp;quot;/&amp;gt; By 2001, the project changed to one more formally encyclopædic in nature called ‘The Scrabacombs’,&amp;lt;ref name=&amp;quot;scrabacombs&amp;quot;/&amp;gt; but by 2002 this was renamed to ‘The Oddworld Encyclopedia’ to reflect his Oddworld Forums nickname.&amp;lt;ref name=&amp;quot;websiteEnc&amp;quot;/&amp;gt; Despite numerous promises that the site was coming, only an FAQ appeared (in 2003)&amp;lt;ref name=&amp;quot;firstfaq&amp;quot;/&amp;gt; before [[The Oddworld Encyclopædia]] finally launched in April 2006—although the April Fools’ Day joke articles were little appreciated by members of the Oddworld Forums given the site’s long-awaited appearance.&amp;lt;ref name=&amp;quot;TOLlaunch&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
By this time Bunce-Edwards had already created [[OddBlog]]&amp;lt;ref name=&amp;quot;oddblog&amp;quot;/&amp;gt;—originally a personal blog but quickly evolving into an Oddworld news blog—and had made plans to have it join with [[Xavier De Coster]]’s [[TOGG]] and Oddsville’s [[Oddworld Archives]] to form ‘The Shaman Network’. Although De Coster eventually assumed Oddsville’s role of creating the Archives and most component subsites were already public, the project—incorporating The Oddworld Encyclopædia and renamed ‘[[The Oddworld Library]]’—was formally launched simultaneously with the Encyclopædia.&amp;lt;ref name=&amp;quot;TOLlaunch&amp;quot;/&amp;gt; The Oddworld Forums became a sponsor of the Oddworld Library in January 2008 by adding a link to the fansite to the top of its banner alongside links to [[Oddworld-Web]] and [[Oddworld Universe]].&amp;lt;ref name=&amp;quot;admin&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Just Add Water ==&lt;br /&gt;
Bunce-Edwards and De Coster visited the office of [[Just Add Water]] in August 2010, between [[OddTours]] 3a and 3b, meeting [[Stewart Gilray]] for the first time. Bunce-Edwards was invited back to the office in November that year where he was offered the task of looking after the [[official Oddworld Inhabitants website]] and [[Oddworld Inhabitants Facebook Page|Facebook Page]] in his spare time.&amp;lt;ref name=&amp;quot;JAW&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
At the start of August 2011, Bunce-Edwards began working in the office full-time with the job title of Studio Coordinator. His usual tasks include monitoring of Oddworld fan communities, filing, watering plants and communicating with fans, job applicants, the gaming press and potential merchandise partners. During the production of &#039;&#039;[[Oddworld: Stranger’s Wrath HD]]&#039;&#039; he put together the unlockable extras, contributed to the [[Achievements in Oddworld: Stranger’s Wrath|achievements]] and decided where to place the [[RuptureFarms barrels in &#039;&#039;Oddworld: Stranger’s Wrath HD&#039;&#039;|easter eggs]]. Although he had updated his Twitter and Facebook profiles to accurately identify his job with JAW, Bunce-Edwards did not declare his employment on the Oddworld Forums until 23 December 2011.&amp;lt;ref name=&amp;quot;JAW&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== References ==&lt;br /&gt;
&amp;lt;references&amp;gt;&lt;br /&gt;
&amp;lt;ref name=&amp;quot;fom&amp;quot;&amp;gt;Odd Wide Web, Oddworld Archives, Oddworld Library (15 August 2010). Archive of Max the Mug (19 February 2003). [http://oddworldlibrary.net/archives/web/oddworld.com/firsttenyears/alf/ow_fan2_03.shtml Fan of the Month February–March 2003]. Alf’s Fan Odds N Ends. Alf’s Rehab &amp;amp; Tea. Official Oddworld website.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;elderberries&amp;quot;&amp;gt;Max the Mug (22 June 2004). [http://www.oddworldforums.net/showthread.php?p=158224&amp;amp;highlight=demo#post158224 Post 14] in ‘What made YOU buy your first OW game?’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;toexoddusclub&amp;quot;&amp;gt;Max the Mug (24 August 2001). [http://www.oddworldforums.net/showthread.php?p=30920#post30920 Post 13] in ‘How did you find Oddworld Forums?’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;ecmemlist&amp;quot;&amp;gt;[http://games.groups.yahoo.com/group/exoddusclub/members Exoddus Club member list]. Exoddus Club. Yahoo! Groups. (accessed 26 November 2010)&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;ezboardprofile&amp;quot;&amp;gt;Wayback Machine (1 September 2001). Archive of [http://web.archive.org/web/20010901052759/pub10.ezboard.com/boddworldian.showLocalUserPublicProfile?login=maxthemeetle Profile for Max the Meetle]. Oddworld Forums. ezboard.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;newname&amp;quot;&amp;gt;Max the Mug (14 April 2001). [http://www.oddworldforums.net/showthread.php?p=6480#post6480 Post 20] in ‘Welcome to Oddworld General Discussion’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;dannyDictionary&amp;quot;&amp;gt;Danny (19 April 2001). [http://www.oddworldforums.net/showthread.php?p=7360&amp;amp;#post7360 Post 15] in ‘rumours’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;maxEnc&amp;quot;&amp;gt;Max the Mug (17 April 2001). [http://www.oddworldforums.net/showthread.php?p=6884&amp;amp;#post6884 Post 19] in ‘hey! vital info on munch to be noted!’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;khanzStatus&amp;quot;&amp;gt;TheKhanzumer (23 September 2002). [http://www.oddworldforums.net/showthread.php?p=87573&amp;amp;#post87573 Post 11] in ‘Look at this pic.’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;xavSekEnc&amp;quot;&amp;gt;Xavier &amp;amp; Sekto Springs (21 June 2004). [http://www.oddworldforums.net/showthread.php?p=158090&amp;amp;#post158090 Posts 34] &amp;amp; 35 in ‘Centered around the poor side of Oddworld!’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;pedstatus&amp;quot;&amp;gt;Wayback Machine (4 May 2006). Archive of Max the Mug (6 May 2004). ‘[http://web.archive.org/web/20060504005357/www.oddworldforums.net/showthread.php?t=10017 Oddworld Questions and Answers III]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;paedist&amp;quot;&amp;gt;Wayback Machine (5 May 2008). Archive of ‘[http://web.archive.org/web/20080505011113/http://www.oddworldforums.net/member.php?u=20 View Profile: Max the Mug]’. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;replevels&amp;quot;&amp;gt;Alcar (20 March 2008). ‘[http://www.oddworldforums.net/showthread.php?t=16758 Revamped Reputation Levels]’. Forum Suggestions &amp;amp; Help. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;swtitles&amp;quot;&amp;gt;Oddworld Forums members (2–26 April 2006). ‘[http://www.oddworldforums.net/showthread.php?t=13668 New Titles System]’. Employee Lounge. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;rules&amp;quot;&amp;gt;Oddworld Forums members (13 July – 23 September 2010). ‘[http://www.oddworldforums.net/showthread.php?t=19363 Forum Rules]’. Employee Lounge. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;firstmail&amp;quot;&amp;gt;Oddworld Forums members (19 June – 25 August 2002). ‘[http://www.oddworldforums.net/showthread.php?t=5391 first Oddworld mail!]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;beforefom&amp;quot;&amp;gt;Oddworld Forums members (29 September – 3 October 2002). ‘[http://www.oddworldforums.net/showthread.php?t=6522 Map Of Oddworld]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;heresfom&amp;quot;&amp;gt;Wayback Machine (22 March 2003). Archive of Oddworld Inhabitants (19 February 2003). [http://web.archive.org/web/20030322165823/http://oddworld.com/ ‘What’s New’ February–March 2003]. Official Oddworld website.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;aboutfom&amp;quot;&amp;gt;Oddworld Forums members (19 February – 8 March 2003). ‘[http://www.oddworldforums.net/showthread.php?t=7486 Oddworld site updated...HAHA, I beat the fans...!!]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;afterfom&amp;quot;&amp;gt;Oddworld Forums members (1 – 3 March 2003). ‘[http://www.oddworldforums.net/showthread.php?t=7533 Map of Oddworld]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;oddtour2&amp;quot;&amp;gt;Oddworld Forums members (12 July – 9 August 2004). ‘[http://www.oddworldforums.net/showthread.php?t=10384 Amsterdam Oddworld Meeting (The Report) -56K Unfriendly-]’. Off-Topic Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;oddtour3&amp;quot;&amp;gt;Oddworld Forums members (2–5 May 2008). ‘[http://www.oddworldforums.net/showthread.php?t=16933 OddTour 3]’. Off-Topic Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;oddtour4&amp;quot;&amp;gt;Oddworld Forums members (13 September – 8 November 2010). ‘[http://www.oddworldforums.net/showthread.php?t=19651 OddTour 4]’. Off-Topic Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;farewell&amp;quot;&amp;gt;Max the Mug (19 August 2002). [http://www.oddworldforums.net/showthread.php?p=82224#post82224 Post 44] in ‘Farewell’. Off-Topic Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;owfreturn&amp;quot;&amp;gt;Max the Mug (14 September 2002). [http://www.oddworldforums.net/showthread.php?p=86136#post86136 Post 9] in ‘The slogan game’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;start2002elecs&amp;quot;&amp;gt;Oddworld Forums members (20–26 August 2002). ‘[http://www.oddworldforums.net/showthread.php?t=6120 Moderator Applications now Open!]’. Forum Suggestions &amp;amp; Help. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;end2002elecs&amp;quot;&amp;gt;Oddworld Forums members (26 August – 8 September 2002). ‘[http://www.oddworldforums.net/showthread.php?t=6202 Voting has begun!]’. Forum Suggestions &amp;amp; Help. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;start2003elecs&amp;quot;&amp;gt;Oddworld Forums members (24 August – 17 September 2003). ‘[http://www.oddworldforums.net/showthread.php?t=8825 New Moderator Nominations]’. Forum Suggestions &amp;amp; Help. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;end2003elecs&amp;quot;&amp;gt;Oddworld Forums members (16–23 September 2003). ‘[http://www.oddworldforums.net/showthread.php?t=8936 New Moderators]’. Forum Suggestions &amp;amp; Help. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;endofmod&amp;quot;&amp;gt;Alcar (15 July 2005). ‘[http://www.oddworldforums.net/showthread.php?t=12480 Staff Shifting and New Positions]’. Forum Suggestions &amp;amp; Help. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;smod&amp;quot;&amp;gt;Alcar (1 February 2007). ‘[http://www.oddworldforums.net/showthread.php?t=14947 New Off-Topic Mod &amp;amp; Zulag 1 SMod]’. Forum Suggestions &amp;amp; Help. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;admin&amp;quot;&amp;gt;Alcar (15 January 2008). ‘[http://www.oddworldforums.net/showthread.php?t=16485 TOL Sponsorship &amp;amp; Staff Changes]’. Forums Suggestions &amp;amp; Help. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;kennels&amp;quot;&amp;gt;billy_squeek (2 July 2000). ‘[http://games.groups.yahoo.com/group/exoddusclub/message/2451 My Webpage]’. Exoddus Club. Yahoo! Groups.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;scrabacombs&amp;quot;&amp;gt;Max the Mug (22 April 2001). ‘[http://www.oddworldforums.net/showthread.php?t=2722 Coming Soon - The Scrabacombs]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;websiteEnc&amp;quot;&amp;gt;Max the Mug (7 April 2002). [http://www.oddworldforums.net/showthread.php?p=58789#post58789 Post 10] in ‘There&#039;s more than one Shrink!?’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;firstfaq&amp;quot;&amp;gt;Cloverfield (24 June 2003).  ‘[http://www.oddworldforums.net/showthread.php?t=8382 Oddworld FAQs:  READ]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;TOLlaunch&amp;quot;&amp;gt;Max the Mug (1 April 2006). ‘[http://www.oddworldforums.net/showthread.php?t=13663 The Oddworld Library - grand opening]’. Oddworld Discussion. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;oddblog&amp;quot;&amp;gt;Max the Mug (17 August 2003). ‘[http://oddworldlibrary.net/oddblog/2003/08/OddBlog_created OddBlog created]’. OddBlog. Oddworld Library.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ref name=&amp;quot;JAW&amp;quot;&amp;gt;Bunce-Edwards, William (23 December 2011). ‘[http://www.oddworldforums.net/blog.php?b=3424 Job]’. Post on ‘A Max to Grind’. Blogs. Oddworld Forums.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/references&amp;gt;&lt;br /&gt;
[[Category:Fans of the Month]]&lt;br /&gt;
[[Category:Oddworld Forums staff]]&lt;br /&gt;
[[Category:Oddworld Library staff]]&lt;br /&gt;
[[Category:Annual Oddworld Forums Poster Awards winners]]&lt;br /&gt;
[[Category:Just Add Water employees]]&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Pokeypines&amp;diff=1207</id>
		<title>Pokeypines</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Pokeypines&amp;diff=1207"/>
		<updated>2018-04-07T14:50:27Z</updated>

		<summary type="html">&lt;p&gt;Max: Redirected page to Pokeypine&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;#REDIRECT [[Pokeypine]]&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Greeter&amp;diff=1206</id>
		<title>Greeter</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Greeter&amp;diff=1206"/>
		<updated>2018-04-07T14:44:01Z</updated>

		<summary type="html">&lt;p&gt;Max: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;A &#039;&#039;&#039;Greeter&#039;&#039;&#039; is an [[Oddworld appliances|appliance]] used by [[Glukkons]] as a combined vending machine, advertiser, security guard, and company greeter. Greeters often patrol [[Magog Cartel]] factories and facilities, commonly for the purpose of distributing [[SoulStorm Brew]] to [[Mudokon]]s. They appear in &#039;&#039;[[Oddworld: Abe’s Exoddus|Abe’s Exoddus]]&#039;&#039; gameplay.&lt;br /&gt;
&lt;br /&gt;
== History ==&lt;br /&gt;
[[Vykkers]] originally designed Greeters for the Magog Cartel to be aggressive, self-promoting vending machines that would follow Mudokons, delivering a sales pitch and selling them [[Oddworld comodditites|comoddities]]. They were meant to double as automated greeters, welcoming business associates to Glukkon workplaces, while attacking intruders.&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
To fulfil these multiple roles, Greeters were equipped with motion detectors and identity recognition intended to distinguish authorized employees and visitors from trespassers. Unfortunately, a programming error caused Greeters to attack Mudokons indiscriminately.&amp;lt;ref name=&amp;quot;AEManual&amp;quot;/&amp;gt; Unable to fix the software, the Glukkons decided that Greeters would be retrofitted and used as security devices. Mudokon workers are informed that they can avoid electrocution by remaining motionless in the Greeters’ infrared beam.&amp;lt;ref name=&amp;quot;StoneGreeters&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Construction ==&lt;br /&gt;
The main body of a Greeter resembles a four-foot-tall (1·2 m)&amp;lt;ref name=&amp;quot;OcInsInh&amp;quot;/&amp;gt; cylinder constructed from sheets of scrap metal,&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt; with a control box, exhaust pipe, and steam whistle (or ‘horn’)&amp;lt;ref name=&amp;quot;OcGreeters&amp;quot;/&amp;gt; attached to the rear. The front of a Greeter is fitted with a large grin, intended to appeal to consumers,&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt; which lip syncs to the speech produced by the appliance’s voicebox; the Greeter originally delivered comoddity sales pitches, but after being repurposed as a security device, now immitates [[Slig]] phrases.&lt;br /&gt;
&lt;br /&gt;
The base of the main body holds a ring of sensors and lightning dispensers,&amp;lt;ref name=&amp;quot;Farzad&amp;quot;/&amp;gt; which joins to a bracket that supports the Greeter on a single wheel. Including this (but excluding the horn), a Greeter’s height is 5 feet 8 inches (1·7 m).&amp;lt;ref name=&amp;quot;Farzad&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;OcInsInhAbe&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Greeters maintain excellent balance on their single wheel.&amp;lt;ref name=&amp;quot;Alf6&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Appearances ==&lt;br /&gt;
=== &#039;&#039;Abe’s Exoddus&#039;&#039; ===&lt;br /&gt;
{{Main|Greeters in Abe&#039;s Exoddus|List of Greeters in Abe&#039;s Exoddus}}&lt;br /&gt;
Greeters are an unusual hazard in &#039;&#039;[[Oddworld: Abe’s Exoddus|Abe’s Exoddus]]&#039;&#039;, appearing in the levels ‘FeeCo Depot’, ‘Slig Barracks’ and ‘SoulStorm Brewery’. They will chase and attempt to electrocute any Mudokons, including Abe, that they detect, resulting in instant death.&lt;br /&gt;
&lt;br /&gt;
Although Greeters behave like other enemy characters in that they follow patrols, chase Abe and have [[GameSpeak]], they will not detect Abe by sight, sound or (usually) proximity. Greeters only become aggressive if Abe or other Mudokons move while inside the Greeter&#039;s motion detector beam. The movement of this beam is difficult to predict because of how it encircles Greeters that are moving across the screen.&lt;br /&gt;
&lt;br /&gt;
=== Merchandise and marketing ===&lt;br /&gt;
Greeter concept art by [[Farzad Varahramyan]] appears on page 128 of &#039;&#039;[[The Art of Oddworld Inhabitants]]&#039;&#039; and Image 0006 of [[Oddworld: The Lost Archives]].&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;LostArc06&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Behind the scenes ==&lt;br /&gt;
Early designs by Farzad explored different shapes for Greeters, but always with a height equal to Abe’s.&amp;lt;ref name=&amp;quot;Farzad&amp;quot;/&amp;gt; According to text in his concept sketches, Greeters should &amp;lt;q&amp;gt;behave like a drunk unicyclist and move &amp;amp; sound like an old tinkertoy.&amp;lt;/q&amp;gt; The Greeters’ steam horn resembles a scaled down replica Greeter, but with a downturned mouth.&lt;br /&gt;
&lt;br /&gt;
== References ==&lt;br /&gt;
&amp;lt;references&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;OcInsInh&amp;quot;&amp;gt;&#039;&#039;&#039;Oddworld Inhabitants (~02/1999)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/wiki/Abe&#039;s_Exoddus_-_Inhabitants Name: Greeters]’, ‘Inhabitants’. Oddworld.com. Archived by [[Oddworld Library#Oddworld Scriptures|Oddworld Scriptures]] on 08/05/2012.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;AEManual&amp;quot;&amp;gt;&#039;&#039;&#039;O’Connor, Paul (17/11/1998)&#039;&#039;&#039;. ‘Greeters’, ‘The Cast’, p. 27. Game manual for &#039;&#039;Oddworld: Abe’s Exoddus&#039;&#039;. GT Interactive. &amp;lt;q&amp;gt;Glukkons were aghast when these marketing and P.R. machines began attacking the customers.&amp;lt;/q&amp;gt;&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;StoneGreeters&amp;quot;&amp;gt;&#039;&#039;&#039;Aslik (17/11/1998)&#039;&#039;&#039;. ‘Uncle Aslik’s Tourist Tip #9: Greeters Welcome You!’. FeeCo Depot. StoryDwelling Theater. StoryStone (FDP02C16), ‘FeeCo Depot’ (FDP02C10). &#039;&#039;Oddworld: Abe’s Exoddus&#039;&#039;. GT Interactive. &amp;lt;q&amp;gt;Remember: If you don’t move, they can’t see you!&amp;lt;/q&amp;gt;&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;OcGreeters&amp;quot;&amp;gt;&#039;&#039;&#039;Oddworld Inhabitants (17/08/2000)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/archives/web/oddworld.com/firsttenyears/universe/industrial/characters/ow_greeter.html Greeters]’. ‘Oddworld Universe’. Oddworld.com. Archived by [[Oddworld Library#Odd_Wide_Web|Odd Wide Web]] on 05/01/2011.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;Farzad&amp;quot;&amp;gt;&#039;&#039;&#039;Varahramyan, Farzad (24/03/1998)&#039;&#039;&#039;. ‘Abe II: Greeters’ concept sketches.&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;LostArc06&amp;quot;/&amp;gt;&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;&amp;gt;&#039;&#039;&#039;Johnson, Cathy; Wade, Johnson (15/09/2004)&#039;&#039;&#039;. ‘Greeters’, ‘&#039;&#039;Oddworld: Abe’s Exoddus&#039;&#039;’, p. 128. &#039;&#039;[[The Art of Oddworld Inhabitants|The Art of Oddworld Inhabitants: The First Ten Years 1994–2004]]&#039;&#039;. Adelaide, South Australia: Ballistic Publishing.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;LostArc06&amp;quot;&amp;gt;&#039;&#039;&#039;Oddworld Inhabitants (11/12/2017 16:47 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BckbYBoDf8M/ The Greeter]’. [[Oddworld: The Lost Archives]]. Post on Instagram.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;Alf6&amp;quot;&amp;gt;&#039;&#039;&#039;Alf (01/03/2001)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/archives/web/oddworld.com/firsttenyears/alf/ow_dearalf06.shtml Dear Alf 06]’, q. 31. ‘Alf’s Rehab &amp;amp; Tea’. Oddworld.com. Archived by Odd Wide Web on 05/01/2011.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;OcInsInhAbe&amp;quot;&amp;gt;&#039;&#039;&#039;Oddworld Inhabitants (~02/1999)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/wiki/Abe&#039;s_Exoddus_-_Inhabitants Name: Abe]’, ‘Inhabitants’. Oddworld.com. Archived by Oddworld Scriptures on 08/05/2012.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;/references&amp;gt;&lt;br /&gt;
[[Category:Appliances]]&lt;br /&gt;
[[Category:Abe&#039;s Exoddus gameplay]]&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Greeter&amp;diff=1205</id>
		<title>Greeter</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Greeter&amp;diff=1205"/>
		<updated>2018-04-07T14:22:44Z</updated>

		<summary type="html">&lt;p&gt;Max: Created page with &amp;quot;A &amp;#039;&amp;#039;&amp;#039;Greeter&amp;#039;&amp;#039;&amp;#039; is an appliance used by Glukkons as a combined vending machine, advertiser, security guard, and company greeter. Greeters often pat...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;A &#039;&#039;&#039;Greeter&#039;&#039;&#039; is an [[Oddworld appliances|appliance]] used by [[Glukkons]] as a combined vending machine, advertiser, security guard, and company greeter. Greeters often patrol [[Magog Cartel]] factories and facilities, commonly for the purpose of distributing [[SoulStorm Brew]] to [[Mudokon]]s. They appear in &#039;&#039;[[Oddworld: Abe’s Exoddus|Abe’s Exoddus]]&#039;&#039; gameplay.&lt;br /&gt;
&lt;br /&gt;
== History ==&lt;br /&gt;
[[Vykkers]] originally designed Greeters for the Magog Cartel to be aggressive, self-promoting vending machines that would follow Mudokons, delivering a sales pitch and selling them [[Oddworld comodditites|comoddities]]. They were meant to double as automated greeters, welcoming business associates to Glukkon workplaces, while attacking intruders.&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
To fulfil these multiple roles, Greeters were equipped with motion detectors and identity recognition intended to distinguish authorized employees and visitors from trespassers. Unfortunately, a programming error caused Greeters to attack Mudokons indiscriminately.&amp;lt;ref name=&amp;quot;AEManual&amp;quot;/&amp;gt; Unable to fix the software, the Glukkons decided that Greeters would be retrofitted and used as security devices. Mudokon workers are informed that they can avoid electrocution by remaining motionless in the Greeters’ infrared beam.&amp;lt;ref name=&amp;quot;StoneGreeters&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Construction ==&lt;br /&gt;
The main body of a Greeter resembles a four-foot-tall (1·2 m)&amp;lt;ref name=&amp;quot;OcInsInh&amp;quot;/&amp;gt; cylinder constructed from sheets of scrap metal,&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt; with a control box, exhaust pipe, and steam whistle (or ‘horn’)&amp;lt;ref name=&amp;quot;OcGreeters&amp;quot;/&amp;gt; attached to the rear. The front of a Greeter is fitted with a large grin, intended to appeal to consumers,&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt; which lip syncs to the speech produced by the appliance’s voicebox; the Greeter originally delivered comoddity sales pitches, but after being repurposed as a security device, now immitates [[Slig]] phrases.&lt;br /&gt;
&lt;br /&gt;
The base of the main body holds a ring of sensors and lightning dispensers,&amp;lt;ref name=&amp;quot;Farzad&amp;quot;/&amp;gt; which joins to a bracket that supports the Greeter on a single wheel. Including this (but excluding the horn), a Greeter’s height is 5 feet 8 inches (1·7 m).&amp;lt;ref name=&amp;quot;Farzad&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;OcInsInhAbe&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Greeters maintain excellent balance on their single wheel.&amp;lt;ref name=&amp;quot;Alf6&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Appearances ==&lt;br /&gt;
=== &#039;&#039;Abe’s Exoddus&#039;&#039; ===&lt;br /&gt;
{{Main|Greeters in Abe&#039;s Exoddus|List of Greeters in Abe&#039;s Exoddus}}&lt;br /&gt;
Greeters are an unusual hazard in &#039;&#039;[[Oddworld: Abe’s Exoddus|Abe’s Exoddus]]&#039;&#039;, appearing in the levels ‘FeeCo Depot’, ‘Slig Barracks’ and ‘SoulStorm Brewery’. They will chase and attempt to electrocute any Mudokons, including Abe, that they detect, resulting in instant death.&lt;br /&gt;
&lt;br /&gt;
Although Greeters behave like other enemy characters in that they follow patrols, chase Abe and have [[GameSpeak]], they will not detect Abe by sight, sound or (usually) proximity. Greeters only become aggressive if Abe or other Mudokons move while inside the Greeter&#039;s motion detector beam. The movement of this beam is difficult to predict because of how it encircles Greeters that are moving across the screen.&lt;br /&gt;
&lt;br /&gt;
=== Merchandise and marketing ===&lt;br /&gt;
Greeter concept art by [[Farzad Varahramyan]] appears on page 128 of &#039;&#039;[[The Art of Oddworld Inhabitants]]&#039;&#039; and Image 0006 of [[Oddworld: The Lost Archives]].&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;LostArc06&amp;quot;/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Behind the scenes ==&lt;br /&gt;
Early designs by Farzad explored different shapes for Greeters, but always with a height equal to Abe’s.&amp;lt;ref name=&amp;quot;Farzad&amp;quot;/&amp;gt; According to text in his concept sketches, Greeters should &amp;lt;q&amp;gt;behave like a drunk unicyclist and move &amp;amp; sound like an old tinkertoy.&amp;lt;/q&amp;gt; The Greeters’ steam horn resembles a scaled down replica Greeter, but with a downturned mouth.&lt;br /&gt;
&lt;br /&gt;
== References ==&lt;br /&gt;
&amp;lt;references&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;OcInsInh&amp;quot;&amp;gt;&#039;&#039;&#039;Oddworld Inhabitants (~02/1999)&#039;&#039;&#039;. ‘[toswi:Inhabitants.php#Greeters Name: Greeters]’, ‘Inhabitants’. Oddworld.com.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;AEManual&amp;quot;&amp;gt;&#039;&#039;&#039;O’Connor, Paul (17/11/1998)&#039;&#039;&#039;. ‘Greeters’, ‘The Cast’, p. 27. Game manual for &#039;&#039;Oddworld: Abe’s Exoddus&#039;&#039;. GT Interactive. &amp;lt;q&amp;gt;Glukkons were aghast when these marketing and P.R. machines began attacking the customers.&amp;lt;/q&amp;gt;&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;StoneGreeters&amp;quot;&amp;gt;&#039;&#039;&#039;Aslik (17/11/1998)&#039;&#039;&#039;. ‘Uncle Aslik’s Tourist Tip #9: Greeters Welcome You!’. FeeCo Depot. StoryDwelling Theater. StoryStone (FDP02C16), ‘FeeCo Depot’ (FDP02C10). &#039;&#039;Oddworld: Abe’s Exoddus&#039;&#039;. GT Interactive. &amp;lt;q&amp;gt;Remember: If you don’t move, they can’t see you!&amp;lt;/q&amp;gt;&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;OcGreeters&amp;quot;&amp;gt;&#039;&#039;&#039;Oddworld Inhabitants (17/08/2000)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/archives/web/oddworld.com/firsttenyears/universe/industrial/characters/ow_greeter.html Greeters]’. ‘Oddworld Universe’. Oddworld.com. Archived by [[Oddworld Library#Odd_Wide_Web|Odd Wide Web]] on 05/01/2011.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;Farzad&amp;quot;&amp;gt;&#039;&#039;&#039;Varahramyan, Farzad (24/03/1998)&#039;&#039;&#039;. ‘Abe II: Greeters’ concept sketches.&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;/&amp;gt;&amp;lt;ref name=&amp;quot;LostArc06&amp;quot;/&amp;gt;&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;AOWI128&amp;quot;&amp;gt;&#039;&#039;&#039;Johnson, Cathy; Wade, Johnson (15/09/2004)&#039;&#039;&#039;. ‘Greeters’, ‘&#039;&#039;Oddworld: Abe’s Exoddus&#039;&#039;’, p. 128. &#039;&#039;[[The Art of Oddworld Inhabitants|The Art of Oddworld Inhabitants: The First Ten Years 1994–2004]]&#039;&#039;. Adelaide, South Australia: Ballistic Publishing.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;LostArc06&amp;quot;&amp;gt;&#039;&#039;&#039;Oddworld Inhabitants (11/12/2017 16:47 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BckbYBoDf8M/ The Greeter]’. [[Oddworld: The Lost Archives]]. Post on Instagram.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;Alf6&amp;quot;&amp;gt;&#039;&#039;&#039;Alf (01/03/2001)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/archives/web/oddworld.com/firsttenyears/alf/ow_dearalf06.shtml Dear Alf 06]’, q. 31. ‘Alf’s Rehab &amp;amp; Tea’. Oddworld.com. Archived by Odd Wide Web on 05/01/2011.&amp;lt;/ref&amp;gt;&lt;br /&gt;
	&amp;lt;ref name=&amp;quot;OcInsInhAbe&amp;quot;&amp;gt;&#039;&#039;&#039;Oddworld Inhabitants (~02/1999)&#039;&#039;&#039;. ‘[http://oddworldlibrary.net/wiki/Abe&#039;s_Exoddus_-_Inhabitants Name: Abe]’, ‘Inhabitants’. Oddworld.com. Archived by [[Oddworld Library#Oddworld Scriptures Oddworld Scriptures] on 08/05/2012.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;/references&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Oddworld:_The_Lost_Archives&amp;diff=1204</id>
		<title>Oddworld: The Lost Archives</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Oddworld:_The_Lost_Archives&amp;diff=1204"/>
		<updated>2018-04-07T12:47:41Z</updated>

		<summary type="html">&lt;p&gt;Max: Created page with &amp;quot;&amp;#039;&amp;#039;&amp;#039;Oddworld: The Lost Archives&amp;#039;&amp;#039;&amp;#039; is a social media series posted by Oddworld Inhabitants on Instagram. It comprises daily posts of Oddworld concept art drawn from...&amp;quot;&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&#039;&#039;&#039;Oddworld: The Lost Archives&#039;&#039;&#039; is a social media series posted by [[Oddworld Inhabitants]] on [[Instagram]]. It comprises daily posts of [[Oddworld]] concept art drawn from a recently recovered archive, much of it previously unreleased.&lt;br /&gt;
&lt;br /&gt;
The first image was posted on 4th December 2017 with new ones being posted every weekday since, with the exception of 19th and 22nd March, both during the same week Oddworld Inhabitants attended [[Game_Developers_Conference#GDC_2018|GDC 2018]] and the launch of the &#039;&#039;[[Oddworld: Abe’s Origins]]&#039;&#039; crowdfunding campaign.&lt;br /&gt;
&lt;br /&gt;
Starting on 22nd January 2018, the first image of each week is deliberately chosen for being in colour.&lt;br /&gt;
&lt;br /&gt;
The series is scheduled to continue with posts every weekday until the release of &#039;&#039;[[Oddworld: Soulstorm]]&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
== References ==&lt;br /&gt;
=== Instagram ===&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (01/12/2017 16:30 UTC)&#039;&#039;&#039;.  [https://www.instagram.com/p/BcKph5IjQtk/ Post] on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (01/12/2017 16:58 UTC)&#039;&#039;&#039;.  [https://www.instagram.com/p/BcKsr81DmYE/ Post] on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (04/12/2017 17:33 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BcSfHtZDUac/ Character Concept Sketches]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (05/12/2017 13:01 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BcUkybpDFCx/ Munch Concept Sketch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (06/12/2017 19:23 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BcX1SbajWQU/ Mudokon Queen Concept]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (07/12/2017 13:30 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BcZxqEqjS8V/ Magog Cartel Lawyers]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (08/12/2017 16:13 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BccpK2UD-8k/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (11/12/2017 16:47 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BckbYBoDf8M/ The Greeter]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (12/12/2017 17:00 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BcnBpm0DBPf/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (13/12/2017 18:00 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BcptYqqjMs5/ Fleech Eating Chart]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (14/12/2017 17:20 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BcsNj2PjYH6/ The Ociti]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (15/12/2017 12:58 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BcuUXGUDYz7/ The Meech]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (18/12/2017 12:04 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bc18mm3jlHr/ Sekto]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (19/12/2017 17:27 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bc5GVB4jjCW/ Fleech]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (20/12/2017 16:58 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bc7n2gJjc0D/ Glukkons]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (21/12/2017 19:00 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bc-al_ADlgQ/ Spiders]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (22/12/2017 14:00 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BdAdF6ZDNMP/ New Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (25/12/2017 12:34 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BdIBmeWDkvR/ Christmas Card Designs]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (26/12/2017 16:11 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BdK_QogDON1/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (27/12/2017 16:43 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BdNnqlmDk2t/ Priests]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (28/12/2017 16:32 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BdQLLzfjpI1/ Elum]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (29/12/2017 15:59 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BdSsOtIjdYg/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (01/01/2018 16:45 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bdaf2-FjVvs/ Abe]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (02/01/2018 14:47 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bdc3KBTj7wm/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (03/01/2018 16:57 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bdfq2eJjv33/ Abe Chest Tattoo]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (04/01/2018 17:53 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BdiWAg0jTI3/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (05/01/2018 18:12 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bdk9A1XjFOq/ Munch Skeleton Detail]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (08/01/2018 17:01 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BdsjRvOjhTh/ Character Tongues]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (09/01/2018 18:03 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BdvPMHdjk92/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (10/01/2018 18:50 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bdx5UuNjK47/ Facial Expressions]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (11/01/2018 18:01 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bd0YjAmDWLd/ Abe]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (12/01/2018 17:32 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bd26BgaDaMa/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (15/01/2018 19:27 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bd-1lQij6gg/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (16/01/2018 17:39 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeBN8psDe13/ Abe]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (17/01/2018 18:42 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeD59uNDRwo/ Mudokon Skulls]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (18/01/2018 18:31 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeGdfVCjfFw/ Mudokon Queen Concept]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (19/01/2018 18:05 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeI_W1WDYH0/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (22/01/2018 16:03 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeQfzwBjs2h/ E3 Booth]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (23/01/2018 15:58 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeTD8aDjxd0/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (24/01/2018 16:54 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeVvPIEjeMb/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (25/01/2018 16:49 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeYTbYfD1K2/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (26/01/2018 16:27 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bea1v3GD6DE/ Fleech]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (29/01/2018 16:05 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeihhefH3_Z/ Lightning Strike]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (30/01/2018 16:42 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BelKoSQnIn0/ Mudokon Hand]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (31/01/2018 15:45 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Beno6N4D5Yu/ Fleech Animation]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (01/02/2018 16:18 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BeqRaa3Ae_s/ Fleech Redesign]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (02/02/2018 16:39 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bes4rhZA5uM/ Abe’s Bones]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (05/02/2018 17:33 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Be0tKmnggUG/ Abe on Elum]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (06/02/2018 14:52 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Be2_moXDG1T/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (07/02/2018 19:07 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Be6BfP0BebC/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (08/02/2018 18:02 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Be8e8BzhvTP/ Munch Camouflage]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (09/02/2018 17:21 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Be-_CBAj2Op/ Rodent Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (12/02/2018 17:22 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BfGtdm4gs_H/ Paramonian Temple]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (13/02/2018 18:48 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BfJcHxHFwKQ/ Floating Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (14/02/2018 23:03 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BfMeHFRAs3f/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (15/02/2018 18:18 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BfOiTN6gQkQ/ Swimming]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (16/02/2018 17:08 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BfQ_H7ChCHV/ Friends]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (19/02/2018 18:18 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BfY1gVYn25n/ Rupture Farms]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (20/02/2018 20:00 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bfbl7DKAnrg/ Munch Head]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (21/02/2018 20:48 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BfeQNaZhTv1/ Tall Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (22/02/2018 22:34 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BfhBMt8g3i7/ Abe and Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (23/02/2018 22:24 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bfjkx_fgI2h/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (26/02/2018 18:58 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bfq7nvwheUy/ Help Wanted]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (27/02/2018 18:26 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bftcuwwl3JT/ Headley]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (28/02/2018 16:56 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bfv3PzoFHx-/ Baby Mudokon]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (01/03/2018 19:51 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BfywHRBAQ12/ The Pit]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (02/03/2018 17:35 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bf1FTcdBVy0/ Intern (Naked)]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (05/03/2018 17:31 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bf8zQmAgXDn/ Slig Painting]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (06/03/2018 15:09 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bf_HvK0H-Yu/ Young Vykker]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (07/03/2018 18:11 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgCBcSOBC-V/ Octigi]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (08/03/2018 19:09 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgEsxDHg_9i/ Octigi (Suited)]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (09/03/2018 18:55 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgHQEPGl22l/ Opinionites]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (12/03/2018 18:41 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgO82vGH7ga/ Characters]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (13/03/2018 18:38 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgRhMrQBRxo/ Fuzzles]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (14/03/2018 18:12 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgUDBH3hrXk/ Vykker Poses]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (15/03/2018 21:21 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgW9divnLfu/ Frogger and Friends]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (16/03/2018 22:47 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgZsIXtgjjY/ Creatures]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (20/03/2018 03:15 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bgh5MV5lgMF/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (21/03/2018 20:05 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgmRkIuAsWL/ A Meeting]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (23/03/2018 18:03 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BgrNIytBQY0/ Molluck]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (27/03/2018 02:57 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bgz4syvAebW/ Ratz]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (28/03/2018 18:39 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bg1kijRgHdt/ Vykker Doctor]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (29/03/2018 00:08 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bg4u-H7g7Cs/ Sting Ring]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (29/03/2018 21:04 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bg6-r3pjYp_/ Poison Darts]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (30/03/2018 23:47 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/Bg92EiKgwmX/ Large Land Predator]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (03/04/2018 01:50 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BhFyjS-gtIW/ Almighty Raisin]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (04/04/2018 02:47 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BhId8d3A-eF/ Vykkers Labs]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (04/04/2018 18:05 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BhKG_sLB2Tb/ Munch]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (05/04/2018 18:02 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BhMrdUDjGx-/ Vykker Arm]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
# &#039;&#039;&#039;Oddworld Inhabitants (06/04/2018 19:08 UTC)&#039;&#039;&#039;. ‘[https://www.instagram.com/p/BhPXztvgeci/ Unnamed Creature]’. Oddworld: The Lost Archives. Post on Instagram.&lt;br /&gt;
&lt;br /&gt;
=== Twitter ===&lt;br /&gt;
{{Ordered list |start=91&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (01/12/2017 16:32 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/936634013296549888 Dec 4th, 2017... http://ow.ly/Le3b30gX0b9]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (01/12/2017 16:59 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/936640829195681792 Dec 4th, 2017... http://ow.ly/l14H30gX3my]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (04/12/2017 17:03 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/937728985550729216 Today&#039;s announcement is here: The lost Oddworld archives have been found!]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (04/12/2017 17:37 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/937737713125593090 Here&#039;s our first image! It&#039;s pretty gruesome, but enjoy! Here&#039;s a sneak preview for anyone who didn&#039;t read our post! http://ow.ly/A1sP30h0djb ]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (05/12/2017 13:13 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/938033529157545984 Today&#039;s lost archive image is &#039;An early exploration for Munch&#039; Here&#039;s a sneak peek, you can see the full image on our Instagram right here http://ow.ly/H3x130h1sYX]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (05/12/2017 16:02 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/938076024000208898 In case you missed it yesterday, along with the discovery of boxes and boxes of brand new never before seen art, we&#039;ve also uncovered the source code to Abe&#039;s Oddysee. More news on that soon.]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (05/12/2017 21:47 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/938162828946624513 For today&#039;s image you can take a look at what Munch might have looked like! http://ow.ly/wBLw30h2leb]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (06/12/2017 19:27 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/938490176359288832 Today&#039;s lost archive image is Sam. Ever wondered about Abe&#039;s Mom? You can see an early exploration here: http://ow.ly/O6V130h3FSz]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (07/12/2017 13:32 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/938763185150185473 Today&#039;s lost archive image: Lawyers! You can find the full image here: http://ow.ly/W87X30h4DCR]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (08/12/2017 16:16 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/939166845675991040 Today&#039;s lost archive image: A little too grim? http://ow.ly/bieZ30h6jx1]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (11/12/2017 16:48 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/940262063888363520 Today&#039;s lost archive image: A familiar grin! http://ow.ly/kE3l30h9rPq]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (12/12/2017 13:03 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/940628079134887937 Today&#039;s lost archive image: Munch is looking fierce! http://ow.ly/cxmu30hbcXv ]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (13/12/2017 18:03 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/941005755347603458 Today&#039;s lost archive post- Hungry Fleech! http://ow.ly/5sKm30hcO6R ]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (14/12/2017 17:23 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/941357984512430081 Today&#039;s lost archive image. A priest! &amp;lt;nowiki&amp;gt;https://www.instagram.com/p/BcsNj2PjYH6/?hl=en&amp;lt;/nowiki&amp;gt; …]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (15/12/2017 12:59 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/941654046116667392 Today&#039;s lost archive: an original concept from &#039;95! &amp;lt;nowiki&amp;gt;https://www.instagram.com/p/BcuUXGUDYz7/?hl=en&amp;lt;/nowiki&amp;gt; …]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (18/12/2017 12:06 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/942727684429373440 Today&#039;s lost archive image- an early design of a familiar face https://www.instagram.com/p/Bc18mm3jlHr/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (19/12/2017 17:29 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/943171479897804802 Today&#039;s lost archive image- Fleech close-up! https://www.instagram.com/p/Bc5GVB4jjCW/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (20/12/2017 17:00 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/943526442268229632 Today&#039;s lost archive image- experimenting with posing and lighting https://www.instagram.com/p/Bc7n2gJjc0D/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (21/12/2017 19:01 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/943919471340802049 Today&#039;s lost archive image- look away now if you&#039;re afraid of spiders! https://www.instagram.com/p/Bc-al_ADlgQ/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (22/12/2017 14:02 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/944206414591004672 Today&#039;s lost archive image. If there&#039;s such a thing as too cute this is it https://www.instagram.com/p/BdAdF6ZDNMP/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (25/12/2017 12:36 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/945271940243214336 Happy holidays from everyone here at Oddworld Inhabitants! https://www.instagram.com/p/BdIBmeWDkvR/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (26/12/2017 16:13 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/945689100446773248 Today&#039;s lost archive image is a creepy Munch. We really like this one! https://www.instagram.com/p/BdK_QogDON1/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (27/12/2017 16:45 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/946059388908916736 Today&#039;s lost archive image- corrupt priests https://www.instagram.com/p/BdNnqlmDk2t/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (28/12/2017 16:34 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/946419064943054854 Today&#039;s lost archive image- drooling Elum! As always here&#039;s a preview... https://www.instagram.com/p/BdQLLzfjpI1/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (29/12/2017 16:02 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/946773367838953473 Today&#039;s lost archive image- An unusual design for Munch. https://www.instagram.com/p/BdSsOtIjdYg/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (01/01/2018 16:46 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/947871727765348352 Today&#039;s lost archive image- Abe&#039;s in party mode! https://www.instagram.com/p/Bdaf2-FjVvs/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (02/01/2018 14:48 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/948204292082675712 Today&#039;s lost archive image- Munch expressions! https://www.instagram.com/p/Bdc3KBTj7wm/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (03/01/2018 16:58 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/948599483012657152 Today&#039;s lost archive image- choosing a new tattoo can be tricky! https://www.instagram.com/p/Bdfq2eJjv33/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (04/01/2018 17:55 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/948976130748551168 Today&#039;s lost archive image- Munch was almost musical? https://www.instagram.com/p/BdiWAg0jTI3/ ]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (05/01/2018 18:13 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/949343206105321472 Today&#039;s lost archive- skeletal Munch! https://www.instagram.com/p/Bdk9A1XjFOq/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (08/01/2018 17:02 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/950412443972440064 Today&#039;s lost archive image- attention to detail! https://www.instagram.com/p/BdsjRvOjhTh/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (09/01/2018 18:05 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/950790623329771520 Today&#039;s lost archive image. Some ideas for swimming Munch. https://www.instagram.com/p/BdvPMHdjk92/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (10/01/2018 18:51 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/951164654423826432 Today&#039;s lost archive image- Mudokons pulling faces! https://www.instagram.com/p/Bdx5UuNjK47/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (11/01/2018 18:03 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/951514913905758208 Today&#039;s lost archive image- An early Abe! https://www.instagram.com/p/Bd0YjAmDWLd/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (12/01/2018 17:34 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/951869895414812673 Today&#039;s lost archive image- Expressions for Munch. Look at that face! https://www.instagram.com/p/Bd26BgaDaMa/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (15/01/2018 19:28 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/952985980902010881 Today&#039;s lost archive image- Munch the Catfish! https://www.instagram.com/p/Bd-1lQij6gg/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (16/01/2018 17:41 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/953321232597946369 Today&#039;s lost archive image- an idea for a t-shirt design https://www.instagram.com/p/BeBN8psDe13/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (17/01/2018 18:44 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/953699517177696256 Today&#039;s lost archive image- Creepy, creepy Mudokon skulls https://www.instagram.com/p/BeD59uNDRwo/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (18/01/2018 18:32 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/954058871282241536 Today&#039;s lost archive image- Abe&#039;s Mom https://www.instagram.com/p/BeGdfVCjfFw/ ]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (19/01/2018 18:07 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/954414971378597889 Today&#039;s lost archive image- dangerous friends https://www.instagram.com/p/BeI_W1WDYH0/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (22/01/2018 16:06 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/955471747511398400 We&#039;re brightening up the beginning of the week by adding a splash of color to our Instagram every Monday. Today&#039;s lost archive image- Oddysee E3 booth https://www.instagram.com/p/BeQfzwBjs2h/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (23/01/2018 16:02 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/955833033415946241 Today&#039;s lost archive image- making Munch expressive https://www.instagram.com/p/BeTD8aDjxd0/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (24/01/2018 16:56 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/956209055118356481 Today&#039;s lost archive image- Munch could use a little help... https://www.instagram.com/p/BeVvPIEjeMb/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (25/01/2018 16:50 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/956570006913015809 Today&#039;s lost archive image- Munch the rodent. https://www.instagram.com/p/BeYTbYfD1K2/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (26/01/2018 16:28 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/956926928820297731 Today&#039;s lost archive image- Fleech animation https://www.instagram.com/p/Bea1v3GD6DE/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (29/01/2018 16:06 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/958008439438966787 Today&#039;s lost archive image- Watch out for that lightning! https://www.instagram.com/p/BeihhefH3_Z/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (30/01/2018 16:43 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/958380222189010945 Today&#039;s lost archive image- Mudokon hands https://www.instagram.com/p/BelKoSQnIn0/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (31/01/2018 15:47 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/958728329649061893 Today&#039;s lost archive image- Fleech eating animation https://www.instagram.com/p/Beno6N4D5Yu/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (01/02/2018 16:20 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/959099033498382336 Today&#039;s lost archive image- a Fleech redesign &amp;lt;nowiki&amp;gt;http://www.instagram.com/p/BeqRaa3Ae_s/?taken-by=oddworldinc&amp;lt;/nowiki&amp;gt; …]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (02/02/2018 16:43 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/959467241153671168 Today&#039;s lost archive image- Mudokon bones. &amp;lt;nowiki&amp;gt;https://www.instagram.com/p/Bes4rhZA5uM/?taken-by=oddworldinc&amp;lt;/nowiki&amp;gt; …]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (05/02/2018 18:27 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/960580660250464256 Don&#039;t forget that every day we post a new image from the Lost Archives to our Instagram. On Mondays it&#039;s in color to brighten up the start of the week. Here&#039;s today&#039;s image. You can see comments right here. &amp;lt;nowiki&amp;gt;http://www.instagram.com/p/Be0tKmnggUG/?taken-by=oddworldinc&amp;lt;/nowiki&amp;gt; …]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (08/02/2018 18:04 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/961662132365549568 We&#039;re celebrating Munch right now, here&#039;s something from the archives. If they can&#039;t spot you they can&#039;t catch you! &amp;lt;nowiki&amp;gt;http://www.instagram.com/p/Be8e8BzhvTP/?taken-by=oddworldinc&amp;lt;/nowiki&amp;gt; …]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (09/02/2018 17:23 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/962014034814840832 Today&#039;s lost archive image is here! As always you can follow the Instagram link to see what people are saying https://www.instagram.com/p/Be-_CBAj2Op/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (15/02/2018 21:05 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/964244271552434176 Today&#039;s lost archive image shows how Munch swims. We share a lost archive image every weekday on our Instagram :) http://ow.ly/il9k30iqIKW]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (19/02/2018 18:20 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/965652294221139968 Today&#039;s lost archive image is in color to brighten up your Monday. This week&#039;s is a creepy early concept for Rupture Farms. http://ow.ly/gCJc30iurCH]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (27/02/2018 18:28 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/968553352152911874 Today&#039;s lost archive image- Headley might not be easy to look at, but he sure is well dressed. (If you ignore the fact that he doesn&#039;t wear pants) http://ow.ly/hBr730iEgYC]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (28/02/2018 17:01 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/968894059472408576 Today&#039;s lost archive is a baby Mudokon- he might just be the cutest thing we&#039;ve ever seen. As always if you want to check out the other images on our Instagram the link is right here http://ow.ly/a91I30iFLBQ]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (28/02/2018 17:01 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/969634323015053313 Look how happy this Intern is. Maybe they just get grumpy when they&#039;re made to wear clothes? You can find more Lost Archive images over on our Instagram https://www.instagram.com/oddworldinc/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (06/03/2018 15:14 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/971041370264735746 Today’s lost archive image is a young Vykker. He got his hands on some serious weapons but he doesn’t look as menacing as he thinks he does https://www.instagram.com/p/Bf_HvK0H-Yu/]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (12/03/2018 18:42 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/973268022042529792 Today&#039;s lost archive image- Abe and Elum are looking outnumbered right now.]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (27/03/2018 19:45 UTC)&#039;&#039;&#039;. ‘&amp;lt;q&amp;gt;[https://twitter.com/OddworldInc/status/978704550109564928 Here&#039;s a look at today&#039;s Lost Archive image- you might want to reschedule your appointment if it&#039;s with this particular doctor... You can catch more lost archives and some other really cool stuff on our Instagram! http://ow.ly/nZk430jbCXn]&amp;lt;/q&amp;gt;’. Tweet on Twitter.&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
=== Facebook ===&lt;br /&gt;
{{Ordered list |start=152&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (01/12/2017 16:32)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/posts/1462613543775646 Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (01/12/2017 16:59)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/posts/1462635550440112 Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (04/12/2017 17:03)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/posts/1465594720144195 Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (04/12/2017 17:38)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/posts/1465620336808300 Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (05/12/2017 13:13)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1466341146736219/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (05/12/2017 16:02)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/posts/1466475330056134 Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (06/12/2017 19:27)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/posts/1467625663274434 Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (07/12/2017 13:32)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1468338509869816/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (08/12/2017 16:16)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1469526079751059/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (11/12/2017 16:48)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1472344659469201/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (12/12/2017 17:03)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1473276859375981/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (13/12/2017 18:03)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1474273665942967/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (14/12/2017 17:23)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/posts/1475174075852926 Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (15/12/2017 12:59)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1475880552448945/?type{{=}}3 Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (18/12/2017 12:06)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1478772995493034/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (19/12/2017 17:29)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1479945068709160/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (20/12/2017 17:00)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1480775681959432/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (21/12/2017 19:01)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1481706391866361/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (22/12/2017 14:02)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1482337148469952/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (25/12/2017 12:36)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1484910068212660/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (26/12/2017 16:13)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1485915684778765/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (27/12/2017 16:45)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1486740431362957/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (28/12/2017 16:34)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1487587294611604/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (29/12/2017 16:02)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1488414421195558/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (01/01/2018 16:46)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1491344150902585/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (02/01/2018 14:48)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1492122240824776/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (03/01/2018 16:58)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1493205800716420/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (04/01/2018 17:55)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1494322470604753/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (05/01/2018 18:13)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1495375127166154/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (08/01/2018 17:02)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1498381340198866/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (09/01/2018 18:05)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1499412223429111/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (10/01/2018 18:51)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1500368063333527/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (11/01/2018 18:03)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1501189633251370/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (12/01/2018 17:34)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1502026013167732/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (15/01/2018 19:28)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1504696522900681/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (16/01/2018 17:41)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1505488146154852/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (17/01/2018 18:44)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1506461586057508/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (18/01/2018 18:32)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1507372075966459/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (19/01/2018 18:07)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1508267645876902/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (22/01/2018 16:06)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1511071152263218/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (23/01/2018 16:02)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1512052595498407/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (24/01/2018 16:56)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1513077712062562/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (25/01/2018 16:50)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1514042498632750/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (26/01/2018 16:28)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1514957861874547/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (29/01/2018 16:06)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1517796804923986/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (30/01/2018 16:43)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1518741071496226/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (31/01/2018 15:47)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1519647484738918/?type{{=}}3&amp;amp;amp;theater Post] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (01/02/2018 16:20)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1520516167985383/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (02/02/2018 16:43)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1521464631223870/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (05/02/2018 18:27)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1524324544271212/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (08/02/2018 18:04)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1526994310670902/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (09/02/2018 17:23)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1527921753911491/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (15/02/2018 21:05)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1534156963287970/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (19/02/2018 18:20)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1538158459554487/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (27/02/2018 18:28)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1546279558742377/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (28/02/2018 17:02)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1547194268650906/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (02/03/2018 18:03)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1549385328431800/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (06/03/2018 15:14)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1553312171372449/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (29/03/2018 01:17)&#039;&#039;&#039;. [https://www.facebook.com/OfficialOddworld/photos/a.176207019082978.28797.165852613451752/1576480365722296/?type{{=}}3&amp;amp;amp;theater link] on Facebook.&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
=== Other official coverage ===&lt;br /&gt;
{{Ordered list |start=500&lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (04/12/2017)&#039;&#039;&#039;. ‘[http://www.oddworld.com/2017/12/announcing-oddworld-the-lost-archives/ Announcing Oddworld: The Lost Archives]’. Oddworld News. &lt;br /&gt;
|&#039;&#039;&#039;Oddworld Inhabitants (07/03/2018 18:42 UTC)&#039;&#039;&#039;. [https://oddworldinc.tumblr.com/post/171633602001/its-been-a-while-since-weve-posted-on-tumblr Post] on Tumblr.&lt;br /&gt;
}}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:String&amp;diff=1203</id>
		<title>Module:String</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:String&amp;diff=1203"/>
		<updated>2018-04-07T11:49:53Z</updated>

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

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module implements {{section link}}.&lt;br /&gt;
&lt;br /&gt;
local checkType = require(&#039;libraryUtil&#039;).checkType&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function makeSectionLink(page, section, display)&lt;br /&gt;
	display = display or section&lt;br /&gt;
	page = page or &#039;&#039;&lt;br /&gt;
	return string.format(&#039;[[%s#%s|%s]]&#039;, page, section, display)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function normalizeTitle(title)&lt;br /&gt;
	title = mw.ustring.gsub(mw.ustring.gsub(title,&amp;quot;&#039;&amp;quot;,&amp;quot;&amp;quot;),&#039;&amp;quot;&#039;,&#039;&#039;)&lt;br /&gt;
	return mw.title.new(mw.ustring.gsub(title,&amp;quot;%b&amp;lt;&amp;gt;&amp;quot;,&amp;quot;&amp;quot;)).prefixedText&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(page, sections, options, title)&lt;br /&gt;
	-- Validate input.&lt;br /&gt;
	checkType(&#039;_main&#039;, 1, page, &#039;string&#039;, true)&lt;br /&gt;
	checkType(&#039;_main&#039;, 3, options, &#039;table&#039;, true)&lt;br /&gt;
	if sections == nil then&lt;br /&gt;
		sections = {}&lt;br /&gt;
	elseif type(sections) == &#039;string&#039; then&lt;br /&gt;
		sections = {sections}&lt;br /&gt;
	elseif type(sections) ~= &#039;table&#039; then&lt;br /&gt;
		error(string.format(&lt;br /&gt;
			&amp;quot;type error in argument #2 to &#039;_main&#039; &amp;quot; ..&lt;br /&gt;
			&amp;quot;(string, table or nil expected, got %s)&amp;quot;,&lt;br /&gt;
			type(sections)&lt;br /&gt;
		), 2)&lt;br /&gt;
	end&lt;br /&gt;
	options = options or {}&lt;br /&gt;
	title = title or mw.title.getCurrentTitle()&lt;br /&gt;
&lt;br /&gt;
	-- Deal with blank page names elegantly&lt;br /&gt;
	if page and not page:find(&#039;%S&#039;) then&lt;br /&gt;
		page = nil&lt;br /&gt;
		options.nopage = true&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Make the link(s).&lt;br /&gt;
	local isShowingPage = not options.nopage&lt;br /&gt;
	if #sections &amp;lt;= 1 then&lt;br /&gt;
		local linkPage = page or &#039;&#039;&lt;br /&gt;
		local section = sections[1] or &#039;Notes&#039;&lt;br /&gt;
		local display = &#039;§&amp;amp;nbsp;&#039; .. section&lt;br /&gt;
		if isShowingPage then&lt;br /&gt;
			page = page or title.prefixedText&lt;br /&gt;
			if options.display and options.display ~= &#039;&#039; then&lt;br /&gt;
				if normalizeTitle(options.display) == normalizeTitle(page) then&lt;br /&gt;
					display = options.display .. &#039; &#039; .. display&lt;br /&gt;
				else&lt;br /&gt;
					error(string.format(&lt;br /&gt;
						&#039;Display title &amp;quot;%s&amp;quot; was ignored since it is &#039; ..&lt;br /&gt;
						&amp;quot;not equivalent to the page&#039;s actual title&amp;quot;,&lt;br /&gt;
						options.display&lt;br /&gt;
					), 0)&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				display = page .. &#039; &#039; .. display&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		return makeSectionLink(linkPage, section, display)&lt;br /&gt;
	else&lt;br /&gt;
		-- Multiple sections. First, make a list of the links to display.&lt;br /&gt;
		local ret = {}&lt;br /&gt;
		for i, section in ipairs(sections) do&lt;br /&gt;
			ret[i] = makeSectionLink(page, section)&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		-- Assemble the list of links into a string with mw.text.listToText.&lt;br /&gt;
		-- We use the default separator for mw.text.listToText, but a custom&lt;br /&gt;
		-- conjunction. There is also a special case conjunction if we only&lt;br /&gt;
		-- have two links.&lt;br /&gt;
		local conjunction&lt;br /&gt;
		if #sections == 2 then&lt;br /&gt;
			conjunction = &#039;&amp;amp;#8203; and &#039;&lt;br /&gt;
		else&lt;br /&gt;
			conjunction = &#039;, and &#039;&lt;br /&gt;
		end&lt;br /&gt;
		ret = mw.text.listToText(ret, nil, conjunction)&lt;br /&gt;
&lt;br /&gt;
		-- Add the intro text.&lt;br /&gt;
		local intro = &#039;§§&amp;amp;nbsp;&#039;&lt;br /&gt;
		if isShowingPage then&lt;br /&gt;
			intro = (page or title.prefixedText) .. &#039; &#039; .. intro&lt;br /&gt;
		end&lt;br /&gt;
		ret = intro .. ret&lt;br /&gt;
&lt;br /&gt;
		return ret&lt;br /&gt;
	end&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;
		wrappers = &#039;Template:Section link&#039;,&lt;br /&gt;
		valueFunc = function (key, value)&lt;br /&gt;
			value = value:match(&#039;^%s*(.-)%s*$&#039;) -- Trim whitespace&lt;br /&gt;
			-- Allow blank first parameters, as the wikitext template does this.&lt;br /&gt;
			if value ~= &#039;&#039; or key == 1 then&lt;br /&gt;
				return value&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	})&lt;br /&gt;
&lt;br /&gt;
	-- Sort the arguments.&lt;br /&gt;
	local page&lt;br /&gt;
	local sections, options = {}, {}&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		if k == 1 then&lt;br /&gt;
			-- Doing this in the loop because of a bug in [[Module:Arguments]]&lt;br /&gt;
			-- when using pairs with deleted arguments.&lt;br /&gt;
			page = v&lt;br /&gt;
		elseif type(k) == &#039;number&#039; then&lt;br /&gt;
			sections[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;
	-- Extract section from page, if present&lt;br /&gt;
	if page then&lt;br /&gt;
		local p, s = page:match(&#039;^(.-)#(.*)$&#039;)&lt;br /&gt;
		if p then page, sections[1] = p, s end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Compress the sections array.&lt;br /&gt;
	local function compressArray(t)&lt;br /&gt;
		local nums, ret = {}, {}&lt;br /&gt;
		for num in pairs(t) do&lt;br /&gt;
			nums[#nums + 1] = num&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;
	sections = compressArray(sections)&lt;br /&gt;
&lt;br /&gt;
	return p._main(page, sections, options)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Effective_protection_level&amp;diff=1199</id>
		<title>Module:Effective protection level</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Effective_protection_level&amp;diff=1199"/>
		<updated>2018-04-07T11:49:52Z</updated>

		<summary type="html">&lt;p&gt;Max: 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; then&lt;br /&gt;
		error( &#039;First parameter must be one of edit, move, create, upload, autoreview&#039;, 2 )&lt;br /&gt;
	end&lt;br /&gt;
	if title.namespace == 8 then -- MediaWiki namespace&lt;br /&gt;
		return &#039;sysop&#039;&lt;br /&gt;
	elseif title.namespace == 2 and title.isSubpage and ( title.contentModel == &#039;javascript&#039; or title.contentModel == &#039;css&#039; or title.contentModel == &#039;json&#039; ) then -- user JS, CSS or JSON page&lt;br /&gt;
		return &#039;sysop&#039;&lt;br /&gt;
	end&lt;br /&gt;
	local level = title.protectionLevels[action] and title.protectionLevels[action][1]&lt;br /&gt;
	if level == &#039;sysop&#039; or level == &#039;editprotected&#039; then&lt;br /&gt;
		return &#039;sysop&#039;&lt;br /&gt;
	elseif title.cascadingProtection.restrictions[action] and title.cascadingProtection.restrictions[action][1] then -- used by a cascading-protected page&lt;br /&gt;
		return &#039;sysop&#039;&lt;br /&gt;
	elseif level == &#039;templateeditor&#039; then&lt;br /&gt;
		return &#039;templateeditor&#039;&lt;br /&gt;
	elseif action == &#039;move&#039; then&lt;br /&gt;
		local blacklistentry = mw.ext.TitleBlacklist.test(&#039;edit&#039;, pagename) -- Testing action edit is correct, since this is for the source page. The target page name gets tested with action move.&lt;br /&gt;
		if blacklistentry and not blacklistentry.params.autoconfirmed then&lt;br /&gt;
			return &#039;templateeditor&#039;&lt;br /&gt;
		elseif title.namespace == 6 then&lt;br /&gt;
			return &#039;filemover&#039;&lt;br /&gt;
		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>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Delink&amp;diff=1197</id>
		<title>Module:Delink</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Delink&amp;diff=1197"/>
		<updated>2018-04-07T11:49:52Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module de-links most wikitext.&lt;br /&gt;
&lt;br /&gt;
require(&#039;Module:No globals&#039;)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local getArgs&lt;br /&gt;
&lt;br /&gt;
local function delinkReversePipeTrick(s)&lt;br /&gt;
    if s:match(&amp;quot;^%[%[|.*[|\n]&amp;quot;) then -- Check for newlines or multiple pipes.&lt;br /&gt;
        return s&lt;br /&gt;
    else&lt;br /&gt;
        return s:match(&amp;quot;%[%[|(.*)%]%]&amp;quot;)&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function delinkPipeTrick(s)&lt;br /&gt;
    local linkarea, display = &amp;quot;&amp;quot;, &amp;quot;&amp;quot;&lt;br /&gt;
    -- We need to deal with colons, brackets, and commas, per [[Help:Pipe trick]].&lt;br /&gt;
    &lt;br /&gt;
    -- First, remove the text before the first colon, if any.&lt;br /&gt;
    if s:match(&amp;quot;:&amp;quot;) then&lt;br /&gt;
        s = s:match(&amp;quot;%[%[.-:(.*)|%]%]&amp;quot;)&lt;br /&gt;
    -- If there are no colons, grab all of the text apart from the square brackets and the pipe.&lt;br /&gt;
    else&lt;br /&gt;
        s = s:match(&amp;quot;%[%[(.*)|%]%]&amp;quot;)&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- Next up, brackets and commas.&lt;br /&gt;
    if s:match(&amp;quot;%(.-%)$&amp;quot;) then -- Brackets trump commas.&lt;br /&gt;
        s = s:match(&amp;quot;(.-) ?%(.-%)$&amp;quot;)&lt;br /&gt;
    elseif s:match(&amp;quot;,&amp;quot;) then -- If there are no brackets, display only the text before the first comma.&lt;br /&gt;
        s = s:match(&amp;quot;(.-),.*$&amp;quot;)&lt;br /&gt;
    end&lt;br /&gt;
    return s&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function delinkWikilink(s)&lt;br /&gt;
    local result = s&lt;br /&gt;
    -- Deal with the reverse pipe trick.&lt;br /&gt;
    if result:match(&amp;quot;%[%[|&amp;quot;) then&lt;br /&gt;
        return delinkReversePipeTrick(result)&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    result = mw.uri.decode(result, &amp;quot;PATH&amp;quot;) -- decode percent-encoded entities. Leave underscores and plus signs.&lt;br /&gt;
    result = mw.text.decode(result, true) -- decode HTML entities.&lt;br /&gt;
    &lt;br /&gt;
    -- Check for bad titles. To do this we need to find the&lt;br /&gt;
    -- title area of the link, i.e. the part before any pipes.&lt;br /&gt;
    local titlearea&lt;br /&gt;
    if result:match(&amp;quot;|&amp;quot;) then -- Find if we&#039;re dealing with a piped link.&lt;br /&gt;
        titlearea = result:match(&amp;quot;^%[%[(.-)|.*%]%]&amp;quot;)&lt;br /&gt;
    else&lt;br /&gt;
        titlearea = result:match(&amp;quot;^%[%[(.-)%]%]&amp;quot;)&lt;br /&gt;
    end&lt;br /&gt;
    -- Check for bad characters.&lt;br /&gt;
    if mw.ustring.match(titlearea, &amp;quot;[%[%]&amp;lt;&amp;gt;{}%%%c\n]&amp;quot;) then&lt;br /&gt;
        return s&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- Check for categories, interwikis, and files.&lt;br /&gt;
    local colonprefix = result:match(&amp;quot;%[%[(.-):.*%]%]&amp;quot;) or &amp;quot;&amp;quot; -- Get the text before the first colon.&lt;br /&gt;
    local ns = mw.site.namespaces[colonprefix] -- see if this is a known namespace&lt;br /&gt;
    if mw.language.isKnownLanguageTag(colonprefix)&lt;br /&gt;
    or ( ns and ( ns.canonicalName == &amp;quot;File&amp;quot; or ns.canonicalName == &amp;quot;Category&amp;quot; ) ) then&lt;br /&gt;
        return &amp;quot;&amp;quot;&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- Remove the colon if the link is using the [[Help:Colon trick]].&lt;br /&gt;
    if result:match(&amp;quot;%[%[:&amp;quot;) then&lt;br /&gt;
        result = &amp;quot;[[&amp;quot; .. result:match(&amp;quot;%[%[:(.*%]%])&amp;quot;)&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- Deal with links using the [[Help:Pipe trick]].&lt;br /&gt;
    if mw.ustring.match(result, &amp;quot;^%[%[[^|]*|%]%]&amp;quot;) then&lt;br /&gt;
        return delinkPipeTrick(result)&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- Find the display area of the wikilink&lt;br /&gt;
    if result:match(&amp;quot;|&amp;quot;) then -- Find if we&#039;re dealing with a piped link.&lt;br /&gt;
        result = result:match(&amp;quot;^%[%[.-|(.+)%]%]&amp;quot;)&lt;br /&gt;
        -- Remove new lines from the display of multiline piped links,&lt;br /&gt;
        -- where the pipe is before the first new line.&lt;br /&gt;
        result = result:gsub(&amp;quot;\n&amp;quot;, &amp;quot;&amp;quot;)&lt;br /&gt;
    else&lt;br /&gt;
        result = result:match(&amp;quot;^%[%[(.-)%]%]&amp;quot;)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function delinkURL(s)&lt;br /&gt;
    -- Assume we have already delinked internal wikilinks, and that&lt;br /&gt;
    -- we have been passed some text between two square brackets [foo].&lt;br /&gt;
    &lt;br /&gt;
    -- If the text contains a line break it is not formatted as a URL, regardless of other content.&lt;br /&gt;
    if s:match(&amp;quot;\n&amp;quot;) then&lt;br /&gt;
        return s&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- Check if the text has a valid URL prefix and at least one valid URL character.&lt;br /&gt;
    local valid_url_prefixes = {&amp;quot;//&amp;quot;, &amp;quot;http://&amp;quot;, &amp;quot;https://&amp;quot;, &amp;quot;ftp://&amp;quot;, &amp;quot;gopher://&amp;quot;, &amp;quot;mailto:&amp;quot;, &amp;quot;news:&amp;quot;, &amp;quot;irc://&amp;quot;} &lt;br /&gt;
    local url_prefix&lt;br /&gt;
    for i,v in ipairs(valid_url_prefixes) do&lt;br /&gt;
        if mw.ustring.match(s, &#039;^%[&#039; .. v ..&#039;[^&amp;quot;%s].*%]&#039; ) then&lt;br /&gt;
            url_prefix = v&lt;br /&gt;
            break&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
    &lt;br /&gt;
    -- Get display text&lt;br /&gt;
    if not url_prefix then&lt;br /&gt;
        return s&lt;br /&gt;
    end&lt;br /&gt;
    s = s:match(&amp;quot;^%[&amp;quot; .. url_prefix .. &amp;quot;(.*)%]&amp;quot;) -- Grab all of the text after the URL prefix and before the final square bracket.&lt;br /&gt;
    s = s:match(&#039;^.-([&amp;quot;&amp;lt;&amp;gt; ].*)&#039;) or &amp;quot;&amp;quot; -- Grab all of the text after the first URL separator character (&amp;quot;&amp;lt;&amp;gt; ).&lt;br /&gt;
    s = mw.ustring.match(s, &amp;quot;^%s*(%S.*)$&amp;quot;) or &amp;quot;&amp;quot; -- If the separating character was a space, trim it off.&lt;br /&gt;
    &lt;br /&gt;
    local s_decoded = mw.text.decode(s, true)&lt;br /&gt;
    if mw.ustring.match(s_decoded, &amp;quot;%c&amp;quot;) then&lt;br /&gt;
        return s&lt;br /&gt;
    else    &lt;br /&gt;
        return s_decoded&lt;br /&gt;
    end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function delinkLinkClass(s, pattern, delinkFunction)&lt;br /&gt;
    if not type(s) == &amp;quot;string&amp;quot; then&lt;br /&gt;
        error(&amp;quot;Attempt to de-link non-string input.&amp;quot;, 2)&lt;br /&gt;
    end&lt;br /&gt;
    if not ( type(pattern) == &amp;quot;string&amp;quot; and mw.ustring.sub(pattern, 1, 1) == &amp;quot;^&amp;quot; ) then&lt;br /&gt;
        error(&#039;Invalid pattern detected. Patterns must begin with &amp;quot;^&amp;quot;.&#039;, 2)&lt;br /&gt;
    end&lt;br /&gt;
    -- Iterate over the text string, and replace any matched text. using the &lt;br /&gt;
    -- delink function. We need to iterate character by character rather &lt;br /&gt;
    -- than just use gsub, otherwise nested links aren&#039;t detected properly.&lt;br /&gt;
    local result = &amp;quot;&amp;quot;&lt;br /&gt;
    while s ~= &#039;&#039; do&lt;br /&gt;
        -- Replace text using one iteration of gsub.&lt;br /&gt;
        s = mw.ustring.gsub(s, pattern, delinkFunction, 1)&lt;br /&gt;
        -- Append the left-most character to the result string.&lt;br /&gt;
        result = result .. mw.ustring.sub(s, 1, 1)&lt;br /&gt;
        s = mw.ustring.sub(s, 2, -1)&lt;br /&gt;
    end&lt;br /&gt;
    return result&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._delink(args)&lt;br /&gt;
    local text = args[1] or &amp;quot;&amp;quot;&lt;br /&gt;
    if args.refs == &amp;quot;yes&amp;quot; then&lt;br /&gt;
        -- Remove any [[Help:Strip markers]] representing ref tags. In most situations &lt;br /&gt;
        -- this is not a good idea - only use it if you know what you are doing!&lt;br /&gt;
        text = mw.ustring.gsub(text, &amp;quot;UNIQ%w*%-ref%-%d*%-QINU&amp;quot;, &amp;quot;&amp;quot;)&lt;br /&gt;
    end&lt;br /&gt;
    if not (args.comments == &amp;quot;no&amp;quot;) then&lt;br /&gt;
        text = text:gsub(&amp;quot;&amp;lt;!%-%-.-%-%-&amp;gt;&amp;quot;, &amp;quot;&amp;quot;) -- Remove html comments.&lt;br /&gt;
    end&lt;br /&gt;
    if not (args.wikilinks == &amp;quot;no&amp;quot;) then&lt;br /&gt;
        text = delinkLinkClass(text, &amp;quot;^%[%[.-%]%]&amp;quot;, delinkWikilink) -- De-link wikilinks.&lt;br /&gt;
    end&lt;br /&gt;
    if not (args.urls == &amp;quot;no&amp;quot;) then&lt;br /&gt;
        text = delinkLinkClass(text, &amp;quot;^%[.-%]&amp;quot;, delinkURL) -- De-link URLs.&lt;br /&gt;
    end&lt;br /&gt;
    if not (args.whitespace == &amp;quot;no&amp;quot;) then&lt;br /&gt;
        -- Replace single new lines with a single space, but leave double new lines&lt;br /&gt;
        -- and new lines only containing spaces or tabs before a second new line.&lt;br /&gt;
        text = mw.ustring.gsub(text, &amp;quot;([^\n \t][ \t]*)\n([ \t]*[^\n \t])&amp;quot;, &amp;quot;%1 %2&amp;quot;)&lt;br /&gt;
        text = text:gsub(&amp;quot;[ \t]+&amp;quot;, &amp;quot; &amp;quot;) -- Remove extra tabs and spaces.&lt;br /&gt;
    end&lt;br /&gt;
    return text&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.delink(frame)&lt;br /&gt;
    if not getArgs then&lt;br /&gt;
    	getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
    end&lt;br /&gt;
    return p._delink(getArgs(frame, {wrappers = &#039;Template:Delink&#039;}))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Whitelist&amp;diff=1195</id>
		<title>Module:Citation/CS1/Whitelist</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Whitelist&amp;diff=1195"/>
		<updated>2018-04-07T11:49:51Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;br /&gt;
--[[--------------------------&amp;lt; P A R A M E T E R S   N O T   S U P P O R T E D &amp;gt;------------------------------&lt;br /&gt;
&lt;br /&gt;
This is a list of parameters that once were but now are no longer supported:&lt;br /&gt;
&lt;br /&gt;
	[&#039;albumlink&#039;] = nil,			-- unique alias of titlelink used by old cite AV media notes&lt;br /&gt;
	[&#039;albumtype&#039;] = nil,			-- controled inappropriate functionality in the old cite AV media notes&lt;br /&gt;
	[&#039;artist&#039;] = nil,				-- unique alias of others used by old cite AV media notes&lt;br /&gt;
	[&#039;ARXIV&#039;] = nil,				-- not an initialization&lt;br /&gt;
	[&#039;Author&#039;] = nil,				-- non-standard capitalization&lt;br /&gt;
	[&#039;authorformat&#039;] = nil,			-- primarily used to support Vancouver format which functionality now part of name-list-format&lt;br /&gt;
	[&#039;author-format&#039;] = nil,		-- primarily used to support Vancouver format which functionality now part of name-list-format&lt;br /&gt;
	[&#039;author-name-separator&#039;] = nil,-- primarily used to support Vancouver format which functionality now part of name-list-format&lt;br /&gt;
	[&#039;author-separator&#039;] = nil,		-- primarily used to support Vancouver format which functionality now part of name-list-format&lt;br /&gt;
	[&#039;began&#039;] = nil,				-- module handles date ranges; cite episode and cite series&lt;br /&gt;
	[&#039;BIBCODE&#039;] = nil,				-- not an initialization&lt;br /&gt;
	[&#039;callsign&#039;] = nil,				-- cite interview removed&lt;br /&gt;
	[&#039;call-sign&#039;] = nil,			-- cite interview removed&lt;br /&gt;
	[&#039;chapterlink&#039;] = nil,			-- if ever necessary to link to a chapter article, |chapter= can be wikilinked &lt;br /&gt;
	[&#039;chapter-link&#039;] = nil,			-- &lt;br /&gt;
	[&#039;city&#039;] = nil,					-- cite interview removed&lt;br /&gt;
	[&#039;coauthor&#039;] = nil,				-- redundant to |authorn=; not made part of metadata&lt;br /&gt;
	[&#039;coauthors&#039;] = nil,			-- redundant to |authorn=; not made part of metadata&lt;br /&gt;
	[&#039;cointerviewers&#039;] = nil,		-- unique alias of others used by old cite interview&lt;br /&gt;
	[&#039;day&#039;] = nil,					-- deprecated in {{citation/core}} and somehow undeprecated in Module:Citation/CS1 and now finally removed&lt;br /&gt;
	[&#039;director&#039;] = nil,				-- unique alias of author used by old cite DVD-notes&lt;br /&gt;
	[&#039;doi_brokendate&#039;] = nil,                  -- alias of doi-broken-date&lt;br /&gt;
	[&#039;doi_inactivedate&#039;] = nil,                  -- alias of doi-inactive-date&lt;br /&gt;
	[&#039;DoiBroken&#039;] = nil,			-- not used, non-standard captialization&lt;br /&gt;
	[&#039;Editor&#039;] = nil,				-- non-standard capitalization&lt;br /&gt;
	[&#039;editorformat&#039;] = nil,			-- primarily used to support Vancouver format which functionality now part of name-list-format&lt;br /&gt;
	[&#039;EditorSurname&#039;] = nil,		-- non-standard capitalization&lt;br /&gt;
	[&#039;editor-format&#039;] = nil,		-- primarily used to support Vancouver format which functionality now part of name-list-format&lt;br /&gt;
	[&#039;EditorGiven&#039;] = nil,			-- non-standard capitalization&lt;br /&gt;
	[&#039;editor-name-separator&#039;] = nil,-- primarily used to support Vancouver format which functionality now part of name-list-format&lt;br /&gt;
	[&#039;editor-separator&#039;] = nil,		-- primarily used to support Vancouver format which functionality now part of name-list-format&lt;br /&gt;
	[&#039;Embargo&#039;] = nil,				-- not used, non-standard capitalization&lt;br /&gt;
	[&#039;ended&#039;] = nil,				-- module handles date ranges; cite episode and cite series&lt;br /&gt;
	[&#039;month&#039;] = nil,				-- functionality supported by |date=&lt;br /&gt;
	[&#039;name-separator&#039;] = nil,		-- primarily used to support Vancouver format which functionality now part of name-list-format&lt;br /&gt;
	[&#039;notestitle&#039;] = nil,			-- unique alias of chapter used by old cite AV media notes&lt;br /&gt;
	[&#039;PPrefix&#039;] = nil,				-- non-standard capitalization&lt;br /&gt;
	[&#039;PPPrefix&#039;] = nil,				-- not used, non-standard capitalization&lt;br /&gt;
	[&#039;pp-prefix&#039;] = nil,			-- not used, not documented&lt;br /&gt;
	[&#039;p-prefix&#039;] = nil,				-- not used, not documented&lt;br /&gt;
	[&#039;program&#039;] = nil,				-- cite interview removed&lt;br /&gt;
	[&#039;publisherid&#039;] = nil,			-- unique alias of id used by old cite AV media notes and old cite DVD-notes&lt;br /&gt;
	[&#039;Ref&#039;] = nil,					-- non-standard capitalization&lt;br /&gt;
	[&#039;separator&#039;] = nil,			-- this functionality now provided by |mode=&lt;br /&gt;
	[&#039;template doc demo&#039;] = nil,            -- alias of template doc demo&lt;br /&gt;
	[&#039;titleyear&#039;] = nil,			-- unique alias of origyear used by old cite DVD-notes&lt;br /&gt;
	[&#039;trans_chapter&#039;] = nil,                -- alias of trans-chapter&lt;br /&gt;
	[&#039;trans_title&#039;] = nil,                  -- alias of trans-title&lt;br /&gt;
&lt;br /&gt;
	[&#039;Author#&#039;] = nil,				-- non-standard capitalization&lt;br /&gt;
	[&#039;authors#&#039;] = nil,				-- no need for multiple lists of author names&lt;br /&gt;
	[&#039;Editor#&#039;] = nil,				-- non-standard capitalization&lt;br /&gt;
	[&#039;editors#&#039;] = nil,				-- no need for multiple lists of editor names&lt;br /&gt;
	[&#039;EditorGiven#&#039;] = nil,			-- non-standard capitalization&lt;br /&gt;
	[&#039;EditorSurname#&#039;] = nil,		-- non-standard capitalization&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S U P P O R T E D   P A R A M E T E R S &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
Because a steady-state signal conveys no useful information, whitelist.basic_arguments[] list items can have three values:&lt;br /&gt;
	true - these parameters are valid and supported parameters&lt;br /&gt;
	false - these parameters are deprecated but still supported&lt;br /&gt;
	nil - these parameters are no longer supported (when setting a parameter to nil, leave a comment stating the reasons for invalidating the parameter)&lt;br /&gt;
	&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local whitelist = {}&lt;br /&gt;
&lt;br /&gt;
local basic_arguments = {&lt;br /&gt;
	[&#039;accessdate&#039;] = true,&lt;br /&gt;
	[&#039;access-date&#039;] = true,&lt;br /&gt;
	[&#039;agency&#039;] = true,&lt;br /&gt;
	[&#039;airdate&#039;] = true,&lt;br /&gt;
	[&#039;air-date&#039;] = true,&lt;br /&gt;
	[&#039;archivedate&#039;] = true,&lt;br /&gt;
	[&#039;archive-date&#039;] = true,&lt;br /&gt;
	[&#039;archive-format&#039;] = true,&lt;br /&gt;
	[&#039;archiveurl&#039;] = true,&lt;br /&gt;
	[&#039;archive-url&#039;] = true,&lt;br /&gt;
	[&#039;article&#039;] = true,&lt;br /&gt;
	[&#039;arxiv&#039;] = true,&lt;br /&gt;
	[&#039;asin&#039;] = true,&lt;br /&gt;
	[&#039;ASIN&#039;] = true,&lt;br /&gt;
	[&#039;asin-tld&#039;] = true,&lt;br /&gt;
	[&#039;ASIN-TLD&#039;] = true,&lt;br /&gt;
	[&#039;at&#039;] = true,&lt;br /&gt;
	[&#039;author&#039;] = true,&lt;br /&gt;
	[&#039;author-first&#039;] = true,&lt;br /&gt;
	[&#039;author-last&#039;] = true,&lt;br /&gt;
	[&#039;authorlink&#039;] = true,&lt;br /&gt;
	[&#039;author-link&#039;] = true,&lt;br /&gt;
	[&#039;authormask&#039;] = true,&lt;br /&gt;
	[&#039;author-mask&#039;] = true,&lt;br /&gt;
	[&#039;authors&#039;] = true,&lt;br /&gt;
	[&#039;bibcode&#039;] = true,&lt;br /&gt;
	[&#039;bibcode-access&#039;] = true,&lt;br /&gt;
	[&#039;biorxiv&#039;] = true,&lt;br /&gt;
	[&#039;booktitle&#039;] = true,&lt;br /&gt;
	[&#039;book-title&#039;] = true,&lt;br /&gt;
	[&#039;cartography&#039;] = true,&lt;br /&gt;
	[&#039;chapter&#039;] = true,&lt;br /&gt;
	[&#039;chapter-format&#039;] = true,&lt;br /&gt;
	[&#039;chapterurl&#039;] = true,&lt;br /&gt;
	[&#039;chapter-url&#039;] = true,&lt;br /&gt;
	[&#039;chapter-url-access&#039;] = true,&lt;br /&gt;
	[&#039;citeseerx&#039;] = true,&lt;br /&gt;
	[&#039;class&#039;] = true,				-- cite arxiv and arxiv identifiers&lt;br /&gt;
	[&#039;collaboration&#039;] = true,&lt;br /&gt;
	[&#039;conference&#039;] = true,&lt;br /&gt;
	[&#039;conference-format&#039;] = true,&lt;br /&gt;
	[&#039;conferenceurl&#039;] = true,&lt;br /&gt;
	[&#039;conference-url&#039;] = true,&lt;br /&gt;
	[&#039;contribution&#039;] = true,&lt;br /&gt;
	[&#039;contribution-format&#039;] = true,&lt;br /&gt;
	[&#039;contributionurl&#039;] = true,&lt;br /&gt;
	[&#039;contribution-url&#039;] = true,&lt;br /&gt;
	[&#039;contributor&#039;] = true,&lt;br /&gt;
	[&#039;contributor-first&#039;] = true,&lt;br /&gt;
	[&#039;contributor-last&#039;] = true,&lt;br /&gt;
	[&#039;contributor-given&#039;] = true,&lt;br /&gt;
	[&#039;contributor-surname&#039;] = true,&lt;br /&gt;
	[&#039;contributor-link&#039;] = true,&lt;br /&gt;
	[&#039;contributor-mask&#039;] = true,&lt;br /&gt;
	[&#039;credits&#039;] = true,				-- cite episode, cite serial&lt;br /&gt;
	[&#039;date&#039;] = true,&lt;br /&gt;
	[&#039;deadurl&#039;] = true,&lt;br /&gt;
	[&#039;dead-url&#039;] = true,&lt;br /&gt;
	[&#039;degree&#039;] = true,&lt;br /&gt;
	[&#039;department&#039;] = true,&lt;br /&gt;
	[&#039;df&#039;] = true,&lt;br /&gt;
	[&#039;dictionary&#039;] = true,&lt;br /&gt;
	[&#039;displayauthors&#039;] = true,&lt;br /&gt;
	[&#039;display-authors&#039;] = true,&lt;br /&gt;
	[&#039;displayeditors&#039;] = true,&lt;br /&gt;
	[&#039;display-editors&#039;] = true,&lt;br /&gt;
	[&#039;docket&#039;] = true,&lt;br /&gt;
	[&#039;doi&#039;] = true,&lt;br /&gt;
	[&#039;DOI&#039;] = true,&lt;br /&gt;
	[&#039;doi-access&#039;] = true,&lt;br /&gt;
	[&#039;doi-broken&#039;] = true,&lt;br /&gt;
	[&#039;doi-broken-date&#039;] = true,&lt;br /&gt;
	[&#039;doi-inactive-date&#039;] = true,&lt;br /&gt;
	[&#039;edition&#039;] = true,&lt;br /&gt;
	[&#039;editor&#039;] = true,&lt;br /&gt;
	[&#039;editor-first&#039;] = true,&lt;br /&gt;
	[&#039;editor-given&#039;] = true,&lt;br /&gt;
	[&#039;editor-last&#039;] = true,&lt;br /&gt;
	[&#039;editorlink&#039;] = true,&lt;br /&gt;
	[&#039;editor-link&#039;] = true,&lt;br /&gt;
	[&#039;editormask&#039;] = true,&lt;br /&gt;
	[&#039;editor-mask&#039;] = true,&lt;br /&gt;
	[&#039;editors&#039;] = true,&lt;br /&gt;
	[&#039;editor-surname&#039;] = true,&lt;br /&gt;
	[&#039;eissn&#039;] = true,&lt;br /&gt;
	[&#039;EISSN&#039;] = true,&lt;br /&gt;
	[&#039;embargo&#039;] = true,&lt;br /&gt;
	[&#039;encyclopaedia&#039;] = true,&lt;br /&gt;
	[&#039;encyclopedia&#039;] = true,&lt;br /&gt;
	[&#039;entry&#039;] = true,&lt;br /&gt;
	[&#039;episode&#039;] = true,															-- cite serial only TODO: make available to cite episode?&lt;br /&gt;
	[&#039;episodelink&#039;] = true,														-- cite episode and cite serial&lt;br /&gt;
	[&#039;episode-link&#039;] = true,													-- cite episode and cite serial&lt;br /&gt;
	[&#039;eprint&#039;] = true,															-- cite arxiv and arxiv identifiers&lt;br /&gt;
	[&#039;event&#039;] = true,&lt;br /&gt;
	[&#039;event-format&#039;] = true,&lt;br /&gt;
	[&#039;eventurl&#039;] = true,&lt;br /&gt;
	[&#039;event-url&#039;] = true,&lt;br /&gt;
	[&#039;first&#039;] = true,&lt;br /&gt;
	[&#039;format&#039;] = true,&lt;br /&gt;
	[&#039;given&#039;] = true,&lt;br /&gt;
	[&#039;hdl&#039;] = true,&lt;br /&gt;
	[&#039;HDL&#039;] = true,&lt;br /&gt;
	[&#039;hdl-access&#039;] = true,&lt;br /&gt;
	[&#039;host&#039;] = true,&lt;br /&gt;
	[&#039;id&#039;] = true,&lt;br /&gt;
	[&#039;ID&#039;] = true,&lt;br /&gt;
	[&#039;ignoreisbnerror&#039;] = true,&lt;br /&gt;
	[&#039;ignore-isbn-error&#039;] = true,&lt;br /&gt;
	[&#039;in&#039;] = true,&lt;br /&gt;
	[&#039;inset&#039;] = true,&lt;br /&gt;
	[&#039;institution&#039;] = true,&lt;br /&gt;
	[&#039;interviewer&#039;] = true,&lt;br /&gt;
	[&#039;interviewer-first&#039;] = true,&lt;br /&gt;
	[&#039;interviewer-last&#039;] = true,&lt;br /&gt;
	[&#039;interviewerlink&#039;] = true,&lt;br /&gt;
	[&#039;interviewer-link&#039;] = true,&lt;br /&gt;
	[&#039;interviewermask&#039;] = true,&lt;br /&gt;
	[&#039;interviewer-mask&#039;] = true,&lt;br /&gt;
	[&#039;interviewers&#039;] = true,&lt;br /&gt;
	[&#039;isbn&#039;] = true,&lt;br /&gt;
	[&#039;ISBN&#039;] = true,&lt;br /&gt;
	[&#039;isbn13&#039;] = true,&lt;br /&gt;
	[&#039;ISBN13&#039;] = true,&lt;br /&gt;
	[&#039;ismn&#039;] = true,&lt;br /&gt;
	[&#039;ISMN&#039;] = true,&lt;br /&gt;
	[&#039;issn&#039;] = true,&lt;br /&gt;
	[&#039;ISSN&#039;] = true,&lt;br /&gt;
	[&#039;issue&#039;] = true,&lt;br /&gt;
	[&#039;jfm&#039;] = true,&lt;br /&gt;
	[&#039;JFM&#039;] = true,&lt;br /&gt;
	[&#039;journal&#039;] = true,&lt;br /&gt;
	[&#039;jstor&#039;] = true,&lt;br /&gt;
	[&#039;JSTOR&#039;] = true,&lt;br /&gt;
	[&#039;jstor-access&#039;] = true,&lt;br /&gt;
	[&#039;language&#039;] = true,&lt;br /&gt;
	[&#039;last&#039;] = true,&lt;br /&gt;
	[&#039;lastauthoramp&#039;] = true,&lt;br /&gt;
	[&#039;last-author-amp&#039;] = true,&lt;br /&gt;
	[&#039;laydate&#039;] = true,&lt;br /&gt;
	[&#039;lay-date&#039;] = true,&lt;br /&gt;
	[&#039;laysource&#039;] = true,&lt;br /&gt;
	[&#039;lay-source&#039;] = true,&lt;br /&gt;
	[&#039;laysummary&#039;] = true,&lt;br /&gt;
	[&#039;lay-summary&#039;] = true,&lt;br /&gt;
	[&#039;lay-format&#039;] = true,&lt;br /&gt;
	[&#039;layurl&#039;] = true,&lt;br /&gt;
	[&#039;lay-url&#039;] = true,&lt;br /&gt;
	[&#039;lccn&#039;] = true,&lt;br /&gt;
	[&#039;LCCN&#039;] = true,&lt;br /&gt;
	[&#039;location&#039;] = true,&lt;br /&gt;
	[&#039;magazine&#039;] = true,&lt;br /&gt;
	[&#039;mailinglist&#039;] = true,				-- cite mailing list only&lt;br /&gt;
	[&#039;mailing-list&#039;] = true,			-- cite mailing list only&lt;br /&gt;
	[&#039;map&#039;] = true,						-- cite map only&lt;br /&gt;
	[&#039;map-format&#039;] = true,				-- cite map only&lt;br /&gt;
	[&#039;mapurl&#039;] = true,					-- cite map only&lt;br /&gt;
	[&#039;map-url&#039;] = true,					-- cite map only&lt;br /&gt;
	[&#039;medium&#039;] = true,&lt;br /&gt;
	[&#039;message-id&#039;] = true,			-- cite newsgroup&lt;br /&gt;
	[&#039;minutes&#039;] = true,&lt;br /&gt;
	[&#039;mode&#039;] = true,&lt;br /&gt;
	[&#039;mr&#039;] = true,&lt;br /&gt;
	[&#039;MR&#039;] = true,&lt;br /&gt;
	[&#039;name-list-format&#039;] = true,&lt;br /&gt;
	[&#039;network&#039;] = true,&lt;br /&gt;
	[&#039;newsgroup&#039;] = true,&lt;br /&gt;
	[&#039;newspaper&#039;] = true,&lt;br /&gt;
	[&#039;nocat&#039;] = true,&lt;br /&gt;
	[&#039;no-cat&#039;] = true,&lt;br /&gt;
	[&#039;nopp&#039;] = true,&lt;br /&gt;
	[&#039;no-pp&#039;] = true,&lt;br /&gt;
	[&#039;notracking&#039;] = true,&lt;br /&gt;
	[&#039;no-tracking&#039;] = true,&lt;br /&gt;
	[&#039;number&#039;] = true,&lt;br /&gt;
	[&#039;oclc&#039;] = true,&lt;br /&gt;
	[&#039;OCLC&#039;] = true,&lt;br /&gt;
	[&#039;ol&#039;] = true,&lt;br /&gt;
	[&#039;OL&#039;] = true,&lt;br /&gt;
	[&#039;ol-access&#039;] = true,&lt;br /&gt;
	[&#039;origyear&#039;] = true,&lt;br /&gt;
	[&#039;orig-year&#039;] = true,&lt;br /&gt;
	[&#039;osti&#039;] = true,&lt;br /&gt;
	[&#039;OSTI&#039;] = true,&lt;br /&gt;
	[&#039;osti-access&#039;] = true,&lt;br /&gt;
	[&#039;others&#039;] = true,&lt;br /&gt;
	[&#039;p&#039;] = true,&lt;br /&gt;
	[&#039;page&#039;] = true,&lt;br /&gt;
	[&#039;pages&#039;] = true,&lt;br /&gt;
	[&#039;people&#039;] = true,&lt;br /&gt;
	[&#039;periodical&#039;] = true,&lt;br /&gt;
	[&#039;place&#039;] = true,&lt;br /&gt;
	[&#039;pmc&#039;] = true,&lt;br /&gt;
	[&#039;PMC&#039;] = true,&lt;br /&gt;
	[&#039;pmid&#039;] = true,&lt;br /&gt;
	[&#039;PMID&#039;] = true,&lt;br /&gt;
	[&#039;postscript&#039;] = true,&lt;br /&gt;
	[&#039;pp&#039;] = true,&lt;br /&gt;
	[&#039;publicationdate&#039;] = true,&lt;br /&gt;
	[&#039;publication-date&#039;] = true,&lt;br /&gt;
	[&#039;publicationplace&#039;] = true,&lt;br /&gt;
	[&#039;publication-place&#039;] = true,&lt;br /&gt;
	[&#039;publisher&#039;] = true,&lt;br /&gt;
	[&#039;quotation&#039;] = true,&lt;br /&gt;
	[&#039;quote&#039;] = true,&lt;br /&gt;
	[&#039;ref&#039;] = true,&lt;br /&gt;
	[&#039;registration&#039;] = true,&lt;br /&gt;
	[&#039;rfc&#039;] = true,&lt;br /&gt;
	[&#039;RFC&#039;] = true,&lt;br /&gt;
	[&#039;scale&#039;] = true,&lt;br /&gt;
	[&#039;script-chapter&#039;] = true,&lt;br /&gt;
	[&#039;script-title&#039;] = true,&lt;br /&gt;
	[&#039;season&#039;] = true,&lt;br /&gt;
	[&#039;section&#039;] = true,&lt;br /&gt;
	[&#039;section-format&#039;] = true,&lt;br /&gt;
	[&#039;sections&#039;] = true,					-- cite map only&lt;br /&gt;
	[&#039;sectionurl&#039;] = true,&lt;br /&gt;
	[&#039;section-url&#039;] = true,&lt;br /&gt;
	[&#039;series&#039;] = true,&lt;br /&gt;
	[&#039;serieslink&#039;] = true,&lt;br /&gt;
	[&#039;series-link&#039;] = true,&lt;br /&gt;
	[&#039;seriesno&#039;] = true,&lt;br /&gt;
	[&#039;series-no&#039;] = true,&lt;br /&gt;
	[&#039;seriesnumber&#039;] = true,&lt;br /&gt;
	[&#039;series-number&#039;] = true,&lt;br /&gt;
	[&#039;series-separator&#039;] = true,&lt;br /&gt;
	[&#039;sheet&#039;] = true,															-- cite map only&lt;br /&gt;
	[&#039;sheets&#039;] = true,															-- cite map only&lt;br /&gt;
	[&#039;ssrn&#039;] = true,&lt;br /&gt;
	[&#039;SSRN&#039;] = true,&lt;br /&gt;
	[&#039;station&#039;] = true,&lt;br /&gt;
	[&#039;subject&#039;] = true,&lt;br /&gt;
	[&#039;subjectlink&#039;] = true,&lt;br /&gt;
	[&#039;subject-link&#039;] = true,&lt;br /&gt;
	[&#039;subscription&#039;] = true,&lt;br /&gt;
	[&#039;surname&#039;] = true,&lt;br /&gt;
	[&#039;template-doc-demo&#039;] = true,&lt;br /&gt;
	[&#039;time&#039;] = true,&lt;br /&gt;
	[&#039;timecaption&#039;] = true,&lt;br /&gt;
	[&#039;time-caption&#039;] = true,&lt;br /&gt;
	[&#039;title&#039;] = true,&lt;br /&gt;
	[&#039;titlelink&#039;] = true,&lt;br /&gt;
	[&#039;title-link&#039;] = true,&lt;br /&gt;
	[&#039;trans-chapter&#039;] = true,&lt;br /&gt;
	[&#039;trans-map&#039;] = true,&lt;br /&gt;
	[&#039;transcript&#039;] = true,&lt;br /&gt;
	[&#039;transcript-format&#039;] = true,&lt;br /&gt;
	[&#039;transcripturl&#039;] = true,&lt;br /&gt;
	[&#039;transcript-url&#039;] = true,&lt;br /&gt;
	[&#039;trans-title&#039;] = true,&lt;br /&gt;
	[&#039;translator&#039;] = true,&lt;br /&gt;
	[&#039;translator-first&#039;] = true,&lt;br /&gt;
	[&#039;translator-last&#039;] = true,&lt;br /&gt;
	[&#039;translator-given&#039;] = true,&lt;br /&gt;
	[&#039;translator-surname&#039;] = true,&lt;br /&gt;
	[&#039;translator-link&#039;] = true,&lt;br /&gt;
	[&#039;translator-mask&#039;] = true,&lt;br /&gt;
	[&#039;type&#039;] = true,&lt;br /&gt;
	[&#039;url&#039;] = true,&lt;br /&gt;
	[&#039;URL&#039;] = true,&lt;br /&gt;
	[&#039;url-access&#039;] = true,&lt;br /&gt;
	[&#039;vauthors&#039;] = true,&lt;br /&gt;
	[&#039;veditors&#039;] = true,&lt;br /&gt;
	[&#039;version&#039;] = true,&lt;br /&gt;
	[&#039;via&#039;] = true,&lt;br /&gt;
	[&#039;volume&#039;] = true,&lt;br /&gt;
	[&#039;website&#039;] = true,&lt;br /&gt;
	[&#039;work&#039;] = true,&lt;br /&gt;
	[&#039;year&#039;] = true,&lt;br /&gt;
	[&#039;zbl&#039;] = true,&lt;br /&gt;
	[&#039;ZBL&#039;] = true,&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
local numbered_arguments = {&lt;br /&gt;
	[&#039;author#&#039;] = true,&lt;br /&gt;
	[&#039;author-first#&#039;] = true,&lt;br /&gt;
	[&#039;author#-first&#039;] = true,&lt;br /&gt;
	[&#039;author-last#&#039;] = true,&lt;br /&gt;
	[&#039;author#-last&#039;] = true,&lt;br /&gt;
	[&#039;author-link#&#039;] = true,&lt;br /&gt;
	[&#039;author#link&#039;] = true,&lt;br /&gt;
	[&#039;author#-link&#039;] = true,&lt;br /&gt;
	[&#039;authorlink#&#039;] = true,&lt;br /&gt;
	[&#039;author-mask#&#039;] = true,&lt;br /&gt;
	[&#039;author#mask&#039;] = true,&lt;br /&gt;
	[&#039;author#-mask&#039;] = true,&lt;br /&gt;
	[&#039;authormask#&#039;] = true,&lt;br /&gt;
	[&#039;contributor#&#039;] = true,&lt;br /&gt;
	[&#039;contributor-first#&#039;] = true,&lt;br /&gt;
	[&#039;contributor#-first&#039;] = true,&lt;br /&gt;
	[&#039;contributor-last#&#039;] = true,&lt;br /&gt;
	[&#039;contributor#-last&#039;] = true,&lt;br /&gt;
	[&#039;contributor-given#&#039;] = true,&lt;br /&gt;
	[&#039;contributor#-given&#039;] = true,&lt;br /&gt;
	[&#039;contributor-surname#&#039;] = true,&lt;br /&gt;
	[&#039;contributor#-surname&#039;] = true,&lt;br /&gt;
	[&#039;contributor-link#&#039;] = true,&lt;br /&gt;
	[&#039;contributor#-link&#039;] = true,&lt;br /&gt;
	[&#039;contributor-mask#&#039;] = true,&lt;br /&gt;
	[&#039;contributor#-mask&#039;] = true,&lt;br /&gt;
	[&#039;editor#&#039;] = true,&lt;br /&gt;
	[&#039;editor-first#&#039;] = true,&lt;br /&gt;
	[&#039;editor#-first&#039;] = true,&lt;br /&gt;
	[&#039;editor#-given&#039;] = true,&lt;br /&gt;
	[&#039;editor-given#&#039;] = true,&lt;br /&gt;
	[&#039;editor-last#&#039;] = true,&lt;br /&gt;
	[&#039;editor#-last&#039;] = true,&lt;br /&gt;
	[&#039;editor-link#&#039;] = true,&lt;br /&gt;
	[&#039;editor#link&#039;] = true,&lt;br /&gt;
	[&#039;editor#-link&#039;] = true,&lt;br /&gt;
	[&#039;editorlink#&#039;] = true,&lt;br /&gt;
	[&#039;editor-mask#&#039;] = true,&lt;br /&gt;
	[&#039;editor#mask&#039;] = true,&lt;br /&gt;
	[&#039;editor#-mask&#039;] = true,&lt;br /&gt;
	[&#039;editormask#&#039;] = true,&lt;br /&gt;
	[&#039;editor#-surname&#039;] = true,&lt;br /&gt;
	[&#039;editor-surname#&#039;] = true,&lt;br /&gt;
	[&#039;first#&#039;] = true,&lt;br /&gt;
	[&#039;given#&#039;] = true,&lt;br /&gt;
	[&#039;interviewer#&#039;] = true,&lt;br /&gt;
	[&#039;interviewer-first#&#039;] = true,&lt;br /&gt;
	[&#039;interviewer#-first&#039;] = true,&lt;br /&gt;
	[&#039;interviewer-last#&#039;] = true,&lt;br /&gt;
	[&#039;interviewer#-last&#039;] = true,&lt;br /&gt;
	[&#039;interviewer-link#&#039;] = true,&lt;br /&gt;
	[&#039;interviewer#-link&#039;] = true,&lt;br /&gt;
	[&#039;interviewer-mask#&#039;] = true,&lt;br /&gt;
	[&#039;interviewer#-mask&#039;] = true,&lt;br /&gt;
	[&#039;last#&#039;] = true,&lt;br /&gt;
	[&#039;subject#&#039;] = true,&lt;br /&gt;
	[&#039;subject-link#&#039;] = true,&lt;br /&gt;
	[&#039;subject#link&#039;] = true,&lt;br /&gt;
	[&#039;subject#-link&#039;] = true,&lt;br /&gt;
	[&#039;subjectlink#&#039;] = true,&lt;br /&gt;
	[&#039;surname#&#039;] = true,&lt;br /&gt;
	[&#039;translator#&#039;] = true,&lt;br /&gt;
	[&#039;translator-first#&#039;] = true,&lt;br /&gt;
	[&#039;translator#-first&#039;] = true,&lt;br /&gt;
	[&#039;translator-last#&#039;] = true,&lt;br /&gt;
	[&#039;translator#-last&#039;] = true,&lt;br /&gt;
	[&#039;translator-given#&#039;] = true,&lt;br /&gt;
	[&#039;translator#-given&#039;] = true,&lt;br /&gt;
	[&#039;translator-surname#&#039;] = true,&lt;br /&gt;
	[&#039;translator#-surname&#039;] = true,&lt;br /&gt;
	[&#039;translator-link#&#039;] = true,&lt;br /&gt;
	[&#039;translator#-link&#039;] = true,&lt;br /&gt;
	[&#039;translator-mask#&#039;] = true,&lt;br /&gt;
	[&#039;translator#-mask&#039;] = true,&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C I T E   A R X I V   S U P P O R T E D   P A R A M E T E R S &amp;gt;----------------&lt;br /&gt;
&lt;br /&gt;
This is an experiment that attempts to use validate() and a limited list of valid parameters to validate the&lt;br /&gt;
parameters provided in a cite arxiv template.  This method might be expanded to other templates being considered.&lt;br /&gt;
&lt;br /&gt;
Because a steady-state signal conveys no useful information, whitelist.basic_arguments[] list items can have three values:&lt;br /&gt;
	true - these parameters are valid and supported parameters&lt;br /&gt;
	false - these parameters are deprecated but still supported&lt;br /&gt;
	nil - these parameters are no longer supported (when setting a parameter to nil, leave a comment stating the reasons for invalidating the parameter)&lt;br /&gt;
	&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
This is a list of parameters that once were but now are no longer supported:&lt;br /&gt;
	[&#039;ARXIV&#039;] = nil,				-- not an initialization&lt;br /&gt;
	[&#039;version&#039;] = nil,				-- this is the cite arxiv parameter; |version= still supported by other cs1|2 templates&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local arxiv_basic_arguments = {&lt;br /&gt;
	[&#039;arxiv&#039;] = true,&lt;br /&gt;
	[&#039;class&#039;] = true,															-- cite arxiv and arxiv identifiers&lt;br /&gt;
	[&#039;eprint&#039;] = true,															-- cite arxiv and arxiv identifiers&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C I T E   B I O R X I V   S U P P O R T E D   P A R A M E T E R S &amp;gt;------------&lt;br /&gt;
&lt;br /&gt;
This is an experiment that attempts to use validate() and a limited list of valid parameters to validate the&lt;br /&gt;
parameters provided in a cite biorxiv template.  This method might be expanded to other templates being considered.&lt;br /&gt;
&lt;br /&gt;
Because a steady-state signal conveys no useful information, whitelist.basic_arguments[] list items can have three values:&lt;br /&gt;
	true - these parameters are valid and supported parameters&lt;br /&gt;
	false - these parameters are deprecated but still supported&lt;br /&gt;
	nil - these parameters are no longer supported (when setting a parameter to nil, leave a comment stating the reasons for invalidating the parameter)&lt;br /&gt;
	&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local biorxiv_basic_arguments = {&lt;br /&gt;
	[&#039;biorxiv&#039;] = true,&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C I T E   C I T E S E E R X   S U P P O R T E D   P A R A M E T E R S &amp;gt;--------&lt;br /&gt;
&lt;br /&gt;
This is an experiment that attempts to use validate() and a limited list of valid parameters to validate the&lt;br /&gt;
parameters provided in a cite citeseerx template.  This method might be expanded to other templates being considered.&lt;br /&gt;
&lt;br /&gt;
Because a steady-state signal conveys no useful information, whitelist.basic_arguments[] list items can have three values:&lt;br /&gt;
	true - these parameters are valid and supported parameters&lt;br /&gt;
	false - these parameters are deprecated but still supported&lt;br /&gt;
	nil - these parameters are no longer supported (when setting a parameter to nil, leave a comment stating the reasons for invalidating the parameter)&lt;br /&gt;
	&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local citeseerx_basic_arguments = {&lt;br /&gt;
	[&#039;citeseerx&#039;] = true,&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; L I M I T E D   S U P P O R T E D   P A R A M E T E R S &amp;gt;----------------------&lt;br /&gt;
&lt;br /&gt;
This is an experiment that attempts to use validate() and a limited list of valid parameters to validate the&lt;br /&gt;
parameters provided in a cite arxiv, cite biorxiv, or cite citeseerx templates.  These parameters are common to&lt;br /&gt;
all three templates&lt;br /&gt;
&lt;br /&gt;
Because a steady-state signal conveys no useful information, whitelist.basic_arguments[] list items can have three values:&lt;br /&gt;
	true - these parameters are valid and supported parameters&lt;br /&gt;
	false - these parameters are deprecated but still supported&lt;br /&gt;
	nil - these parameters are no longer supported (when setting a parameter to nil, leave a comment stating the reasons for invalidating the parameter)&lt;br /&gt;
	&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local limited_basic_arguments = {&lt;br /&gt;
	[&#039;at&#039;] = true,&lt;br /&gt;
	[&#039;author&#039;] = true,&lt;br /&gt;
	[&#039;author-first&#039;] = true,&lt;br /&gt;
	[&#039;author-last&#039;] = true,&lt;br /&gt;
	[&#039;authorlink&#039;] = true,&lt;br /&gt;
	[&#039;author-link&#039;] = true,&lt;br /&gt;
	[&#039;authormask&#039;] = true,&lt;br /&gt;
	[&#039;author-mask&#039;] = true,&lt;br /&gt;
	[&#039;authors&#039;] = true,&lt;br /&gt;
	[&#039;collaboration&#039;] = true,&lt;br /&gt;
	[&#039;date&#039;] = true,&lt;br /&gt;
	[&#039;df&#039;] = true,&lt;br /&gt;
	[&#039;display-authors&#039;] = true,&lt;br /&gt;
	[&#039;first&#039;] = true,&lt;br /&gt;
	[&#039;given&#039;] = true,&lt;br /&gt;
	[&#039;language&#039;] = true,&lt;br /&gt;
	[&#039;last&#039;] = true,&lt;br /&gt;
	[&#039;lastauthoramp&#039;] = true,&lt;br /&gt;
	[&#039;last-author-amp&#039;] = true,&lt;br /&gt;
	[&#039;mode&#039;] = true,&lt;br /&gt;
	[&#039;name-list-format&#039;] = true,&lt;br /&gt;
	[&#039;nocat&#039;] = true,&lt;br /&gt;
	[&#039;no-cat&#039;] = true,&lt;br /&gt;
	[&#039;notracking&#039;] = true,&lt;br /&gt;
	[&#039;no-tracking&#039;] = true,&lt;br /&gt;
	[&#039;p&#039;] = true,&lt;br /&gt;
	[&#039;page&#039;] = true,&lt;br /&gt;
	[&#039;pages&#039;] = true,&lt;br /&gt;
	[&#039;postscript&#039;] = true,&lt;br /&gt;
	[&#039;pp&#039;] = true,&lt;br /&gt;
	[&#039;quotation&#039;] = true,&lt;br /&gt;
	[&#039;quote&#039;] = true,&lt;br /&gt;
	[&#039;ref&#039;] = true,&lt;br /&gt;
	[&#039;surname&#039;] = true,&lt;br /&gt;
	[&#039;template-doc-demo&#039;] = true,&lt;br /&gt;
	[&#039;title&#039;] = true,&lt;br /&gt;
	[&#039;url&#039;] = true,&lt;br /&gt;
	[&#039;URL&#039;] = true,&lt;br /&gt;
	[&#039;vauthors&#039;] = true,&lt;br /&gt;
	[&#039;year&#039;] = true,&lt;br /&gt;
}&lt;br /&gt;
local limited_numbered_arguments = {&lt;br /&gt;
	[&#039;author#&#039;] = true,&lt;br /&gt;
	[&#039;author-first#&#039;] = true,&lt;br /&gt;
	[&#039;author#-first&#039;] = true,&lt;br /&gt;
	[&#039;author-last#&#039;] = true,&lt;br /&gt;
	[&#039;author#-last&#039;] = true,&lt;br /&gt;
	[&#039;author-link#&#039;] = true,&lt;br /&gt;
	[&#039;author#link&#039;] = true,&lt;br /&gt;
	[&#039;author#-link&#039;] = true,&lt;br /&gt;
	[&#039;authorlink#&#039;] = true,&lt;br /&gt;
	[&#039;author-mask#&#039;] = true,&lt;br /&gt;
	[&#039;author#mask&#039;] = true,&lt;br /&gt;
	[&#039;author#-mask&#039;] = true,&lt;br /&gt;
	[&#039;authormask#&#039;] = true,&lt;br /&gt;
	[&#039;first#&#039;] = true,&lt;br /&gt;
	[&#039;given#&#039;] = true,&lt;br /&gt;
	[&#039;last#&#039;] = true,&lt;br /&gt;
	[&#039;surname#&#039;] = true,&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
return {&lt;br /&gt;
	basic_arguments = basic_arguments,&lt;br /&gt;
	numbered_arguments = numbered_arguments,&lt;br /&gt;
	limited_basic_arguments = limited_basic_arguments,&lt;br /&gt;
	limited_numbered_arguments = limited_numbered_arguments,&lt;br /&gt;
	arxiv_basic_arguments = arxiv_basic_arguments,&lt;br /&gt;
	biorxiv_basic_arguments = biorxiv_basic_arguments,&lt;br /&gt;
	citeseerx_basic_arguments = citeseerx_basic_arguments&lt;br /&gt;
};&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Utilities&amp;diff=1193</id>
		<title>Module:Citation/CS1/Utilities</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Utilities&amp;diff=1193"/>
		<updated>2018-04-07T11:49:51Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;local u = {}&lt;br /&gt;
&lt;br /&gt;
local z = {&lt;br /&gt;
	error_categories = {};														-- for categorizing citations that contain errors&lt;br /&gt;
	error_ids = {};&lt;br /&gt;
	message_tail = {};&lt;br /&gt;
	maintenance_cats = {};														-- for categorizing citations that aren&#039;t erroneous per se, but could use a little work&lt;br /&gt;
	properties_cats = {};														-- for categorizing citations based on certain properties, language of source for instance&lt;br /&gt;
};&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; F O R W A R D   D E C L A R A T I O N S &amp;gt;--------------------------------------&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local cfg;																		-- table of tables imported from selected Module:Citation/CS1/Configuration&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ S E T &amp;gt;------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Returns true if argument is set; false otherwise. Argument is &#039;set&#039; when it exists (not nil) or when it is not an empty string.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_set( var )&lt;br /&gt;
	return not (var == nil or var == &#039;&#039;);&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I N _ A R R A Y &amp;gt;--------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Whether needle is in haystack&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function in_array( needle, haystack )&lt;br /&gt;
	if needle == nil then&lt;br /&gt;
		return false;&lt;br /&gt;
	end&lt;br /&gt;
	for n,v in ipairs( haystack ) do&lt;br /&gt;
		if v == needle then&lt;br /&gt;
			return n;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return false;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S U B S T I T U T E &amp;gt;----------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Populates numbered arguments in a message string using an argument table.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function substitute( msg, args )&lt;br /&gt;
	return args and mw.message.newRawMessage( msg, args ):plain() or msg;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; E R R O R _ C O M M E N T &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Wraps error messages with css markup according to the state of hidden.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function error_comment( content, hidden )&lt;br /&gt;
	return substitute( hidden and cfg.presentation[&#039;hidden-error&#039;] or cfg.presentation[&#039;visible-error&#039;], content );&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; M A K E _ W I K I L I N K &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Makes a wikilink; when bot link and display text is provided, returns a wikilink in the form [[L|D]]; if only&lt;br /&gt;
link is provided, returns a wikilink in the form [[L]]; if neither are provided or link is omitted, returns an&lt;br /&gt;
empty string.&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function make_wikilink (link, display)&lt;br /&gt;
	if is_set (link) then&lt;br /&gt;
		if is_set (display) then&lt;br /&gt;
			return table.concat ({&#039;[[&#039;, link, &#039;|&#039;, display, &#039;]]&#039;});&lt;br /&gt;
		else&lt;br /&gt;
			return table.concat ({&#039;[[&#039;, link, &#039;]]&#039;});&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		return &#039;&#039;;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E T _ E R R O R &amp;gt;--------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Sets an error condition and returns the appropriate error message.  The actual placement of the error message in the output is&lt;br /&gt;
the responsibility of the calling function.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function set_error( error_id, arguments, raw, prefix, suffix )&lt;br /&gt;
	local error_state = cfg.error_conditions[ error_id ];&lt;br /&gt;
	&lt;br /&gt;
	prefix = prefix or &amp;quot;&amp;quot;;&lt;br /&gt;
	suffix = suffix or &amp;quot;&amp;quot;;&lt;br /&gt;
	&lt;br /&gt;
	if error_state == nil then&lt;br /&gt;
		error( cfg.messages[&#039;undefined_error&#039;] );								-- because missing error handler in Module:Citation/CS1/Configuration&lt;br /&gt;
	elseif is_set( error_state.category ) then&lt;br /&gt;
		table.insert( z.error_categories, error_state.category );&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local message = substitute( error_state.message, arguments );&lt;br /&gt;
&lt;br /&gt;
	message = table.concat (&lt;br /&gt;
		{&lt;br /&gt;
		message,&lt;br /&gt;
		&#039; (&#039;,&lt;br /&gt;
		make_wikilink (&lt;br /&gt;
			table.concat (&lt;br /&gt;
				{&lt;br /&gt;
				cfg.messages[&#039;help page link&#039;],&lt;br /&gt;
				&#039;#&#039;,&lt;br /&gt;
				error_state.anchor&lt;br /&gt;
				}),&lt;br /&gt;
			cfg.messages[&#039;help page label&#039;]),&lt;br /&gt;
		&#039;)&#039;&lt;br /&gt;
		});&lt;br /&gt;
&lt;br /&gt;
--	message = table.concat ({message, &#039; (&#039;, substitute (cfg.presentation[&#039;wikilink&#039;], &lt;br /&gt;
--		{cfg.messages[&#039;help page link&#039;] .. &#039;#&#039; .. error_state.anchor, cfg.messages[&#039;help page label&#039;]}), &#039;)&#039;});&lt;br /&gt;
--	message = message .. &amp;quot; ([[&amp;quot; .. cfg.messages[&#039;help page link&#039;] .. &lt;br /&gt;
--		&amp;quot;#&amp;quot; .. error_state.anchor .. &amp;quot;|&amp;quot; ..&lt;br /&gt;
--		cfg.messages[&#039;help page label&#039;] .. &amp;quot;]])&amp;quot;;&lt;br /&gt;
	&lt;br /&gt;
	z.error_ids[ error_id ] = true;&lt;br /&gt;
	if in_array( error_id, { &#039;bare_url_missing_title&#039;, &#039;trans_missing_title&#039; } )&lt;br /&gt;
			and z.error_ids[&#039;citation_missing_title&#039;] then&lt;br /&gt;
		return &#039;&#039;, false;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	message = table.concat({ prefix, message, suffix });&lt;br /&gt;
	&lt;br /&gt;
	if raw == true then&lt;br /&gt;
		return message, error_state.hidden;&lt;br /&gt;
	end		&lt;br /&gt;
		&lt;br /&gt;
	return error_comment( message, error_state.hidden );&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; I S _ A L I A S _ U S E D &amp;gt;-----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
This function is used by select_one() to determine if one of a list of alias parameters is in the argument list&lt;br /&gt;
provided by the template.&lt;br /&gt;
&lt;br /&gt;
Input:&lt;br /&gt;
	args – pointer to the arguments table from calling template&lt;br /&gt;
	alias – one of the list of possible aliases in the aliases lists from Module:Citation/CS1/Configuration&lt;br /&gt;
	index – for enumerated parameters, identifies which one&lt;br /&gt;
	enumerated – true/false flag used choose how enumerated aliases are examined&lt;br /&gt;
	value – value associated with an alias that has previously been selected; nil if not yet selected&lt;br /&gt;
	selected – the alias that has previously been selected; nil if not yet selected&lt;br /&gt;
	error_list – list of aliases that are duplicates of the alias already selected&lt;br /&gt;
&lt;br /&gt;
Returns:&lt;br /&gt;
	value – value associated with alias we selected or that was previously selected or nil if an alias not yet selected&lt;br /&gt;
	selected – the alias we selected or the alias that was previously selected or nil if an alias not yet selected&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_alias_used (args, alias, index, enumerated, value, selected, error_list)&lt;br /&gt;
	if enumerated then															-- is this a test for an enumerated parameters?&lt;br /&gt;
		alias = alias:gsub (&#039;#&#039;, index);										-- replace &#039;#&#039; with the value in index&lt;br /&gt;
	else&lt;br /&gt;
		alias = alias:gsub (&#039;#&#039;, &#039;&#039;);											-- remove &#039;#&#039; if it exists&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set(args[alias]) then													-- alias is in the template&#039;s argument list&lt;br /&gt;
		if value ~= nil and selected ~= alias then								-- if we have already selected one of the aliases&lt;br /&gt;
			local skip;&lt;br /&gt;
			for _, v in ipairs(error_list) do									-- spin through the error list to see if we&#039;ve added this alias&lt;br /&gt;
				if v == alias then&lt;br /&gt;
					skip = true;&lt;br /&gt;
					break;														-- has been added so stop looking &lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			if not skip then													-- has not been added so&lt;br /&gt;
				table.insert( error_list, alias );								-- add error alias to the error list&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			value = args[alias];												-- not yet selected an alias, so select this one&lt;br /&gt;
			selected = alias;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return value, selected;														-- return newly selected alias, or previously selected alias&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; A D D _ M A I N T _ C A T &amp;gt;------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Adds a category to z.maintenance_cats using names from the configuration file with additional text if any.&lt;br /&gt;
To prevent duplication, the added_maint_cats table lists the categories by key that have been added to z.maintenance_cats.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local added_maint_cats = {}														-- list of maintenance categories that have been added to z.maintenance_cats&lt;br /&gt;
local function add_maint_cat (key, arguments)&lt;br /&gt;
	if not added_maint_cats [key] then&lt;br /&gt;
		added_maint_cats [key] = true;											-- note that we&#039;ve added this category&lt;br /&gt;
		table.insert( z.maintenance_cats, substitute (cfg.maint_cats [key], arguments));	-- make name then add to table&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S A F E _ F O R _ I T A L I C S &amp;gt;----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Protects a string that will be wrapped in wiki italic markup &#039;&#039; ... &#039;&#039;&lt;br /&gt;
&lt;br /&gt;
Note: We cannot use &amp;lt;i&amp;gt; for italics, as the expected behavior for italics specified by &#039;&#039;...&#039;&#039; in the title is that&lt;br /&gt;
they will be inverted (i.e. unitalicized) in the resulting references.  In addition, &amp;lt;i&amp;gt; and &#039;&#039; tend to interact&lt;br /&gt;
poorly under Mediawiki&#039;s HTML tidy.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function safe_for_italics( str )&lt;br /&gt;
	if not is_set(str) then&lt;br /&gt;
		return str;&lt;br /&gt;
	else&lt;br /&gt;
		if str:sub(1,1) == &amp;quot;&#039;&amp;quot; then str = &amp;quot;&amp;lt;span&amp;gt;&amp;lt;/span&amp;gt;&amp;quot; .. str; end&lt;br /&gt;
		if str:sub(-1,-1) == &amp;quot;&#039;&amp;quot; then str = str .. &amp;quot;&amp;lt;span&amp;gt;&amp;lt;/span&amp;gt;&amp;quot;; end&lt;br /&gt;
		&lt;br /&gt;
		-- Remove newlines as they break italics.&lt;br /&gt;
		return str:gsub( &#039;\n&#039;, &#039; &#039; );&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; W R A P _ S T Y L E &amp;gt;----------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Applies styling to various parameters.  Supplied string is wrapped using a message_list configuration taking one&lt;br /&gt;
argument; protects italic styled parameters.  Additional text taken from citation_config.presentation - the reason&lt;br /&gt;
this function is similar to but separate from wrap_msg().&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function wrap_style (key, str)&lt;br /&gt;
	if not is_set( str ) then&lt;br /&gt;
		return &amp;quot;&amp;quot;;&lt;br /&gt;
	elseif in_array( key, { &#039;italic-title&#039;, &#039;trans-italic-title&#039; } ) then&lt;br /&gt;
		str = safe_for_italics( str );&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return substitute( cfg.presentation[key], {str} );&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E L E C T _ O N E &amp;gt;----------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Chooses one matching parameter from a list of parameters to consider.  The list of parameters to consider is just&lt;br /&gt;
names.  For parameters that may be enumerated, the position of the numerator in the parameter name is identified&lt;br /&gt;
by the &#039;#&#039; so |author-last1= and |author1-last= are represented as &#039;author-last#&#039; and &#039;author#-last&#039;.&lt;br /&gt;
&lt;br /&gt;
Because enumerated parameter |&amp;lt;param&amp;gt;1= is an alias of |&amp;lt;param&amp;gt;= we must test for both possibilities.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Generates an error if more than one match is present.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function select_one( args, aliases_list, error_condition, index )&lt;br /&gt;
	local value = nil;															-- the value assigned to the selected parameter&lt;br /&gt;
	local selected = &#039;&#039;;														-- the name of the parameter we have chosen&lt;br /&gt;
	local error_list = {};&lt;br /&gt;
&lt;br /&gt;
	if index ~= nil then index = tostring(index); end&lt;br /&gt;
&lt;br /&gt;
	for _, alias in ipairs( aliases_list ) do									-- for each alias in the aliases list&lt;br /&gt;
		if alias:match (&#039;#&#039;) then												-- if this alias can be enumerated&lt;br /&gt;
			if &#039;1&#039; == index then												-- when index is 1 test for enumerated and non-enumerated aliases&lt;br /&gt;
				value, selected = is_alias_used (args, alias, index, false, value, selected, error_list);	-- first test for non-enumerated alias&lt;br /&gt;
			end&lt;br /&gt;
			value, selected = is_alias_used (args, alias, index, true, value, selected, error_list);		-- test for enumerated alias&lt;br /&gt;
		else&lt;br /&gt;
			value, selected = is_alias_used (args, alias, index, false, value, selected, error_list);		--test for non-enumerated alias&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if #error_list &amp;gt; 0 and &#039;none&#039; ~= error_condition then						-- for cases where this code is used outside of extract_names()&lt;br /&gt;
		local error_str = &amp;quot;&amp;quot;;&lt;br /&gt;
		for _, k in ipairs( error_list ) do&lt;br /&gt;
			if error_str ~= &amp;quot;&amp;quot; then error_str = error_str .. cfg.messages[&#039;parameter-separator&#039;] end&lt;br /&gt;
			error_str = error_str .. wrap_style (&#039;parameter&#039;, k);&lt;br /&gt;
		end&lt;br /&gt;
		if #error_list &amp;gt; 1 then&lt;br /&gt;
			error_str = error_str .. cfg.messages[&#039;parameter-final-separator&#039;];&lt;br /&gt;
		else&lt;br /&gt;
			error_str = error_str .. cfg.messages[&#039;parameter-pair-separator&#039;];&lt;br /&gt;
		end&lt;br /&gt;
		error_str = error_str .. wrap_style (&#039;parameter&#039;, selected);&lt;br /&gt;
		table.insert( z.message_tail, { set_error( error_condition, {error_str}, true ) } );&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return value, selected;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; R E M O V E _ W I K I _ L I N K &amp;gt;----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Gets the display text from a wikilink like [[A|B]] or [[B]] gives B&lt;br /&gt;
&lt;br /&gt;
The str:gsub() returns either A|B froma [[A|B]] or B from [[B]] or B from B (no wikilink markup).&lt;br /&gt;
&lt;br /&gt;
In l(), l:gsub() removes the link and pipe (if they exist); the second :gsub() trims white space from the label&lt;br /&gt;
if str was wrapped in wikilink markup.  Presumably, this is because without wikimarkup in str, there is no match&lt;br /&gt;
in the initial gsub, the replacement function l() doesn&#039;t get called.&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function remove_wiki_link (str)&lt;br /&gt;
	return (str:gsub( &amp;quot;%[%[([^%[%]]*)%]%]&amp;quot;, function(l)&lt;br /&gt;
		return l:gsub( &amp;quot;^[^|]*|(.*)$&amp;quot;, &amp;quot;%1&amp;quot; ):gsub(&amp;quot;^%s*(.-)%s*$&amp;quot;, &amp;quot;%1&amp;quot;);&lt;br /&gt;
	end));&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; I S _ W I K I L I N K &amp;gt;--------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Determines if str is a wikilink, extracts, and returns the the wikilink type, link text, and display text parts.&lt;br /&gt;
If str is a complex wikilink ([[L|D]]):&lt;br /&gt;
	returns wl_type 2 and D and L from [[L|D]];&lt;br /&gt;
if str is a simple wikilink ([[D]])&lt;br /&gt;
	returns wl_type 1 and D from [[D]] and L as empty string;&lt;br /&gt;
if not a wikilink:&lt;br /&gt;
	returns wl_type 0, str as D, and L as empty string.&lt;br /&gt;
&lt;br /&gt;
trims leading and trailing white space and pipes from L and D ([[L|]] and [[|D]] are accepted by MediaWiki and&lt;br /&gt;
treated like [[D]]; while [[|D|]] is not accepted by MediaWiki, here, we accept it and return D without the pipes).&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function is_wikilink (str)&lt;br /&gt;
	local D, L&lt;br /&gt;
	local wl_type = 2;															-- assume that str is a complex wikilink [[L|D]]&lt;br /&gt;
&lt;br /&gt;
	L, D = str:match (&#039;%[%[([^|]+)|([^%]]+)%]%]&#039;);								-- get L and D from [[L|D]] &lt;br /&gt;
&lt;br /&gt;
	if not is_set (D) then														-- if no separate link&lt;br /&gt;
		D = str:match (&#039;%[%[([^%]]*)|*%]%]&#039;);									-- get D from [[D]]&lt;br /&gt;
		wl_type = 1; &lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if not is_set (D) then														-- no wikilink markup&lt;br /&gt;
		D = str;																-- return the string as D&lt;br /&gt;
		wl_type = 0;															-- but say that it is not a wikilink&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	D = mw.text.trim (D, &#039;%s|&#039;);												-- trim white space and pipe characters &lt;br /&gt;
	L = L and mw.text.trim (L, &#039;%s|&#039;);&lt;br /&gt;
	&lt;br /&gt;
	return wl_type, D, L or &#039;&#039;;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E T _ S E L E C T E D _ M O D U L E S &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
Sets local cfg table to same (live or sandbox) as that used by the other modules.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function set_selected_modules (cfg_table_ptr)&lt;br /&gt;
	cfg = cfg_table_ptr;&lt;br /&gt;
	&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
return {																		-- return exported functions and tables&lt;br /&gt;
	is_set = is_set,&lt;br /&gt;
	in_array = in_array,&lt;br /&gt;
	substitute = substitute,&lt;br /&gt;
	error_comment = error_comment,&lt;br /&gt;
	set_error = set_error,&lt;br /&gt;
	select_one = select_one,&lt;br /&gt;
	add_maint_cat = add_maint_cat,&lt;br /&gt;
	wrap_style = wrap_style,&lt;br /&gt;
	safe_for_italics = safe_for_italics,&lt;br /&gt;
	remove_wiki_link = remove_wiki_link,&lt;br /&gt;
	is_wikilink = is_wikilink,&lt;br /&gt;
	make_wikilink = make_wikilink,&lt;br /&gt;
	set_selected_modules = set_selected_modules,&lt;br /&gt;
	z = z,&lt;br /&gt;
	}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Identifiers&amp;diff=1191</id>
		<title>Module:Citation/CS1/Identifiers</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Identifiers&amp;diff=1191"/>
		<updated>2018-04-07T11:49:51Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;br /&gt;
local identifiers = {};&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; F O R W A R D   D E C L A R A T I O N S &amp;gt;--------------------------------------&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local is_set, in_array, set_error, select_one, add_maint_cat, substitute, make_wikilink;	-- functions in Module:Citation/CS1/Utilities&lt;br /&gt;
&lt;br /&gt;
local z;																		-- table of tables defined in Module:Citation/CS1/Utilities&lt;br /&gt;
&lt;br /&gt;
local cfg;																		-- table of configuration tables that are defined in Module:Citation/CS1/Configuration&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--============================&amp;lt;&amp;lt; H E L P E R   F U N C T I O N S &amp;gt;&amp;gt;============================================&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; E X T E R N A L _ L I N K _ I D &amp;gt;----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Formats a wiki style external link&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function external_link_id(options)&lt;br /&gt;
	local url_string = options.id;&lt;br /&gt;
	local ext_link;&lt;br /&gt;
	&lt;br /&gt;
	if options.encode == true or options.encode == nil then&lt;br /&gt;
		url_string = mw.uri.encode( url_string );&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	ext_link = mw.ustring.format (&#039;[%s%s%s %s]&#039;, options.prefix, url_string, options.suffix or &amp;quot;&amp;quot;, mw.text.nowiki(options.id));&lt;br /&gt;
	if is_set(options.access) then&lt;br /&gt;
		ext_link = substitute (cfg.presentation[&#039;access-signal&#039;], {ext_link, cfg.presentation[options.access]});	-- add the free-to-read / paywall lock&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return table.concat	({&lt;br /&gt;
		make_wikilink (options.link, options.label),&lt;br /&gt;
		options.separator or &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
		ext_link&lt;br /&gt;
		});&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I N T E R N A L _ L I N K _ I D &amp;gt;----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Formats a wiki style internal link&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function internal_link_id(options)&lt;br /&gt;
&lt;br /&gt;
	return table.concat (&lt;br /&gt;
		{&lt;br /&gt;
		make_wikilink (options.link, options.label),&lt;br /&gt;
		options.separator or &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
		make_wikilink (&lt;br /&gt;
			table.concat (&lt;br /&gt;
				{&lt;br /&gt;
				options.prefix,&lt;br /&gt;
				options.id,&lt;br /&gt;
				options.suffix or &#039;&#039;&lt;br /&gt;
				}),&lt;br /&gt;
			mw.text.nowiki (options.id)&lt;br /&gt;
			);&lt;br /&gt;
		});&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ E M B A R G O E D &amp;gt;------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Determines if a PMC identifier&#039;s online version is embargoed. Compares the date in |embargo= against today&#039;s date.  If embargo date is&lt;br /&gt;
in the future, returns the content of |embargo=; otherwise, returns and empty string because the embargo has expired or because&lt;br /&gt;
|embargo= was not set in this cite.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_embargoed (embargo)&lt;br /&gt;
	if is_set (embargo) then&lt;br /&gt;
		local lang = mw.getContentLanguage();&lt;br /&gt;
		local good1, embargo_date, good2, todays_date;&lt;br /&gt;
		good1, embargo_date = pcall( lang.formatDate, lang, &#039;U&#039;, embargo );&lt;br /&gt;
		good2, todays_date = pcall( lang.formatDate, lang, &#039;U&#039; );&lt;br /&gt;
	&lt;br /&gt;
		if good1 and good2 then													-- if embargo date and today&#039;s date are good dates&lt;br /&gt;
			if tonumber( embargo_date ) &amp;gt;= tonumber( todays_date ) then			-- is embargo date is in the future?&lt;br /&gt;
				return embargo;													-- still embargoed&lt;br /&gt;
			else&lt;br /&gt;
				add_maint_cat (&#039;embargo&#039;)&lt;br /&gt;
				return &#039;&#039;;														-- unset because embargo has expired&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return &#039;&#039;;																	-- |embargo= not set return empty string&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; IS _ V A L I D _ I S X N &amp;gt;-----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
ISBN-10 and ISSN validator code calculates checksum across all isbn/issn digits including the check digit.&lt;br /&gt;
ISBN-13 is checked in isbn().&lt;br /&gt;
&lt;br /&gt;
If the number is valid the result will be 0. Before calling this function, issbn/issn must be checked for length&lt;br /&gt;
and stripped of dashes, spaces and other non-isxn characters.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_valid_isxn (isxn_str, len)&lt;br /&gt;
	local temp = 0;&lt;br /&gt;
	isxn_str = { isxn_str:byte(1, len) };	-- make a table of byte values &#039;0&#039; → 0x30 .. &#039;9&#039; → 0x39, &#039;X&#039; → 0x58&lt;br /&gt;
	len = len+1;							-- adjust to be a loop counter&lt;br /&gt;
	for i, v in ipairs( isxn_str ) do		-- loop through all of the bytes and calculate the checksum&lt;br /&gt;
		if v == string.byte( &amp;quot;X&amp;quot; ) then		-- if checkdigit is X (compares the byte value of &#039;X&#039; which is 0x58)&lt;br /&gt;
			temp = temp + 10*( len - i );	-- it represents 10 decimal&lt;br /&gt;
		else&lt;br /&gt;
			temp = temp + tonumber( string.char(v) )*(len-i);&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return temp % 11 == 0;					-- returns true if calculation result is zero&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; IS _ V A L I D _ I S X N _ 1 3 &amp;gt;-----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
ISBN-13 and ISMN validator code calculates checksum across all 13 isbn/ismn digits including the check digit.&lt;br /&gt;
If the number is valid, the result will be 0. Before calling this function, isbn-13/ismn must be checked for length&lt;br /&gt;
and stripped of dashes, spaces and other non-isxn-13 characters.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_valid_isxn_13 (isxn_str)&lt;br /&gt;
	local temp=0;&lt;br /&gt;
	&lt;br /&gt;
	isxn_str = { isxn_str:byte(1, 13) };										-- make a table of byte values &#039;0&#039; → 0x30 .. &#039;9&#039; → 0x39&lt;br /&gt;
	for i, v in ipairs( isxn_str ) do&lt;br /&gt;
		temp = temp + (3 - 2*(i % 2)) * tonumber( string.char(v) );				-- multiply odd index digits by 1, even index digits by 3 and sum; includes check digit&lt;br /&gt;
	end&lt;br /&gt;
	return temp % 10 == 0;														-- sum modulo 10 is zero when isbn-13/ismn is correct&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; N O R M A L I Z E _ L C C N &amp;gt;--------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
lccn normalization (http://www.loc.gov/marc/lccn-namespace.html#normalization)&lt;br /&gt;
1. Remove all blanks.&lt;br /&gt;
2. If there is a forward slash (/) in the string, remove it, and remove all characters to the right of the forward slash.&lt;br /&gt;
3. If there is a hyphen in the string:&lt;br /&gt;
	a. Remove it.&lt;br /&gt;
	b. Inspect the substring following (to the right of) the (removed) hyphen. Then (and assuming that steps 1 and 2 have been carried out):&lt;br /&gt;
		1. All these characters should be digits, and there should be six or less. (not done in this function)&lt;br /&gt;
		2. If the length of the substring is less than 6, left-fill the substring with zeroes until the length is six.&lt;br /&gt;
&lt;br /&gt;
Returns a normalized lccn for lccn() to validate.  There is no error checking (step 3.b.1) performed in this function.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function normalize_lccn (lccn)&lt;br /&gt;
	lccn = lccn:gsub (&amp;quot;%s&amp;quot;, &amp;quot;&amp;quot;);									-- 1. strip whitespace&lt;br /&gt;
&lt;br /&gt;
	if nil ~= string.find (lccn,&#039;/&#039;) then&lt;br /&gt;
		lccn = lccn:match (&amp;quot;(.-)/&amp;quot;);								-- 2. remove forward slash and all character to the right of it&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local prefix&lt;br /&gt;
	local suffix&lt;br /&gt;
	prefix, suffix = lccn:match (&amp;quot;(.+)%-(.+)&amp;quot;);						-- 3.a remove hyphen by splitting the string into prefix and suffix&lt;br /&gt;
&lt;br /&gt;
	if nil ~= suffix then											-- if there was a hyphen&lt;br /&gt;
		suffix=string.rep(&amp;quot;0&amp;quot;, 6-string.len (suffix)) .. suffix;	-- 3.b.2 left fill the suffix with 0s if suffix length less than 6&lt;br /&gt;
		lccn=prefix..suffix;										-- reassemble the lccn&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return lccn;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
--============================&amp;lt;&amp;lt; I D E N T I F I E R   F U N C T I O N S &amp;gt;&amp;gt;====================================&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; A R X I V &amp;gt;--------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
See: http://arxiv.org/help/arxiv_identifier&lt;br /&gt;
&lt;br /&gt;
format and error check arXiv identifier.  There are three valid forms of the identifier:&lt;br /&gt;
the first form, valid only between date codes 9108 and 0703 is:&lt;br /&gt;
	arXiv:&amp;lt;archive&amp;gt;.&amp;lt;class&amp;gt;/&amp;lt;date code&amp;gt;&amp;lt;number&amp;gt;&amp;lt;version&amp;gt;&lt;br /&gt;
where:&lt;br /&gt;
	&amp;lt;archive&amp;gt; is a string of alpha characters - may be hyphenated; no other punctuation&lt;br /&gt;
	&amp;lt;class&amp;gt; is a string of alpha characters - may be hyphenated; no other punctuation&lt;br /&gt;
	&amp;lt;date code&amp;gt; is four digits in the form YYMM where YY is the last two digits of the four-digit year and MM is the month number January = 01&lt;br /&gt;
		first digit of YY for this form can only 9 and 0&lt;br /&gt;
	&amp;lt;number&amp;gt; is a three-digit number&lt;br /&gt;
	&amp;lt;version&amp;gt; is a 1 or more digit number preceded with a lowercase v; no spaces (undocumented)&lt;br /&gt;
	&lt;br /&gt;
the second form, valid from April 2007 through December 2014 is:&lt;br /&gt;
	arXiv:&amp;lt;date code&amp;gt;.&amp;lt;number&amp;gt;&amp;lt;version&amp;gt;&lt;br /&gt;
where:&lt;br /&gt;
	&amp;lt;date code&amp;gt; is four digits in the form YYMM where YY is the last two digits of the four-digit year and MM is the month number January = 01&lt;br /&gt;
	&amp;lt;number&amp;gt; is a four-digit number&lt;br /&gt;
	&amp;lt;version&amp;gt; is a 1 or more digit number preceded with a lowercase v; no spaces&lt;br /&gt;
&lt;br /&gt;
the third form, valid from January 2015 is:&lt;br /&gt;
	arXiv:&amp;lt;date code&amp;gt;.&amp;lt;number&amp;gt;&amp;lt;version&amp;gt;&lt;br /&gt;
where:&lt;br /&gt;
	&amp;lt;date code&amp;gt; and &amp;lt;version&amp;gt; are as defined for 0704-1412&lt;br /&gt;
	&amp;lt;number&amp;gt; is a five-digit number&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function arxiv (id, class)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;ARXIV&#039;];&lt;br /&gt;
	local year, month, version;&lt;br /&gt;
	local err_cat = &#039;&#039;;&lt;br /&gt;
	local text;&lt;br /&gt;
	&lt;br /&gt;
	if id:match(&amp;quot;^%a[%a%.%-]+/[90]%d[01]%d%d%d%d$&amp;quot;) or id:match(&amp;quot;^%a[%a%.%-]+/[90]%d[01]%d%d%d%dv%d+$&amp;quot;) then	-- test for the 9108-0703 format w/ &amp;amp; w/o version&lt;br /&gt;
		year, month = id:match(&amp;quot;^%a[%a%.%-]+/([90]%d)([01]%d)%d%d%d[v%d]*$&amp;quot;);&lt;br /&gt;
		year = tonumber(year);&lt;br /&gt;
		month = tonumber(month);&lt;br /&gt;
		if ((not (90 &amp;lt; year or 8 &amp;gt; year)) or (1 &amp;gt; month or 12 &amp;lt; month)) or		-- if invalid year or invalid month&lt;br /&gt;
			((91 == year and 7 &amp;gt; month) or (7 == year and 3 &amp;lt; month)) then		-- if years ok, are starting and ending months ok?&lt;br /&gt;
				err_cat = &#039; &#039; .. set_error( &#039;bad_arxiv&#039; );						-- set error message&lt;br /&gt;
		end&lt;br /&gt;
	elseif id:match(&amp;quot;^%d%d[01]%d%.%d%d%d%d$&amp;quot;) or id:match(&amp;quot;^%d%d[01]%d%.%d%d%d%dv%d+$&amp;quot;) then	-- test for the 0704-1412 w/ &amp;amp; w/o version&lt;br /&gt;
		year, month = id:match(&amp;quot;^(%d%d)([01]%d)%.%d%d%d%d[v%d]*$&amp;quot;);&lt;br /&gt;
		year = tonumber(year);&lt;br /&gt;
		month = tonumber(month);&lt;br /&gt;
		if ((7 &amp;gt; year) or (14 &amp;lt; year) or (1 &amp;gt; month or 12 &amp;lt; month)) or			-- is year invalid or is month invalid? (doesn&#039;t test for future years)&lt;br /&gt;
			((7 == year) and (4 &amp;gt; month)) then --or									-- when year is 07, is month invalid (before April)?&lt;br /&gt;
				err_cat = &#039; &#039; .. set_error( &#039;bad_arxiv&#039; );						-- set error message&lt;br /&gt;
		end&lt;br /&gt;
	elseif id:match(&amp;quot;^%d%d[01]%d%.%d%d%d%d%d$&amp;quot;) or id:match(&amp;quot;^%d%d[01]%d%.%d%d%d%d%dv%d+$&amp;quot;) then	-- test for the 1501- format w/ &amp;amp; w/o version&lt;br /&gt;
		year, month = id:match(&amp;quot;^(%d%d)([01]%d)%.%d%d%d%d%d[v%d]*$&amp;quot;);&lt;br /&gt;
		year = tonumber(year);&lt;br /&gt;
		month = tonumber(month);&lt;br /&gt;
		if ((15 &amp;gt; year) or (1 &amp;gt; month or 12 &amp;lt; month)) then						-- is year invalid or is month invalid? (doesn&#039;t test for future years)&lt;br /&gt;
			err_cat = &#039; &#039; .. set_error( &#039;bad_arxiv&#039; );							-- set error message&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_arxiv&#039; );								-- arXiv id doesn&#039;t match any format&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	text = external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
			prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode, access=handler.access}) .. err_cat;&lt;br /&gt;
&lt;br /&gt;
	if is_set (class) then&lt;br /&gt;
		class = &#039; [[&#039; .. &#039;//arxiv.org/archive/&#039; .. class .. &#039; &#039; .. class .. &#039;]]&#039;;	-- external link within square brackets, not wikilink&lt;br /&gt;
	else&lt;br /&gt;
		class = &#039;&#039;;																-- empty string for concatenation&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return text .. class;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; B I B C O D E &amp;gt;--------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Validates (sort of) and formats a bibcode id.&lt;br /&gt;
&lt;br /&gt;
Format for bibcodes is specified here: http://adsabs.harvard.edu/abs_doc/help_pages/data.html#bibcodes&lt;br /&gt;
&lt;br /&gt;
But, this: 2015arXiv151206696F is apparently valid so apparently, the only things that really matter are length, 19 characters&lt;br /&gt;
and first four digits must be a year.  This function makes these tests:&lt;br /&gt;
	length must be 19 characters&lt;br /&gt;
	characters in position&lt;br /&gt;
		1–4 must be digits and must represent a year in the range of 1000 – next year&lt;br /&gt;
		5 must be a letter&lt;br /&gt;
		6 must be letter, ampersand, or dot (ampersand cannot directly precede a dot; &amp;amp;. )&lt;br /&gt;
		7–8 must be letter, digit, ampersand, or dot (ampersand cannot directly precede a dot; &amp;amp;. )&lt;br /&gt;
		9–18 must be letter, digit, or dot&lt;br /&gt;
		19 must be a letter or dot&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function bibcode (id, access)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;BIBCODE&#039;];&lt;br /&gt;
	local err_type;&lt;br /&gt;
	local year;&lt;br /&gt;
&lt;br /&gt;
	local text = external_link_id({link=handler.link, label=handler.label,&lt;br /&gt;
		prefix=handler.prefix, id=id, separator=handler.separator, encode=handler.encode,&lt;br /&gt;
		access=access});&lt;br /&gt;
	&lt;br /&gt;
	if 19 ~= id:len() then&lt;br /&gt;
		err_type = &#039;length&#039;;&lt;br /&gt;
	else&lt;br /&gt;
		year = id:match (&amp;quot;^(%d%d%d%d)[%a][%a&amp;amp;%.][%a&amp;amp;%.%d][%a&amp;amp;%.%d][%a%d%.]+[%a%.]$&amp;quot;)	-- &lt;br /&gt;
		if not year then														-- if nil then no pattern match&lt;br /&gt;
			err_type = &#039;value&#039;;													-- so value error&lt;br /&gt;
		else&lt;br /&gt;
			local next_year = tonumber(os.date (&#039;%Y&#039;))+1;						-- get the current year as a number and add one for next year&lt;br /&gt;
			year = tonumber (year);												-- convert year portion of bibcode to a number&lt;br /&gt;
			if (1000 &amp;gt; year) or (year &amp;gt; next_year) then&lt;br /&gt;
				err_type = &#039;year&#039;;												-- year out of bounds&lt;br /&gt;
			end&lt;br /&gt;
			if id:find(&#039;&amp;amp;%.&#039;) then&lt;br /&gt;
				err_type = &#039;journal&#039;;											-- journal abbreviation must not have &#039;&amp;amp;.&#039; (if it does its missing a letter)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set (err_type) then													-- if there was an error detected&lt;br /&gt;
		text = text .. &#039; &#039; .. set_error( &#039;bad_bibcode&#039;, {err_type});&lt;br /&gt;
	end&lt;br /&gt;
	return text;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; B I O R X I V &amp;gt;-----------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Format bioRxiv id and do simple error checking.  BiorXiv ids are exactly 6 digits.&lt;br /&gt;
The bioRxiv id is the number following the last slash in the bioRxiv-issued DOI:&lt;br /&gt;
https://doi.org/10.1101/078733 -&amp;gt; 078733&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function biorxiv(id)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;BIORXIV&#039;];&lt;br /&gt;
	local err_cat = &#039;&#039;;															-- presume that bioRxiv id is valid&lt;br /&gt;
	&lt;br /&gt;
	if nil == id:match(&amp;quot;^%d%d%d%d%d%d$&amp;quot;) then									-- if bioRxiv id has anything but six digits&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_biorxiv&#039;);	-- set an error message&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
			prefix=handler.prefix,id=id,separator=handler.separator,&lt;br /&gt;
			encode=handler.encode, access=handler.access}) .. err_cat;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C I T E S E E R X &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
CiteSeerX use their own notion of &amp;quot;doi&amp;quot; (not to be confused with the identifiers resolved via doi.org).&lt;br /&gt;
&lt;br /&gt;
The description of the structure of this identifier can be found at Help_talk:Citation_Style_1/Archive_26#CiteSeerX_id_structure&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function citeseerx (id)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;CITESEERX&#039;];&lt;br /&gt;
	local matched;&lt;br /&gt;
	&lt;br /&gt;
	local text = external_link_id({link=handler.link, label=handler.label,&lt;br /&gt;
		prefix=handler.prefix, id=id, separator=handler.separator, encode=handler.encode,&lt;br /&gt;
		access=handler.access});&lt;br /&gt;
	&lt;br /&gt;
	matched = id:match (&amp;quot;^10%.1%.1%.[1-9]%d?%d?%d?%.[1-9]%d?%d?%d?$&amp;quot;);&lt;br /&gt;
	if not matched then&lt;br /&gt;
		text = text .. &#039; &#039; .. set_error( &#039;bad_citeseerx&#039; );&lt;br /&gt;
	end&lt;br /&gt;
	return text;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; D O I &amp;gt;------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Formats a DOI and checks for DOI errors.&lt;br /&gt;
&lt;br /&gt;
DOI names contain two parts: prefix and suffix separated by a forward slash.&lt;br /&gt;
	Prefix: directory indicator &#039;10.&#039; followed by a registrant code&lt;br /&gt;
	Suffix: character string of any length chosen by the registrant&lt;br /&gt;
&lt;br /&gt;
This function checks a DOI name for: prefix/suffix.  If the doi name contains spaces or endashes, or, if it ends&lt;br /&gt;
with a period or a comma, this function will emit a bad_doi error message.&lt;br /&gt;
&lt;br /&gt;
DOI names are case-insensitive and can incorporate any printable Unicode characters so the test for spaces, endash,&lt;br /&gt;
and terminal punctuation may not be technically correct but it appears, that in practice these characters are rarely&lt;br /&gt;
if ever used in doi names.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function doi(id, inactive, access)&lt;br /&gt;
	local cat = &amp;quot;&amp;quot;&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;DOI&#039;];&lt;br /&gt;
	&lt;br /&gt;
	local text;&lt;br /&gt;
	if is_set(inactive) then&lt;br /&gt;
		local inactive_year = inactive:match(&amp;quot;%d%d%d%d&amp;quot;) or &#039;&#039;;					-- try to get the year portion from the inactive date&lt;br /&gt;
		if is_set(inactive_year) then&lt;br /&gt;
			table.insert( z.error_categories, &amp;quot;Pages with DOIs inactive since &amp;quot; .. inactive_year );&lt;br /&gt;
		else&lt;br /&gt;
			table.insert( z.error_categories, &amp;quot;Pages with inactive DOIs&amp;quot; );		-- when inactive doesn&#039;t contain a recognizable year&lt;br /&gt;
		end&lt;br /&gt;
		inactive = &amp;quot; (&amp;quot; .. cfg.messages[&#039;inactive&#039;] .. &amp;quot; &amp;quot; .. inactive .. &amp;quot;)&amp;quot; &lt;br /&gt;
	end&lt;br /&gt;
	text = external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
		prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode, access=access}) .. (inactive or &#039;&#039;)&lt;br /&gt;
&lt;br /&gt;
	if nil == id:match(&amp;quot;^10%.[^%s–]-/[^%s–]-[^%.,]$&amp;quot;) then						-- doi must begin with &#039;10.&#039;, must contain a fwd slash, must not contain spaces or endashes, and must not end with period or comma&lt;br /&gt;
		cat = &#039; &#039; .. set_error( &#039;bad_doi&#039; );&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return text .. cat &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; H D L &amp;gt;------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Formats an HDL with minor error checking.&lt;br /&gt;
&lt;br /&gt;
HDL names contain two parts: prefix and suffix separated by a forward slash.&lt;br /&gt;
	Prefix: character string using any character in the UCS-2 character set except &#039;/&#039;&lt;br /&gt;
	Suffix: character string of any length using any character in the UCS-2 character set chosen by the registrant&lt;br /&gt;
&lt;br /&gt;
This function checks a HDL name for: prefix/suffix.  If the HDL name contains spaces, endashes, or, if it ends&lt;br /&gt;
with a period or a comma, this function will emit a bad_hdl error message.&lt;br /&gt;
&lt;br /&gt;
HDL names are case-insensitive and can incorporate any printable Unicode characters so the test for endashes and&lt;br /&gt;
terminal punctuation may not be technically correct but it appears, that in practice these characters are rarely&lt;br /&gt;
if ever used in HDLs.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function hdl(id, access)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;HDL&#039;];&lt;br /&gt;
	&lt;br /&gt;
	local text = external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
			prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode, access=access})&lt;br /&gt;
&lt;br /&gt;
	if nil == id:match(&amp;quot;^[^%s–]-/[^%s–]-[^%.,]$&amp;quot;) then							-- hdl must contain a fwd slash, must not contain spaces, endashes, and must not end with period or comma&lt;br /&gt;
		text = text .. &#039; &#039; .. set_error( &#039;bad_hdl&#039; );&lt;br /&gt;
	end&lt;br /&gt;
	return text;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S B N &amp;gt;----------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Determines whether an ISBN string is valid&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function isbn( isbn_str )&lt;br /&gt;
	if nil ~= isbn_str:match(&amp;quot;[^%s-0-9X]&amp;quot;) then&lt;br /&gt;
		return false, &#039;invalid character&#039;;										-- fail if isbn_str contains anything but digits, hyphens, or the uppercase X&lt;br /&gt;
	end&lt;br /&gt;
	isbn_str = isbn_str:gsub( &amp;quot;-&amp;quot;, &amp;quot;&amp;quot; ):gsub( &amp;quot; &amp;quot;, &amp;quot;&amp;quot; );						-- remove hyphens and spaces&lt;br /&gt;
	local len = isbn_str:len();&lt;br /&gt;
 &lt;br /&gt;
	if len ~= 10 and len ~= 13 then&lt;br /&gt;
		return false, &#039;length&#039;;													-- fail if incorrect length&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if len == 10 then&lt;br /&gt;
		if isbn_str:match( &amp;quot;^%d*X?$&amp;quot; ) == nil then								-- fail if isbn_str has &#039;X&#039; anywhere but last position&lt;br /&gt;
			return false, &#039;invalid form&#039;;									&lt;br /&gt;
		end&lt;br /&gt;
		return is_valid_isxn(isbn_str, 10), &#039;checksum&#039;;&lt;br /&gt;
	else&lt;br /&gt;
		if isbn_str:match( &amp;quot;^%d+$&amp;quot; ) == nil then&lt;br /&gt;
			return false, &#039;invalid character&#039;;									-- fail if isbn13 is not all digits&lt;br /&gt;
		end&lt;br /&gt;
		if isbn_str:match( &amp;quot;^97[89]%d*$&amp;quot; ) == nil then&lt;br /&gt;
			return false, &#039;invalid prefix&#039;;										-- fail when isbn13 does not begin with 978 or 979&lt;br /&gt;
		end&lt;br /&gt;
		return is_valid_isxn_13 (isbn_str), &#039;checksum&#039;;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; A M A Z O N &amp;gt;------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Formats a link to Amazon.  Do simple error checking: asin must be mix of 10 numeric or uppercase alpha&lt;br /&gt;
characters.  If a mix, first character must be uppercase alpha; if all numeric, asins must be 10-digit&lt;br /&gt;
isbn. If 10-digit isbn, add a maintenance category so a bot or awb script can replace |asin= with |isbn=.&lt;br /&gt;
Error message if not 10 characters, if not isbn10, if mixed and first character is a digit.&lt;br /&gt;
&lt;br /&gt;
This function is positioned here because it calls isbn()&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function asin(id, domain)&lt;br /&gt;
	local err_cat = &amp;quot;&amp;quot;&lt;br /&gt;
&lt;br /&gt;
	if not id:match(&amp;quot;^[%d%u][%d%u][%d%u][%d%u][%d%u][%d%u][%d%u][%d%u][%d%u][%d%u]$&amp;quot;) then&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error (&#039;bad_asin&#039;);								-- asin is not a mix of 10 uppercase alpha and numeric characters&lt;br /&gt;
	else&lt;br /&gt;
		if id:match(&amp;quot;^%d%d%d%d%d%d%d%d%d[%dX]$&amp;quot;) then							-- if 10-digit numeric (or 9 digits with terminal X)&lt;br /&gt;
			if isbn( id ) then													-- see if asin value is isbn10&lt;br /&gt;
				add_maint_cat (&#039;ASIN&#039;);&lt;br /&gt;
			elseif not is_set (err_cat) then&lt;br /&gt;
				err_cat = &#039; &#039; .. set_error (&#039;bad_asin&#039;);						-- asin is not isbn10&lt;br /&gt;
			end&lt;br /&gt;
		elseif not id:match(&amp;quot;^%u[%d%u]+$&amp;quot;) then&lt;br /&gt;
			err_cat = &#039; &#039; .. set_error (&#039;bad_asin&#039;);							-- asin doesn&#039;t begin with uppercase alpha&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if not is_set(domain) then &lt;br /&gt;
		domain = &amp;quot;com&amp;quot;;&lt;br /&gt;
	elseif in_array (domain, {&#039;jp&#039;, &#039;uk&#039;}) then			-- Japan, United Kingdom&lt;br /&gt;
		domain = &amp;quot;co.&amp;quot; .. domain;&lt;br /&gt;
	elseif in_array (domain, {&#039;au&#039;, &#039;br&#039;, &#039;mx&#039;}) then	-- Australia, Brazil, Mexico&lt;br /&gt;
		domain = &amp;quot;com.&amp;quot; .. domain;&lt;br /&gt;
	end&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;ASIN&#039;];&lt;br /&gt;
	return external_link_id({link=handler.link,&lt;br /&gt;
		label=handler.label, prefix=handler.prefix .. domain .. &amp;quot;/dp/&amp;quot;,&lt;br /&gt;
		id=id, encode=handler.encode, separator = handler.separator}) .. err_cat;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S M N &amp;gt;----------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Determines whether an ISMN string is valid.  Similar to isbn-13, ismn is 13 digits begining 979-0-... and uses the&lt;br /&gt;
same check digit calculations.  See http://www.ismn-international.org/download/Web_ISMN_Users_Manual_2008-6.pdf&lt;br /&gt;
section 2, pages 9–12.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function ismn (id)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;ISMN&#039;];&lt;br /&gt;
	local text;&lt;br /&gt;
	local valid_ismn = true;&lt;br /&gt;
	local id_copy;&lt;br /&gt;
&lt;br /&gt;
	id_copy = id;																-- save a copy because this testing is destructive&lt;br /&gt;
	id=id:gsub( &amp;quot;[%s-–]&amp;quot;, &amp;quot;&amp;quot; );													-- strip spaces, hyphens, and endashes from the ismn&lt;br /&gt;
&lt;br /&gt;
	if 13 ~= id:len() or id:match( &amp;quot;^9790%d*$&amp;quot; ) == nil then					-- ismn must be 13 digits and begin 9790&lt;br /&gt;
		valid_ismn = false;&lt;br /&gt;
	else&lt;br /&gt;
		valid_ismn=is_valid_isxn_13 (id);										-- validate ismn&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
--	text = internal_link_id({link = handler.link, label = handler.label,		-- use this (or external version) when there is some place to link to&lt;br /&gt;
--		prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode})&lt;br /&gt;
 &lt;br /&gt;
	text = table.concat (&lt;br /&gt;
		{&lt;br /&gt;
		make_wikilink (handler.link, handler.label),&lt;br /&gt;
		handler.separator,&lt;br /&gt;
		id_copy&lt;br /&gt;
		});		-- because no place to link to yet&lt;br /&gt;
&lt;br /&gt;
	if false == valid_ismn then&lt;br /&gt;
		text = text .. &#039; &#039; .. set_error( &#039;bad_ismn&#039; )							-- add an error message if the ismn is invalid&lt;br /&gt;
	end &lt;br /&gt;
	&lt;br /&gt;
	return text;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S S N &amp;gt;----------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Validate and format an issn.  This code fixes the case where an editor has included an ISSN in the citation but&lt;br /&gt;
has separated the two groups of four digits with a space.  When that condition occurred, the resulting link looked&lt;br /&gt;
like this:&lt;br /&gt;
&lt;br /&gt;
	|issn=0819 4327 gives: [http://www.worldcat.org/issn/0819 4327 0819 4327]	-- can&#039;t have spaces in an external link&lt;br /&gt;
	&lt;br /&gt;
This code now prevents that by inserting a hyphen at the issn midpoint.  It also validates the issn for length&lt;br /&gt;
and makes sure that the checkdigit agrees with the calculated value.  Incorrect length (8 digits), characters&lt;br /&gt;
other than 0-9 and X, or checkdigit / calculated value mismatch will all cause a check issn error message.  The&lt;br /&gt;
issn is always displayed with a hyphen, even if the issn was given as a single group of 8 digits.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function issn(id, e)&lt;br /&gt;
	local issn_copy = id;														-- save a copy of unadulterated issn; use this version for display if issn does not validate&lt;br /&gt;
	local handler;&lt;br /&gt;
	local text;&lt;br /&gt;
	local valid_issn = true;&lt;br /&gt;
	&lt;br /&gt;
	if e then&lt;br /&gt;
		 handler = cfg.id_handlers[&#039;EISSN&#039;];&lt;br /&gt;
	else&lt;br /&gt;
		 handler = cfg.id_handlers[&#039;ISSN&#039;];&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	id=id:gsub( &amp;quot;[%s-–]&amp;quot;, &amp;quot;&amp;quot; );													-- strip spaces, hyphens, and endashes from the issn&lt;br /&gt;
&lt;br /&gt;
	if 8 ~= id:len() or nil == id:match( &amp;quot;^%d*X?$&amp;quot; ) then						-- validate the issn: 8 digits long, containing only 0-9 or X in the last position&lt;br /&gt;
		valid_issn=false;														-- wrong length or improper character&lt;br /&gt;
	else&lt;br /&gt;
		valid_issn=is_valid_isxn(id, 8);										-- validate issn&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if true == valid_issn then&lt;br /&gt;
		id = string.sub( id, 1, 4 ) .. &amp;quot;-&amp;quot; .. string.sub( id, 5 );				-- if valid, display correctly formatted version&lt;br /&gt;
	else&lt;br /&gt;
		id = issn_copy;															-- if not valid, use the show the invalid issn with error message&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	text = external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
		prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode})&lt;br /&gt;
 &lt;br /&gt;
	if false == valid_issn then&lt;br /&gt;
		text = text .. &#039; &#039; .. set_error( &#039;bad_issn&#039;, e and &#039;e&#039; or &#039;&#039; )			-- add an error message if the issn is invalid&lt;br /&gt;
	end &lt;br /&gt;
	&lt;br /&gt;
	return text&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; J F M &amp;gt;-----------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
A numerical identifier in the form nn.nnnn.nn&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function jfm (id)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;JFM&#039;];&lt;br /&gt;
	local id_num;&lt;br /&gt;
	local err_cat = &#039;&#039;;&lt;br /&gt;
	&lt;br /&gt;
	id_num = id:match (&#039;^[Jj][Ff][Mm](.*)$&#039;);									-- identifier with jfm prefix; extract identifier&lt;br /&gt;
&lt;br /&gt;
	if is_set (id_num) then&lt;br /&gt;
		add_maint_cat (&#039;jfm_format&#039;);&lt;br /&gt;
	else																		-- plain number without mr prefix&lt;br /&gt;
		id_num = id;															-- if here id does not have prefix&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if id_num and id_num:match(&#039;^%d%d%.%d%d%d%d%.%d%d$&#039;) then&lt;br /&gt;
		id = id_num;															-- jfm matches pattern&lt;br /&gt;
	else&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_jfm&#039; );								-- set an error message&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
			prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode}) .. err_cat;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; L C C N &amp;gt;----------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Format LCCN link and do simple error checking.  LCCN is a character string 8-12 characters long. The length of&lt;br /&gt;
the LCCN dictates the character type of the first 1-3 characters; the rightmost eight are always digits.&lt;br /&gt;
http://info-uri.info/registry/OAIHandler?verb=GetRecord&amp;amp;metadataPrefix=reg&amp;amp;identifier=info:lccn/&lt;br /&gt;
&lt;br /&gt;
length = 8 then all digits&lt;br /&gt;
length = 9 then lccn[1] is lower case alpha&lt;br /&gt;
length = 10 then lccn[1] and lccn[2] are both lower case alpha or both digits&lt;br /&gt;
length = 11 then lccn[1] is lower case alpha, lccn[2] and lccn[3] are both lower case alpha or both digits&lt;br /&gt;
length = 12 then lccn[1] and lccn[2] are both lower case alpha&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function lccn(lccn)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;LCCN&#039;];&lt;br /&gt;
	local err_cat = &#039;&#039;;															-- presume that LCCN is valid&lt;br /&gt;
	local id = lccn;															-- local copy of the lccn&lt;br /&gt;
&lt;br /&gt;
	id = normalize_lccn (id);													-- get canonical form (no whitespace, hyphens, forward slashes)&lt;br /&gt;
	local len = id:len();														-- get the length of the lccn&lt;br /&gt;
&lt;br /&gt;
	if 8 == len then&lt;br /&gt;
		if id:match(&amp;quot;[^%d]&amp;quot;) then												-- if LCCN has anything but digits (nil if only digits)&lt;br /&gt;
			err_cat = &#039; &#039; .. set_error( &#039;bad_lccn&#039; );							-- set an error message&lt;br /&gt;
		end&lt;br /&gt;
	elseif 9 == len then														-- LCCN should be adddddddd&lt;br /&gt;
		if nil == id:match(&amp;quot;%l%d%d%d%d%d%d%d%d&amp;quot;) then							-- does it match our pattern?&lt;br /&gt;
			err_cat = &#039; &#039; .. set_error( &#039;bad_lccn&#039; );							-- set an error message&lt;br /&gt;
		end&lt;br /&gt;
	elseif 10 == len then														-- LCCN should be aadddddddd or dddddddddd&lt;br /&gt;
		if id:match(&amp;quot;[^%d]&amp;quot;) then												-- if LCCN has anything but digits (nil if only digits) ...&lt;br /&gt;
			if nil == id:match(&amp;quot;^%l%l%d%d%d%d%d%d%d%d&amp;quot;) then					-- ... see if it matches our pattern&lt;br /&gt;
				err_cat = &#039; &#039; .. set_error( &#039;bad_lccn&#039; );						-- no match, set an error message&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	elseif 11 == len then														-- LCCN should be aaadddddddd or adddddddddd&lt;br /&gt;
		if not (id:match(&amp;quot;^%l%l%l%d%d%d%d%d%d%d%d&amp;quot;) or id:match(&amp;quot;^%l%d%d%d%d%d%d%d%d%d%d&amp;quot;)) then	-- see if it matches one of our patterns&lt;br /&gt;
			err_cat = &#039; &#039; .. set_error( &#039;bad_lccn&#039; );							-- no match, set an error message&lt;br /&gt;
		end&lt;br /&gt;
	elseif 12 == len then														-- LCCN should be aadddddddddd&lt;br /&gt;
		if not id:match(&amp;quot;^%l%l%d%d%d%d%d%d%d%d%d%d&amp;quot;) then						-- see if it matches our pattern&lt;br /&gt;
			err_cat = &#039; &#039; .. set_error( &#039;bad_lccn&#039; );							-- no match, set an error message&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_lccn&#039; );								-- wrong length, set an error message&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if not is_set (err_cat) and nil ~= lccn:find (&#039;%s&#039;) then&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_lccn&#039; );								-- lccn contains a space, set an error message&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
			prefix=handler.prefix,id=lccn,separator=handler.separator, encode=handler.encode}) .. err_cat;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; M R &amp;gt;--------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
A seven digit number; if not seven digits, zero-fill leading digits to make seven digits.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function mr (id)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;MR&#039;];&lt;br /&gt;
	local id_num;&lt;br /&gt;
	local id_len;&lt;br /&gt;
	local err_cat = &#039;&#039;;&lt;br /&gt;
	&lt;br /&gt;
	id_num = id:match (&#039;^[Mm][Rr](%d+)$&#039;);										-- identifier with mr prefix&lt;br /&gt;
&lt;br /&gt;
	if is_set (id_num) then&lt;br /&gt;
		add_maint_cat (&#039;mr_format&#039;);&lt;br /&gt;
	else																		-- plain number without mr prefix&lt;br /&gt;
		id_num = id:match (&#039;^%d+$&#039;);											-- if here id is all digits&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	id_len = id_num and id_num:len() or 0;&lt;br /&gt;
	if (7 &amp;gt;= id_len) and (0 ~= id_len) then&lt;br /&gt;
		id = string.rep (&#039;0&#039;, 7-id_len ) .. id_num;								-- zero-fill leading digits&lt;br /&gt;
	else&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_mr&#039; );									-- set an error message&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
			prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode}) .. err_cat;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; O C L C &amp;gt;----------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Validate and format an oclc id.  https://www.oclc.org/batchload/controlnumber.en.html&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function oclc (id)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;OCLC&#039;];&lt;br /&gt;
	local number;&lt;br /&gt;
	local err_msg = &#039;&#039;;															-- empty string for concatenation&lt;br /&gt;
	&lt;br /&gt;
	if id:match(&#039;^ocm%d%d%d%d%d%d%d%d$&#039;) then									-- ocm prefix and 8 digits; 001 field (12 characters)&lt;br /&gt;
		number = id:match(&#039;ocm(%d+)&#039;);											-- get the number&lt;br /&gt;
	elseif id:match(&#039;^ocn%d%d%d%d%d%d%d%d%d$&#039;) then								-- ocn prefix and 9 digits; 001 field (12 characters)&lt;br /&gt;
		number = id:match(&#039;ocn(%d+)&#039;);											-- get the number&lt;br /&gt;
	elseif id:match(&#039;^on%d%d%d%d%d%d%d%d%d%d+$&#039;) then							-- on prefix and 10 or more digits; 001 field (12 characters)&lt;br /&gt;
		number = id:match(&#039;^on(%d%d%d%d%d%d%d%d%d%d+)$&#039;);						-- get the number&lt;br /&gt;
	elseif id:match(&#039;^%(OCoLC%)[1-9]%d*$&#039;) then									-- (OCoLC) prefix and variable number digits; no leading zeros; 035 field&lt;br /&gt;
		number = id:match(&#039;%(OCoLC%)([1-9]%d*)&#039;);								-- get the number&lt;br /&gt;
		if 9 &amp;lt; number:len() then&lt;br /&gt;
			number = nil;														-- contrain to 1 to 9 digits; change this when oclc issues 10-digit numbers&lt;br /&gt;
		end&lt;br /&gt;
	elseif id:match(&#039;^%d+$&#039;) then												-- no prefix&lt;br /&gt;
		number = id;															-- get the number&lt;br /&gt;
		if 10 &amp;lt; number:len() then&lt;br /&gt;
			number = nil;														-- contrain to 1 to 10 digits; change this when oclc issues 11-digit numbers&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if number then																-- proper format&lt;br /&gt;
		id = number;															-- exclude prefix, if any, from external link&lt;br /&gt;
	else&lt;br /&gt;
		err_msg = &#039; &#039; .. set_error( &#039;bad_oclc&#039; )								-- add an error message if the id is malformed&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local text = external_link_id({link=handler.link, label=handler.label,&lt;br /&gt;
		prefix=handler.prefix, id=id, separator=handler.separator, encode=handler.encode}) .. err_msg;&lt;br /&gt;
&lt;br /&gt;
	return text;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; O P E N L I B R A R Y &amp;gt;--------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Formats an OpenLibrary link, and checks for associated errors.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function openlibrary(id, access)&lt;br /&gt;
	local code;&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;OL&#039;];&lt;br /&gt;
	local ident;&lt;br /&gt;
	&lt;br /&gt;
	ident, code = id:gsub(&#039;^OL&#039;, &#039;&#039;):match(&amp;quot;^(%d+([AMW]))$&amp;quot;);					-- optional OL prefix followed immediately by digits followed by &#039;A&#039;, &#039;M&#039;, or &#039;W&#039;; remove OL prefix&lt;br /&gt;
&lt;br /&gt;
	if not is_set (ident) then													-- if malformed return an error&lt;br /&gt;
		return external_link_id({link=handler.link, label=handler.label,&lt;br /&gt;
			prefix=handler.prefix .. &#039;OL&#039;,&lt;br /&gt;
			id=id, separator=handler.separator,	encode = handler.encode,&lt;br /&gt;
			access = access}) .. &#039; &#039; .. set_error( &#039;bad_ol&#039; );&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	id = ident;																	-- use ident without the optional OL prefix (it has been removed)&lt;br /&gt;
	&lt;br /&gt;
	if ( code == &amp;quot;A&amp;quot; ) then&lt;br /&gt;
		return external_link_id({link=handler.link, label=handler.label,&lt;br /&gt;
			prefix=handler.prefix .. &#039;authors/OL&#039;,&lt;br /&gt;
			id=id, separator=handler.separator,	encode = handler.encode,&lt;br /&gt;
			access = access})&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if ( code == &amp;quot;M&amp;quot; ) then&lt;br /&gt;
		return external_link_id({link=handler.link, label=handler.label,&lt;br /&gt;
			prefix=handler.prefix .. &#039;books/OL&#039;,&lt;br /&gt;
			id=id, separator=handler.separator,	encode = handler.encode,&lt;br /&gt;
			access = access})&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if ( code == &amp;quot;W&amp;quot; ) then&lt;br /&gt;
		return external_link_id({link=handler.link, label=handler.label,&lt;br /&gt;
			prefix=handler.prefix .. &#039;works/OL&#039;,&lt;br /&gt;
			id=id, separator=handler.separator,	encode = handler.encode,&lt;br /&gt;
			access = access})&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; P M C &amp;gt;------------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Format a PMC, do simple error checking, and check for embargoed articles.&lt;br /&gt;
&lt;br /&gt;
The embargo parameter takes a date for a value. If the embargo date is in the future the PMC identifier will not&lt;br /&gt;
be linked to the article.  If the embargo date is today or in the past, or if it is empty or omitted, then the&lt;br /&gt;
PMC identifier is linked to the article through the link at cfg.id_handlers[&#039;PMC&#039;].prefix.&lt;br /&gt;
&lt;br /&gt;
PMC embargo date testing is done in function is_embargoed () which is called earlier because when the citation&lt;br /&gt;
has |pmc=&amp;lt;value&amp;gt; but does not have a |url= then |title= is linked with the PMC link.  Function is_embargoed ()&lt;br /&gt;
returns the embargo date if the PMC article is still embargoed, otherwise it returns an empty string.&lt;br /&gt;
&lt;br /&gt;
PMCs are sequential numbers beginning at 1 and counting up.  This code checks the PMC to see that it contains only digits and is less&lt;br /&gt;
than test_limit; the value in local variable test_limit will need to be updated periodically as more PMCs are issued.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function pmc(id, embargo)&lt;br /&gt;
	local test_limit = 6000000;													-- update this value as PMCs approach&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;PMC&#039;];&lt;br /&gt;
	local err_cat = &#039;&#039;;															-- presume that PMC is valid&lt;br /&gt;
	local id_num;&lt;br /&gt;
	local text;&lt;br /&gt;
	&lt;br /&gt;
	id_num = id:match (&#039;^[Pp][Mm][Cc](%d+)$&#039;);									-- identifier with pmc prefix&lt;br /&gt;
&lt;br /&gt;
	if is_set (id_num) then&lt;br /&gt;
		add_maint_cat (&#039;pmc_format&#039;);&lt;br /&gt;
	else																		-- plain number without pmc prefix&lt;br /&gt;
		id_num = id:match (&#039;^%d+$&#039;);											-- if here id is all digits&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set (id_num) then														-- id_num has a value so test it&lt;br /&gt;
		id_num = tonumber(id_num);												-- convert id_num to a number for range testing&lt;br /&gt;
		if 1 &amp;gt; id_num or test_limit &amp;lt; id_num then								-- if PMC is outside test limit boundaries&lt;br /&gt;
			err_cat = &#039; &#039; .. set_error( &#039;bad_pmc&#039; );							-- set an error message&lt;br /&gt;
		else&lt;br /&gt;
			id = tostring (id_num);												-- make sure id is a string&lt;br /&gt;
		end&lt;br /&gt;
	else																		-- when id format incorrect&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_pmc&#039; );								-- set an error message&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if is_set (embargo) then													-- is PMC is still embargoed?&lt;br /&gt;
		text = table.concat (													-- still embargoed so no external link&lt;br /&gt;
			{&lt;br /&gt;
			make_wikilink (handler.link, handler.label),&lt;br /&gt;
			handler.separator,&lt;br /&gt;
			id,&lt;br /&gt;
			err_cat&lt;br /&gt;
			});&lt;br /&gt;
	else&lt;br /&gt;
		text = external_link_id({link = handler.link, label = handler.label,	-- no embargo date or embargo has expired, ok to link to article&lt;br /&gt;
			prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode, access=handler.access}) .. err_cat;&lt;br /&gt;
	end&lt;br /&gt;
	return text;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; P M I D &amp;gt;----------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Format PMID and do simple error checking.  PMIDs are sequential numbers beginning at 1 and counting up.  This&lt;br /&gt;
code checks the PMID to see that it contains only digits and is less than test_limit; the value in local variable&lt;br /&gt;
test_limit will need to be updated periodically as more PMIDs are issued.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function pmid(id)&lt;br /&gt;
	local test_limit = 32000000;												-- update this value as PMIDs approach&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;PMID&#039;];&lt;br /&gt;
	local err_cat = &#039;&#039;;															-- presume that PMID is valid&lt;br /&gt;
	&lt;br /&gt;
	if id:match(&amp;quot;[^%d]&amp;quot;) then													-- if PMID has anything but digits&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_pmid&#039; );								-- set an error message&lt;br /&gt;
	else																		-- PMID is only digits&lt;br /&gt;
		local id_num = tonumber(id);											-- convert id to a number for range testing&lt;br /&gt;
		if 1 &amp;gt; id_num or test_limit &amp;lt; id_num then								-- if PMID is outside test limit boundaries&lt;br /&gt;
			err_cat = &#039; &#039; .. set_error( &#039;bad_pmid&#039; );							-- set an error message&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
			prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode}) .. err_cat;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S S R N &amp;gt;----------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Format an ssrn, do simple error checking&lt;br /&gt;
&lt;br /&gt;
SSRNs are sequential numbers beginning at 100? and counting up.  This code checks the ssrn to see that it is&lt;br /&gt;
only digits and is greater than 99 and less than test_limit; the value in local variable test_limit will need&lt;br /&gt;
to be updated periodically as more SSRNs are issued.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function ssrn (id)&lt;br /&gt;
	local test_limit = 3500000;													-- update this value as SSRNs approach&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;SSRN&#039;];&lt;br /&gt;
	local err_cat = &#039;&#039;;															-- presume that SSRN is valid&lt;br /&gt;
	local id_num;&lt;br /&gt;
	local text;&lt;br /&gt;
	&lt;br /&gt;
	id_num = id:match (&#039;^%d+$&#039;);												-- id must be all digits&lt;br /&gt;
&lt;br /&gt;
	if is_set (id_num) then														-- id_num has a value so test it&lt;br /&gt;
		id_num = tonumber(id_num);												-- convert id_num to a number for range testing&lt;br /&gt;
		if 100 &amp;gt; id_num or test_limit &amp;lt; id_num then								-- if SSRN is outside test limit boundaries&lt;br /&gt;
			err_cat = &#039; &#039; .. set_error( &#039;bad_ssrn&#039; );							-- set an error message&lt;br /&gt;
		end&lt;br /&gt;
	else																		-- when id format incorrect&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_ssrn&#039; );								-- set an error message&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	text = external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
		prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode, access=handler.access}) .. err_cat;&lt;br /&gt;
&lt;br /&gt;
	return text;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; U S E N E T _ I D &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Validate and format a usenet message id.  Simple error checking, looks for &#039;id-left@id-right&#039; not enclosed in&lt;br /&gt;
&#039;&amp;lt;&#039; and/or &#039;&amp;gt;&#039; angle brackets.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function usenet_id (id)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;USENETID&#039;];&lt;br /&gt;
&lt;br /&gt;
	local text = external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
		prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode})&lt;br /&gt;
 &lt;br /&gt;
	if not id:match(&#039;^.+@.+$&#039;) or not id:match(&#039;^[^&amp;lt;].*[^&amp;gt;]$&#039;)then				-- doesn&#039;t have &#039;@&#039; or has one or first or last character is &#039;&amp;lt; or &#039;&amp;gt;&#039;&lt;br /&gt;
		text = text .. &#039; &#039; .. set_error( &#039;bad_usenet_id&#039; )						-- add an error message if the message id is invalid&lt;br /&gt;
	end &lt;br /&gt;
	&lt;br /&gt;
	return text&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; Z B L &amp;gt;-----------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
A numerical identifier in the form nnnn.nnnnn - leading zeros in the first quartet optional&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function zbl (id)&lt;br /&gt;
	local handler = cfg.id_handlers[&#039;ZBL&#039;];&lt;br /&gt;
	local id_num;&lt;br /&gt;
	local err_cat = &#039;&#039;;&lt;br /&gt;
	&lt;br /&gt;
	id_num = id:match (&#039;^[Zz][Bb][Ll](.*)$&#039;);									-- identifier with zbl prefix; extract identifier&lt;br /&gt;
&lt;br /&gt;
	if is_set (id_num) then&lt;br /&gt;
		add_maint_cat (&#039;zbl_format&#039;);&lt;br /&gt;
	else																		-- plain number without zbl prefix&lt;br /&gt;
		id_num = id;															-- if here id does not have prefix&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if id_num:match(&#039;^%d?%d?%d?%d%.%d%d%d%d%d$&#039;) then&lt;br /&gt;
		id = id_num;															-- id matches pattern&lt;br /&gt;
	else&lt;br /&gt;
		err_cat = &#039; &#039; .. set_error( &#039;bad_zbl&#039; );								-- set an error message&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return external_link_id({link = handler.link, label = handler.label,&lt;br /&gt;
			prefix=handler.prefix,id=id,separator=handler.separator, encode=handler.encode}) .. err_cat;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--============================&amp;lt;&amp;lt; I N T E R F A C E   F U N C T I O N S &amp;gt;&amp;gt;==========================================&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; B U I L D _ I D _ L I S T &amp;gt;--------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Takes a table of IDs created by extract_ids() and turns it into a table of formatted ID outputs.&lt;br /&gt;
&lt;br /&gt;
inputs:&lt;br /&gt;
	id_list – table of identifiers built by extract_ids()&lt;br /&gt;
	options – table of various template parameter values used to modify some manually handled identifiers&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function build_id_list( id_list, options )&lt;br /&gt;
	local new_list, handler = {};&lt;br /&gt;
&lt;br /&gt;
	local function fallback(k) return { __index = function(t,i) return cfg.id_handlers[k][i] end } end;&lt;br /&gt;
	&lt;br /&gt;
	for k, v in pairs( id_list ) do												-- k is uc identifier name as index to cfg.id_handlers; e.g. cfg.id_handlers[&#039;ISBN&#039;], v is a table&lt;br /&gt;
		-- fallback to read-only cfg&lt;br /&gt;
		handler = setmetatable( { [&#039;id&#039;] = v, [&#039;access&#039;] = options.IdAccessLevels[k] }, fallback(k) );&lt;br /&gt;
&lt;br /&gt;
		if handler.mode == &#039;external&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, external_link_id( handler ) } );&lt;br /&gt;
		elseif handler.mode == &#039;internal&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, internal_link_id( handler ) } );&lt;br /&gt;
		elseif handler.mode ~= &#039;manual&#039; then&lt;br /&gt;
			error( cfg.messages[&#039;unknown_ID_mode&#039;] );&lt;br /&gt;
		elseif k == &#039;ARXIV&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, arxiv( v, options.Class ) } ); &lt;br /&gt;
		elseif k == &#039;ASIN&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, asin( v, options.ASINTLD ) } ); &lt;br /&gt;
		elseif k == &#039;BIBCODE&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, bibcode( v, handler.access ) } );&lt;br /&gt;
		elseif k == &#039;BIORXIV&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, biorxiv( v ) } );&lt;br /&gt;
		elseif k == &#039;CITESEERX&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, citeseerx( v ) } );&lt;br /&gt;
		elseif k == &#039;DOI&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, doi( v, options.DoiBroken, handler.access ) } );&lt;br /&gt;
		elseif k == &#039;EISSN&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, issn( v, true ) } );		-- true distinguishes eissn from issn&lt;br /&gt;
		elseif k == &#039;HDL&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, hdl( v, handler.access ) } );&lt;br /&gt;
		elseif k == &#039;ISBN&#039; then&lt;br /&gt;
			local ISBN = internal_link_id( handler );&lt;br /&gt;
			local check;&lt;br /&gt;
			local err_type = &#039;&#039;;&lt;br /&gt;
			check, err_type = isbn( v );&lt;br /&gt;
			if not check then&lt;br /&gt;
				if is_set(options.IgnoreISBN) then								-- ISBN is invalid; if |ignore-isbn-error= set&lt;br /&gt;
					add_maint_cat (&#039;ignore_isbn_err&#039;);							-- ad a maint category&lt;br /&gt;
				else&lt;br /&gt;
					ISBN = ISBN .. set_error( &#039;bad_isbn&#039;, {err_type}, false, &amp;quot; &amp;quot;, &amp;quot;&amp;quot; );	-- else display an error message&lt;br /&gt;
				end&lt;br /&gt;
			elseif is_set(options.IgnoreISBN) then								-- ISBN is OK; if |ignore-isbn-error= set&lt;br /&gt;
				add_maint_cat (&#039;ignore_isbn_err&#039;);								-- because |ignore-isbn-error= unnecessary&lt;br /&gt;
			end&lt;br /&gt;
			table.insert( new_list, {handler.label, ISBN } );				&lt;br /&gt;
		elseif k == &#039;ISMN&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, ismn( v ) } );&lt;br /&gt;
		elseif k == &#039;ISSN&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, issn( v ) } );&lt;br /&gt;
		elseif k == &#039;JFM&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, jfm( v ) } );&lt;br /&gt;
		elseif k == &#039;LCCN&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, lccn( v ) } );&lt;br /&gt;
		elseif k == &#039;MR&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, mr( v ) } );&lt;br /&gt;
		elseif k == &#039;OCLC&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, oclc( v ) } );&lt;br /&gt;
		elseif k == &#039;OL&#039; or k == &#039;OLA&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, openlibrary( v, handler.access ) } );&lt;br /&gt;
		elseif k == &#039;PMC&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, pmc( v, options.Embargo ) } );&lt;br /&gt;
		elseif k == &#039;PMID&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, pmid( v ) } );&lt;br /&gt;
		elseif k == &#039;SSRN&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, ssrn( v ) } );&lt;br /&gt;
		elseif k == &#039;USENETID&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, usenet_id( v ) } );&lt;br /&gt;
		elseif k == &#039;ZBL&#039; then&lt;br /&gt;
			table.insert( new_list, {handler.label, zbl( v ) } );&lt;br /&gt;
		else&lt;br /&gt;
			error( cfg.messages[&#039;unknown_manual_ID&#039;] );&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local function comp( a, b )	-- used in following table.sort()&lt;br /&gt;
		return a[1]:lower() &amp;lt; b[1]:lower();&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	table.sort( new_list, comp );&lt;br /&gt;
	for k, v in ipairs( new_list ) do&lt;br /&gt;
		new_list[k] = v[2];&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return new_list;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; E X T R A C T _ I D S &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Populates ID table from arguments using configuration settings. Loops through cfg.id_handlers and searches args for&lt;br /&gt;
any of the parameters listed in each cfg.id_handlers[&#039;...&#039;].parameters.  If found, adds the parameter and value to&lt;br /&gt;
the identifier list.  Emits redundant error message is more than one alias exists in args&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function extract_ids( args )&lt;br /&gt;
	local id_list = {};															-- list of identifiers found in args&lt;br /&gt;
	for k, v in pairs( cfg.id_handlers ) do										-- k is uc identifier name as index to cfg.id_handlers; e.g. cfg.id_handlers[&#039;ISBN&#039;], v is a table&lt;br /&gt;
		v = select_one( args, v.parameters, &#039;redundant_parameters&#039; );			-- v.parameters is a table of aliases for k; here we pick one from args if present&lt;br /&gt;
		if is_set(v) then id_list[k] = v; end									-- if found in args, add identifier to our list&lt;br /&gt;
	end&lt;br /&gt;
	return id_list;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; E X T R A C T _ I D _ A C C E S S _ L E V E L S &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
Fetches custom id access levels from arguments using configuration settings.&lt;br /&gt;
Parameters which have a predefined access level (e.g. arxiv) do not use this&lt;br /&gt;
function as they are directly rendered as free without using an additional parameter.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function extract_id_access_levels( args, id_list )&lt;br /&gt;
	local id_accesses_list = {};&lt;br /&gt;
	for k, v in pairs( cfg.id_handlers ) do&lt;br /&gt;
		local access_param = v.custom_access;&lt;br /&gt;
		local k_lower = string.lower(k);&lt;br /&gt;
		if is_set(access_param) then&lt;br /&gt;
			local access_level = args[access_param];&lt;br /&gt;
			if is_set(access_level) then&lt;br /&gt;
				if not in_array (access_level:lower(), cfg.keywords[&#039;id-access&#039;]) then&lt;br /&gt;
					table.insert( z.message_tail, { set_error( &#039;invalid_param_val&#039;, {access_param, access_level}, true ) } );	&lt;br /&gt;
					access_level = nil;&lt;br /&gt;
				end&lt;br /&gt;
				if not is_set(id_list[k]) then&lt;br /&gt;
					table.insert( z.message_tail, { set_error( &#039;param_access_requires_param&#039;, {k_lower}, true ) } );&lt;br /&gt;
				end&lt;br /&gt;
				if is_set(access_level) then&lt;br /&gt;
					access_level = access_level:lower();&lt;br /&gt;
				end&lt;br /&gt;
				id_accesses_list[k] = access_level;&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return id_accesses_list;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E T _ S E L E C T E D _ M O D U L E S &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
Sets local cfg table and imported functions table to same (live or sandbox) as that used by the other modules.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function set_selected_modules (cfg_table_ptr, utilities_page_ptr)&lt;br /&gt;
	cfg = cfg_table_ptr;&lt;br /&gt;
&lt;br /&gt;
	is_set = utilities_page_ptr.is_set;											-- import functions from select Module:Citation/CS1/Utilities module&lt;br /&gt;
	in_array = utilities_page_ptr.in_array;&lt;br /&gt;
	set_error = utilities_page_ptr.set_error;&lt;br /&gt;
	select_one = utilities_page_ptr.select_one;&lt;br /&gt;
	add_maint_cat = utilities_page_ptr.add_maint_cat;&lt;br /&gt;
	substitute = utilities_page_ptr.substitute;&lt;br /&gt;
	make_wikilink = utilities_page_ptr.make_wikilink;&lt;br /&gt;
&lt;br /&gt;
	z = utilities_page_ptr.z;													-- table of tables in Module:Citation/CS1/Utilities&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
return {&lt;br /&gt;
	build_id_list = build_id_list,&lt;br /&gt;
	extract_ids = extract_ids,&lt;br /&gt;
	extract_id_access_levels = extract_id_access_levels,&lt;br /&gt;
	is_embargoed = is_embargoed;&lt;br /&gt;
	set_selected_modules = set_selected_modules;&lt;br /&gt;
	}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Date_validation&amp;diff=1189</id>
		<title>Module:Citation/CS1/Date validation</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Date_validation&amp;diff=1189"/>
		<updated>2018-04-07T11:49:51Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; F O R W A R D   D E C L A R A T I O N S &amp;gt;--------------------------------------&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local is_set, in_array;															-- imported functions from selected Module:Citation/CS1/Utilities&lt;br /&gt;
local cfg;																		-- table of tables imported from slected Module:Citation/CS1/Configuration&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; I S _ V A L I D _ A C C E S S D A T E &amp;gt;----------------------------------------&lt;br /&gt;
&lt;br /&gt;
returns true if:&lt;br /&gt;
	Wikipedia start date &amp;lt;= accessdate &amp;lt; today + 2 days&lt;br /&gt;
&lt;br /&gt;
Wikipedia start date is 2001-01-15T00:00:00 UTC which is 979516800 seconds after 1970-01-01T00:00:00 UTC (the start of Unix time)&lt;br /&gt;
accessdate is the date provided in |accessdate= at time 00:00:00 UTC&lt;br /&gt;
today is the current date at time 00:00:00 UTC plus 48 hours&lt;br /&gt;
	if today is 2015-01-01T00:00:00 then&lt;br /&gt;
		adding 24 hours gives 2015-01-02T00:00:00 – one second more than today&lt;br /&gt;
		adding 24 hours gives 2015-01-03T00:00:00 – one second more than tomorrow&lt;br /&gt;
&lt;br /&gt;
This function does not work if it is fed month names for languages other than English.  Wikimedia #time: parser&lt;br /&gt;
apparently doesn&#039;t understand non-Engish date month names. This function will always return false when the date&lt;br /&gt;
contains a non-English month name because good1 is false after the call to lang.formatDate().  To get around that&lt;br /&gt;
call this function with YYYY-MM-DD format dates.&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function is_valid_accessdate (accessdate)&lt;br /&gt;
	local lang = mw.getContentLanguage();&lt;br /&gt;
	local good1, good2;&lt;br /&gt;
	local access_ts, tomorrow_ts;												-- to hold unix time stamps representing the dates&lt;br /&gt;
		&lt;br /&gt;
	good1, access_ts = pcall( lang.formatDate, lang, &#039;U&#039;, accessdate );			-- convert accessdate value to unix timesatmp &lt;br /&gt;
	good2, tomorrow_ts = pcall( lang.formatDate, lang, &#039;U&#039;, &#039;today + 2 days&#039; );	-- today midnight + 2 days is one second more than all day tomorrow&lt;br /&gt;
	&lt;br /&gt;
	if good1 and good2 then														-- lang.formatDate() returns a timestamp in the local script which which tonumber() may not understand&lt;br /&gt;
		access_ts = tonumber (access_ts) or lang:parseFormattedNumber (access_ts);			-- convert to numbers for the comparison;&lt;br /&gt;
		tomorrow_ts = tonumber (tomorrow_ts) or lang:parseFormattedNumber (tomorrow_ts);&lt;br /&gt;
	else&lt;br /&gt;
		return false;															-- one or both failed to convert to unix time stamp&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if 979516800 &amp;lt;= access_ts and access_ts &amp;lt; tomorrow_ts then					-- Wikipedia start date &amp;lt;= accessdate &amp;lt; tomorrow&#039;s date&lt;br /&gt;
		return true;&lt;br /&gt;
	else&lt;br /&gt;
		return false;															-- accessdate out of range&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; G E T _ M O N T H _ N U M B E R &amp;gt;----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
returns a number according to the month in a date: 1 for January, etc.  Capitalization and spelling must be correct. If not a valid month, returns 0&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function get_month_number (month)&lt;br /&gt;
	return cfg.date_names[&#039;local&#039;].long[month] or cfg.date_names[&#039;local&#039;].short[month] or		-- look for local names first&lt;br /&gt;
			cfg.date_names[&#039;en&#039;].long[month] or	cfg.date_names[&#039;en&#039;].short[month] or			-- failing that, look for English names&lt;br /&gt;
			0;																					-- not a recognized month name&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ V A L I D _ E M B A R G O _ D A T E &amp;gt;------------------------------------&lt;br /&gt;
&lt;br /&gt;
returns true and date value if that value has proper dmy, mdy, ymd format.&lt;br /&gt;
&lt;br /&gt;
returns false and 9999 (embargoed forever) when date value is not proper format; assumes that when |embargo= is&lt;br /&gt;
set, the editor intended to embargo a pmc but |embargo= does not hold a single date.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_valid_embargo_date (v)&lt;br /&gt;
	if v:match (&#039;^%d%d%d%d%-%d%d%-%d%d$&#039;) or									-- ymd&lt;br /&gt;
		v:match (&#039;^%d%d?%s+%a+%s+%d%d%d%d$&#039;) or									-- dmy&lt;br /&gt;
		v:match (&#039;^%a+%s+%d%d?%s*,%s*%d%d%d%d$&#039;) then							-- mdy&lt;br /&gt;
			return true, v;&lt;br /&gt;
	end&lt;br /&gt;
	return false, &#039;9999&#039;;														-- if here not good date so return false and set embargo date to long time in future&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; G E T _ S E A S O N _ N U M B E R &amp;gt;--------------------------------------------&lt;br /&gt;
&lt;br /&gt;
returns a number according to the sequence of seasons in a year: 1 for Winter, etc.  Capitalization and spelling must be correct. If not a valid season, returns 0&lt;br /&gt;
&lt;br /&gt;
Uses ISO DIS 8601 2016 part 2 §4.7  Divisions of a year for hemishpere-independent seasons:&lt;br /&gt;
	21-24 = Spring, Summer, Autumn, Winter, independent of “Hemisphere”&lt;br /&gt;
&lt;br /&gt;
These additional divisions not currently supported:&lt;br /&gt;
	25-28 = Spring - Northern Hemisphere, Summer- Northern Hemisphere, Autumn - Northern Hemisphere, Winter - Northern Hemisphere&lt;br /&gt;
	29-32 = Spring – Southern Hemisphere, Summer– Southern Hemisphere, Autumn – Southern Hemisphere, Winter - Southern Hemisphere&lt;br /&gt;
	33-36 = Quarter 1, Quarter 2, Quarter 3, Quarter 4 (3 months each)&lt;br /&gt;
	37-39 = Quadrimester 1, Quadrimester 2, Quadrimester 3 (4 months each)&lt;br /&gt;
	40-41 = Semestral 1, Semestral-2 (6 months each)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function get_season_number (season)&lt;br /&gt;
	return cfg.date_names[&#039;local&#039;].season[season] or							-- look for local names first&lt;br /&gt;
			cfg.date_names[&#039;en&#039;].season[season] or								-- failing that, look for English names&lt;br /&gt;
			0;																	-- not a recognized season name&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ P R O P E R _ N A M E &amp;gt;--------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
returns a non-zero number if date contains a recognized proper name.  Capitalization and spelling must be correct.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_proper_name (name)&lt;br /&gt;
	return cfg.date_names[&#039;local&#039;].named[name] or								-- look for local names dates first&lt;br /&gt;
			cfg.date_names[&#039;en&#039;].named[name] or									-- failing that, look for English names&lt;br /&gt;
			0;																	-- not a recognized named date&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ V A L I D _ M O N T H _ O R _ S E A S O N &amp;gt;------------------------------&lt;br /&gt;
&lt;br /&gt;
--returns true if month or season is valid (properly spelled, capitalized, abbreviated)&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_valid_month_or_season (month_season)&lt;br /&gt;
	if 0 == get_month_number (month_season) then		-- if month text isn&#039;t one of the twelve months, might be a season&lt;br /&gt;
		if 0 == get_season_number (month_season) then	-- not a month, is it a season?&lt;br /&gt;
			return false;								-- return false not a month or one of the five seasons&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return true;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ V A L I D _ Y E A R &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Function gets current year from the server and compares it to year from a citation parameter.  Years more than one year in the future are not acceptable.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
local year_limit;&lt;br /&gt;
local function is_valid_year(year)&lt;br /&gt;
	if not is_set(year_limit) then&lt;br /&gt;
		year_limit = tonumber(os.date(&amp;quot;%Y&amp;quot;))+1;			-- global variable so we only have to fetch it once&lt;br /&gt;
	end&lt;br /&gt;
	return tonumber(year) &amp;lt;= year_limit;				-- false if year is in the future more than one year&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ V A L I D _ D A T E &amp;gt;----------------------------------------------------&lt;br /&gt;
Returns true if day is less than or equal to the number of days in month and year is no farther into the future&lt;br /&gt;
than next year; else returns false.&lt;br /&gt;
&lt;br /&gt;
Assumes Julian calendar prior to year 1582 and Gregorian calendar thereafter. Accounts for Julian calendar leap&lt;br /&gt;
years before 1582 and Gregorian leap years after 1582. Where the two calendars overlap (1582 to approximately&lt;br /&gt;
1923) dates are assumed to be Gregorian.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_valid_date (year, month, day)&lt;br /&gt;
local days_in_month = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};&lt;br /&gt;
local month_length;&lt;br /&gt;
	if not is_valid_year(year) then												-- no farther into the future than next year&lt;br /&gt;
		return false;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	month = tonumber(month);													-- required for YYYY-MM-DD dates&lt;br /&gt;
	&lt;br /&gt;
	if (2==month) then															-- if February&lt;br /&gt;
		month_length = 28;														-- then 28 days unless&lt;br /&gt;
		if 1582 &amp;gt; tonumber(year) then											-- Julian calendar&lt;br /&gt;
			if 0==(year%4) then&lt;br /&gt;
				month_length = 29;&lt;br /&gt;
			end&lt;br /&gt;
		else																	-- Gregorian calendar&lt;br /&gt;
			if (0==(year%4) and (0~=(year%100) or 0==(year%400))) then			-- is a leap year?&lt;br /&gt;
				month_length = 29;												-- if leap year then 29 days in February&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		month_length=days_in_month[month];&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if tonumber (day) &amp;gt; month_length then&lt;br /&gt;
		return false;&lt;br /&gt;
	end&lt;br /&gt;
	return true;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ V A L I D _ M O N T H _ R A N G E _ S T Y L E &amp;gt;--------------------------&lt;br /&gt;
&lt;br /&gt;
Months in a range are expected to have the same style: Jan–Mar or October–December but not February–Mar or Jul–August. &lt;br /&gt;
There is a special test for May because it can be either short or long form.&lt;br /&gt;
&lt;br /&gt;
Returns true when style for both months is the same&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_valid_month_range_style (month1, month2)&lt;br /&gt;
local len1 = month1:len();&lt;br /&gt;
local len2 = month2:len();&lt;br /&gt;
	if len1 == len2 then&lt;br /&gt;
		return true;															-- both months are short form so return true&lt;br /&gt;
	elseif &#039;May&#039; == month1 or &#039;May&#039;== month2 then&lt;br /&gt;
		return true;															-- both months are long form so return true&lt;br /&gt;
	elseif 3 == len1 or 3 == len2 then&lt;br /&gt;
		return false;															-- months are mixed form so return false&lt;br /&gt;
	else&lt;br /&gt;
		return true;															-- both months are long form so return true&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ V A L I D _ M O N T H _ S E A S O N _ R A N G E &amp;gt;------------------------&lt;br /&gt;
&lt;br /&gt;
Check a pair of months or seasons to see if both are valid members of a month or season pair.&lt;br /&gt;
&lt;br /&gt;
Month pairs are expected to be left to right, earliest to latest in time.&lt;br /&gt;
&lt;br /&gt;
All season ranges are accepted as valid because there are publishers out there who have published a Summer–Spring YYYY issue so ... ok&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_valid_month_season_range(range_start, range_end)&lt;br /&gt;
	local range_start_number = get_month_number (range_start);&lt;br /&gt;
	local range_end_number;&lt;br /&gt;
	&lt;br /&gt;
	if 0 == range_start_number then												-- is this a month range?&lt;br /&gt;
		range_start_number = get_season_number (range_start);					-- not a month; is it a season? get start season number&lt;br /&gt;
		range_end_number = get_season_number (range_end);						-- get end season number&lt;br /&gt;
&lt;br /&gt;
		if (0 ~= range_start_number) and (0 ~= range_end_number) then&lt;br /&gt;
			return true;														-- any season pairing is accepted&lt;br /&gt;
		end&lt;br /&gt;
		return false;															-- range_start and/or range_end is not a season&lt;br /&gt;
	end&lt;br /&gt;
																				-- here when range_start is a month&lt;br /&gt;
	range_end_number = get_month_number (range_end);							-- get end month number&lt;br /&gt;
	if range_start_number &amp;lt; range_end_number then								-- range_start is a month; does range_start precede range_end?&lt;br /&gt;
		if is_valid_month_range_style (range_start, range_end) then				-- do months have the same style?&lt;br /&gt;
			return true;														-- proper order and same style&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return false;																-- range_start month number is greater than or equal to range end number; or range end isn&#039;t a month&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; M A K E _ C O I N S _ D A T E &amp;gt;------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
This function receives a table of date parts for one or two dates and an empty table reference declared in&lt;br /&gt;
Module:Citation/CS1.  The function is called only for |date= parameters and only if the |date=&amp;lt;value&amp;gt; is &lt;br /&gt;
determined to be a valid date format.  The question of what to do with invalid date formats is not answered here.&lt;br /&gt;
&lt;br /&gt;
The date parts in the input table are converted to an ISO 8601 conforming date string:&lt;br /&gt;
	single whole dates:		yyyy-mm-dd&lt;br /&gt;
	month and year dates:	yyyy-mm&lt;br /&gt;
	year dates:				yyyy&lt;br /&gt;
	ranges:					yyyy-mm-dd/yyyy-mm-dd&lt;br /&gt;
							yyyy-mm/yyyy-mm&lt;br /&gt;
							yyyy/yyyy&lt;br /&gt;
&lt;br /&gt;
Dates in the Julian calendar are reduced to year or year/year so that we don&#039;t have to do calendar conversion from&lt;br /&gt;
Julian to Proleptic Gregorian.&lt;br /&gt;
&lt;br /&gt;
The input table has:&lt;br /&gt;
	year, year2 – always present; if before 1582, ignore months and days if present&lt;br /&gt;
	month, month2 – 0 if not provided, 1-12 for months, 21-24 for seasons; 99 Christmas&lt;br /&gt;
	day, day2 –  0 if not provided, 1-31 for days&lt;br /&gt;
	&lt;br /&gt;
the output table receives:&lt;br /&gt;
	rftdate:	an IS8601 formatted date&lt;br /&gt;
	rftchron:	a free-form version of the date, usually without year which is in rftdate (season ranges and propername dates)&lt;br /&gt;
	rftssn:		one of four season keywords: winter, spring, summer, fall (lowercase)&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function make_COinS_date (input, tCOinS_date)&lt;br /&gt;
	local date;																	-- one date or first date in a range&lt;br /&gt;
	local date2 = &#039;&#039;;															-- end of range date&lt;br /&gt;
-- start temporary Julian / Gregorian calendar uncertainty detection&lt;br /&gt;
	local year = tonumber(input.year);											-- this temporary code to determine the extent of sources dated to the Julian/Gregorian&lt;br /&gt;
	local month = tonumber(input.month);										-- interstice 1 October 1582 – 1 January 1926&lt;br /&gt;
	local day = tonumber (input.day);&lt;br /&gt;
	if (0 ~= day) and															-- day must have a value for this to be a whole date&lt;br /&gt;
		(((1582 == year) and (10 &amp;lt;= month) and (12 &amp;gt;= month)) or				-- any whole 1582 date from 1 october to 31 December or&lt;br /&gt;
			((1926 == year) and (1 == month) and (1 == input.day)) or			-- 1 January 1926 or&lt;br /&gt;
				((1582 &amp;lt; year) and (1925 &amp;gt;= year))) then						-- any date 1 January 1583 – 31 December 1925&lt;br /&gt;
					tCOinS_date.inter_cal_cat = true;							-- set category flag true&lt;br /&gt;
	end&lt;br /&gt;
-- end temporary Julian / Gergorian calendar uncertainty detection&lt;br /&gt;
	&lt;br /&gt;
	if 1582 &amp;gt; tonumber(input.year) or 20 &amp;lt; tonumber(input.month) then			-- Julian calendar or season so &amp;amp;rft.date gets year only&lt;br /&gt;
		date = input.year;&lt;br /&gt;
		if 0 ~= input.year2 and input.year ~= input.year2 then					-- if a range, only the second year portion when not the same as range start year&lt;br /&gt;
			date = string.format (&#039;%.4d/%.4d&#039;, tonumber(input.year), tonumber(input.year2))		-- assemble the date range&lt;br /&gt;
		end&lt;br /&gt;
		if 20 &amp;lt; tonumber(input.month) then										-- if season or propername date&lt;br /&gt;
			local season = {[24]=&#039;winter&#039;, [21]=&#039;spring&#039;, [22]=&#039;summer&#039;, [23]=&#039;fall&#039;, [99]=&#039;Christmas&#039;};	-- seasons lowercase, no autumn; proper names use title case&lt;br /&gt;
			if 0 == input.month2 then											-- single season date&lt;br /&gt;
				if 30 &amp;lt;tonumber(input.month) then&lt;br /&gt;
					tCOinS_date.rftchron = season[input.month];					-- proper name dates&lt;br /&gt;
				else&lt;br /&gt;
					tCOinS_date.rftssn = season[input.month];					-- seasons&lt;br /&gt;
				end&lt;br /&gt;
			else																-- season range with a second season specified&lt;br /&gt;
				if input.year ~= input.year2 then								-- season year – season year range or season year–year&lt;br /&gt;
					tCOinS_date.rftssn = season[input.month];					-- start of range season; keep this?&lt;br /&gt;
					if 0~= input.month2 then&lt;br /&gt;
						tCOinS_date.rftchron = string.format (&#039;%s %s – %s %s&#039;, season[input.month], input.year, season[input.month2], input.year2);&lt;br /&gt;
					end&lt;br /&gt;
				else															-- season–season year range&lt;br /&gt;
					tCOinS_date.rftssn = season[input.month];					-- start of range season; keep this?&lt;br /&gt;
					tCOinS_date.rftchron = season[input.month] .. &#039;–&#039; .. season[input.month2];	-- season–season year range&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		tCOinS_date.rftdate = date;&lt;br /&gt;
		return;																	-- done&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if 0 ~= input.day then&lt;br /&gt;
		date = string.format (&#039;%s-%.2d-%.2d&#039;, input.year, tonumber(input.month), tonumber(input.day));	-- whole date&lt;br /&gt;
	elseif 0 ~= input.month then&lt;br /&gt;
		date = string.format (&#039;%s-%.2d&#039;, input.year, tonumber(input.month));	-- year and month&lt;br /&gt;
	else&lt;br /&gt;
		date = string.format (&#039;%s&#039;, input.year);								-- just year&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if 0 ~= input.year2 then&lt;br /&gt;
		if 0 ~= input.day2 then&lt;br /&gt;
			date2 = string.format (&#039;/%s-%.2d-%.2d&#039;, input.year2, tonumber(input.month2), tonumber(input.day2));		-- whole date&lt;br /&gt;
		elseif 0 ~= input.month2 then&lt;br /&gt;
			date2 = string.format (&#039;/%s-%.2d&#039;, input.year2, tonumber(input.month2));	-- year and month&lt;br /&gt;
		else&lt;br /&gt;
			date2 = string.format (&#039;/%s&#039;, input.year2);							-- just year&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	tCOinS_date.rftdate = date .. date2;										-- date2 has the &#039;/&#039; separator&lt;br /&gt;
	return;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C H E C K _ D A T E &amp;gt;----------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Check date format to see that it is one of the formats approved by WP:DATESNO or WP:DATERANGE. Exception: only&lt;br /&gt;
allowed range separator is endash.  Additionally, check the date to see that it is a real date: no 31 in 30-day&lt;br /&gt;
months; no 29 February when not a leap year.  Months, both long-form and three character abbreviations, and seasons&lt;br /&gt;
must be spelled correctly.  Future years beyond next year are not allowed.&lt;br /&gt;
&lt;br /&gt;
If the date fails the format tests, this function returns false and does not return values for anchor_year and&lt;br /&gt;
COinS_date.  When this happens, the date parameter is used in the COinS metadata and the CITEREF identifier gets&lt;br /&gt;
its year from the year parameter if present otherwise CITEREF does not get a date value.&lt;br /&gt;
&lt;br /&gt;
Inputs:&lt;br /&gt;
	date_string - date string from date-holding parameters (date, year, accessdate, embargo, archivedate, etc.)&lt;br /&gt;
&lt;br /&gt;
Returns:&lt;br /&gt;
	false if date string is not a real date; else&lt;br /&gt;
	true, anchor_year, COinS_date&lt;br /&gt;
		anchor_year can be used in CITEREF anchors&lt;br /&gt;
		COinS_date is ISO 8601 format date; see make_COInS_date()&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function check_date (date_string, tCOinS_date, test_accessdate)&lt;br /&gt;
	local year;			-- assume that year2, months, and days are not used;&lt;br /&gt;
	local year2=0;		-- second year in a year range&lt;br /&gt;
	local month=0;&lt;br /&gt;
	local month2=0;		-- second month in a month range&lt;br /&gt;
	local day=0;&lt;br /&gt;
	local day2=0;		-- second day in a day range&lt;br /&gt;
	local anchor_year;&lt;br /&gt;
	local coins_date;&lt;br /&gt;
&lt;br /&gt;
	if date_string:match(&amp;quot;^%d%d%d%d%-%d%d%-%d%d$&amp;quot;) then										-- year-initial numerical year month day format&lt;br /&gt;
		year, month, day=string.match(date_string, &amp;quot;(%d%d%d%d)%-(%d%d)%-(%d%d)&amp;quot;);&lt;br /&gt;
		if 12 &amp;lt; tonumber(month) or 1 &amp;gt; tonumber(month) or 1582 &amp;gt; tonumber(year) or 0 == tonumber(day) then return false; end	-- month or day number not valid or not Gregorian calendar&lt;br /&gt;
		anchor_year = year;&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^%D- +[1-9]%d?, +[1-9]%d%d%d%a?$&amp;quot;) then						-- month-initial: month day, year&lt;br /&gt;
		month, day, anchor_year, year=mw.ustring.match(date_string, &amp;quot;(%D-) +(%d%d?),%s*((%d%d%d%d?)%a?)&amp;quot;);&lt;br /&gt;
		month = get_month_number (month);&lt;br /&gt;
		if 0 == month then return false; end												-- return false if month text isn&#039;t one of the twelve months&lt;br /&gt;
				&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^%D- +[1-9]%d?[%-–][1-9]%d?, +[1-9]%d%d%d%a?$&amp;quot;) then				-- month-initial day range: month day–day, year; days are separated by endash&lt;br /&gt;
		month, day, day2, anchor_year, year=mw.ustring.match(date_string, &amp;quot;(%D-) +(%d%d?)[%-–](%d%d?), +((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if tonumber(day) &amp;gt;= tonumber(day2) then return false; end							-- date range order is left to right: earlier to later; dates may not be the same;&lt;br /&gt;
		month = get_month_number (month);&lt;br /&gt;
		if 0 == month then return false; end												-- return false if month text isn&#039;t one of the twelve months&lt;br /&gt;
		month2=month;																		-- for metadata&lt;br /&gt;
		year2=year;&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^[1-9]%d? +%D- +[1-9]%d%d%d%a?$&amp;quot;) then						-- day-initial: day month year&lt;br /&gt;
		day, month, anchor_year, year=mw.ustring.match(date_string, &amp;quot;(%d%d*)%s*(%D-) +((%d%d%d%d?)%a?)&amp;quot;);&lt;br /&gt;
		month = get_month_number (month);&lt;br /&gt;
		if 0 == month then return false; end												-- return false if month text isn&#039;t one of the twelve months&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^[1-9]%d?[%-–][1-9]%d? +%D- +[1-9]%d%d%d%a?$&amp;quot;) then				-- day-range-initial: day–day month year; days are separated by endash&lt;br /&gt;
		day, day2, month, anchor_year, year=mw.ustring.match(date_string, &amp;quot;(%d%d?)[%-–](%d%d?) +(%D-) +((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if tonumber(day) &amp;gt;= tonumber(day2) then return false; end							-- date range order is left to right: earlier to later; dates may not be the same;&lt;br /&gt;
		month = get_month_number (month);&lt;br /&gt;
		if 0 == month then return false; end												-- return false if month text isn&#039;t one of the twelve months&lt;br /&gt;
		month2=month;																		-- for metadata&lt;br /&gt;
		year2=year;&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^[1-9]%d? +%D- +[%-–] +[1-9]%d? +%D- +[1-9]%d%d%d%a?$&amp;quot;) then		-- day initial month-day-range: day month - day month year; uses spaced endash&lt;br /&gt;
		day, month, day2, month2, anchor_year, year=mw.ustring.match(date_string, &amp;quot;(%d%d?) +(%D-) +[%-–] +(%d%d?) +(%D-) +((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if (not is_valid_month_season_range(month, month2)) or not is_valid_year(year) then return false; end	-- date range order is left to right: earlier to later;&lt;br /&gt;
		month = get_month_number (month);													-- for metadata&lt;br /&gt;
		month2 = get_month_number (month2);&lt;br /&gt;
		year2=year;&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^%D- +[1-9]%d? +[%-–] +%D- +[1-9]%d?, +[1-9]%d%d%d%a?$&amp;quot;) then		-- month initial month-day-range: month day – month day, year;  uses spaced endash&lt;br /&gt;
		month, day, month2, day2, anchor_year, year=mw.ustring.match(date_string, &amp;quot;(%D-) +(%d%d?) +[%-–] +(%D-) +(%d%d?), +((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if (not is_valid_month_season_range(month, month2)) or not is_valid_year(year) then return false; end&lt;br /&gt;
		month = get_month_number (month);													-- for metadata&lt;br /&gt;
		month2 = get_month_number (month2);&lt;br /&gt;
		year2=year;&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^[1-9]%d? +%D- +[1-9]%d%d%d +[%-–] +[1-9]%d? +%D- +[1-9]%d%d%d%a?$&amp;quot;) then		-- day initial month-day-year-range: day month year - day month year; uses spaced endash&lt;br /&gt;
		day, month, year, day2, month2, anchor_year, year2=mw.ustring.match(date_string, &amp;quot;(%d%d?) +(%D-) +(%d%d%d%d) +[%-–] +(%d%d?) +(%D-) +((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if tonumber(year2) &amp;lt;= tonumber(year) then return false; end												-- must be sequential years, left to right, earlier to later&lt;br /&gt;
		if not is_valid_year(year2) or not is_valid_month_range_style(month, month2) then return false; end		-- year2 no more than one year in the future; months same style&lt;br /&gt;
		month = get_month_number (month);																		-- for metadata&lt;br /&gt;
		month2 = get_month_number (month2);&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^%D- +[1-9]%d?, +[1-9]%d%d%d +[%-–] +%D- +[1-9]%d?, +[1-9]%d%d%d%a?$&amp;quot;) then		-- month initial month-day-year-range: month day, year – month day, year;  uses spaced endash&lt;br /&gt;
		month, day, year, month2, day2, anchor_year, year2=mw.ustring.match(date_string, &amp;quot;(%D-) +(%d%d?), +(%d%d%d%d) +[%-–] +(%D-) +(%d%d?), +((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if tonumber(year2) &amp;lt;= tonumber(year) then return false; end												-- must be sequential years, left to right, earlier to later&lt;br /&gt;
		if not is_valid_year(year2) or not is_valid_month_range_style(month, month2) then return false; end		-- year2 no more than one year in the future; months same style&lt;br /&gt;
		month = get_month_number (month);																		-- for metadata&lt;br /&gt;
		month2 = get_month_number (month2);&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^%D- +[1-9]%d%d%d[%-–]%d%d%a?$&amp;quot;) then								-- special case Winter/Summer year-year (YYYY-YY); year separated with unspaced endash&lt;br /&gt;
		local century;&lt;br /&gt;
		month, year, century, anchor_year, year2=mw.ustring.match(date_string, &amp;quot;(%D-) +((%d%d)%d%d)[%-–]((%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if &#039;Winter&#039; ~= month and &#039;Summer&#039; ~= month then return false end;					-- &#039;month&#039; can only be Winter or Summer&lt;br /&gt;
		anchor_year=year..&#039;–&#039;..anchor_year;													-- assemble anchor_year from both years&lt;br /&gt;
		year2 = century..year2;																-- add the century to year2 for comparisons&lt;br /&gt;
		if 1 ~= tonumber(year2) - tonumber(year) then return false; end						-- must be sequential years, left to right, earlier to later&lt;br /&gt;
		if not is_valid_year(year2) then return false; end									-- no year farther in the future than next year&lt;br /&gt;
		month = get_season_number (month);&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^%D- +[1-9]%d%d%d[%-–][1-9]%d%d%d%a?$&amp;quot;) then						-- special case Winter/Summer year-year; year separated with unspaced endash&lt;br /&gt;
		month, year, anchor_year, year2=mw.ustring.match(date_string, &amp;quot;(%D-) +(%d%d%d%d)[%-–]((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if &#039;Winter&#039; ~= month and &#039;Summer&#039; ~= month then return false end;					-- &#039;month&#039; can only be Winter or Summer&lt;br /&gt;
		anchor_year=year..&#039;–&#039;..anchor_year;													-- assemble anchor_year from both years&lt;br /&gt;
		if 1 ~= tonumber(year2) - tonumber(year) then return false; end						-- must be sequential years, left to right, earlier to later&lt;br /&gt;
		if not is_valid_year(year2) then return false; end									-- no year farther in the future than next year&lt;br /&gt;
		month = get_season_number (month);													-- for metadata&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^%D- +[1-9]%d%d%d +[%-–] +%D- +[1-9]%d%d%d%a?$&amp;quot;) then				-- month/season year - month/season year; separated by spaced endash&lt;br /&gt;
		month, year, month2, anchor_year, year2=mw.ustring.match(date_string, &amp;quot;(%D-) +(%d%d%d%d) +[%-–] +(%D-) +((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		anchor_year=year..&#039;–&#039;..anchor_year;													-- assemble anchor_year from both years&lt;br /&gt;
		if tonumber(year) &amp;gt;= tonumber(year2) then return false; end							-- left to right, earlier to later, not the same&lt;br /&gt;
		if not is_valid_year(year2) then return false; end									-- no year farther in the future than next year&lt;br /&gt;
		if 0 ~= get_month_number(month) and 0 ~= get_month_number(month2) and is_valid_month_range_style(month, month2) then 	-- both must be month year, same month style&lt;br /&gt;
			month = get_month_number(month);&lt;br /&gt;
			month2 = get_month_number(month2);&lt;br /&gt;
		elseif 0 ~= get_season_number(month) and 0 ~= get_season_number(month2) then		-- both must be or season year, not mixed&lt;br /&gt;
			month = get_season_number(month);&lt;br /&gt;
			month2 = get_season_number(month2);&lt;br /&gt;
		else&lt;br /&gt;
			 return false;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^%D-[%-–]%D- +[1-9]%d%d%d%a?$&amp;quot;) then					-- month/season range year; months separated by endash &lt;br /&gt;
		month, month2, anchor_year, year=mw.ustring.match(date_string, &amp;quot;(%D-)[%-–](%D-)%s*((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if (not is_valid_month_season_range(month, month2)) or (not is_valid_year(year)) then return false; end&lt;br /&gt;
		if 0 ~= get_month_number(month) then									-- determined to be a valid range so just check this one to know if month or season&lt;br /&gt;
			month = get_month_number(month);&lt;br /&gt;
			month2 = get_month_number(month2);&lt;br /&gt;
		else&lt;br /&gt;
			month = get_season_number(month);&lt;br /&gt;
			month2 = get_season_number(month2);&lt;br /&gt;
		end&lt;br /&gt;
		year2=year;&lt;br /&gt;
		&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^%D- +%d%d%d%d%a?$&amp;quot;) then							-- month/season year or proper-name year&lt;br /&gt;
		month, anchor_year, year=mw.ustring.match(date_string, &amp;quot;(%D-)%s*((%d%d%d%d)%a?)&amp;quot;);&lt;br /&gt;
		if not is_valid_year(year) then return false; end&lt;br /&gt;
		if not is_valid_month_or_season (month) and 0 == is_proper_name (month) then return false; end&lt;br /&gt;
		if 0 ~= get_month_number(month) then									-- determined to be a valid range so just check this one to know if month or season&lt;br /&gt;
			month = get_month_number(month);&lt;br /&gt;
		elseif 0 ~= get_season_number(month) then&lt;br /&gt;
			month = get_season_number(month);&lt;br /&gt;
		else&lt;br /&gt;
			month = is_proper_name (month);										-- must be proper name; not supported in COinS&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^[1-9]%d%d%d?[%-–][1-9]%d%d%d?%a?$&amp;quot;) then				-- Year range: YYY-YYY or YYY-YYYY or YYYY–YYYY; separated by unspaced endash; 100-9999&lt;br /&gt;
		year, anchor_year, year2=mw.ustring.match(date_string, &amp;quot;(%d%d%d%d?)[%-–]((%d%d%d%d?)%a?)&amp;quot;);&lt;br /&gt;
		anchor_year=year..&#039;–&#039;..anchor_year;										-- assemble anchor year from both years&lt;br /&gt;
		if tonumber(year) &amp;gt;= tonumber(year2) then return false; end				-- left to right, earlier to later, not the same&lt;br /&gt;
		if not is_valid_year(year2) then return false; end						-- no year farther in the future than next year&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;^[1-9]%d%d%d[%-–]%d%d%a?$&amp;quot;) then						-- Year range: YYYY–YY; separated by unspaced endash&lt;br /&gt;
		local century;&lt;br /&gt;
		year, century, anchor_year, year2=mw.ustring.match(date_string, &amp;quot;((%d%d)%d%d)[%-–]((%d%d)%a?)&amp;quot;);&lt;br /&gt;
		anchor_year=year..&#039;–&#039;..anchor_year;										-- assemble anchor year from both years&lt;br /&gt;
		if 13 &amp;gt; tonumber(year2) then return false; end							-- don&#039;t allow 2003-05 which might be May 2003&lt;br /&gt;
		year2 = century..year2;													-- add the century to year2 for comparisons&lt;br /&gt;
		if tonumber(year) &amp;gt;= tonumber(year2) then return false; end				-- left to right, earlier to later, not the same&lt;br /&gt;
		if not is_valid_year(year2) then return false; end						-- no year farther in the future than next year&lt;br /&gt;
&lt;br /&gt;
	elseif date_string:match(&amp;quot;^[1-9]%d%d%d?%a?$&amp;quot;) then							-- year; here accept either YYY or YYYY&lt;br /&gt;
		anchor_year, year=date_string:match(&amp;quot;((%d%d%d%d?)%a?)&amp;quot;);&lt;br /&gt;
		if false == is_valid_year(year) then&lt;br /&gt;
			return false;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	else&lt;br /&gt;
		return false;															-- date format not one of the MOS:DATE approved formats&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if test_accessdate then														-- test accessdate here because we have numerical date parts&lt;br /&gt;
		if 0 ~= year and 0 ~= month and 0 ~= day and 							-- all parts of a single date required&lt;br /&gt;
			0 == year2 and 0 == month2 and 0 == day2 then						-- none of these; accessdate must not be a range&lt;br /&gt;
				if not is_valid_accessdate (year..&#039;-&#039;..month..&#039;-&#039;..day) then	&lt;br /&gt;
					return false;												-- return false when accessdate out of bounds&lt;br /&gt;
				end&lt;br /&gt;
		else&lt;br /&gt;
			return false;														-- return false when accessdate is a range of two dates&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local result=true;															-- check whole dates for validity; assume true because not all dates will go through this test&lt;br /&gt;
	if 0 ~= year and 0 ~= month and 0 ~= day and 0 == year2 and 0 == month2 and 0 == day2 then		-- YMD (simple whole date)&lt;br /&gt;
		result=is_valid_date(year,month,day);&lt;br /&gt;
&lt;br /&gt;
	elseif 0 ~= year and 0 ~= month and 0 ~= day and 0 == year2 and 0 == month2 and 0 ~= day2 then	-- YMD-d (day range)&lt;br /&gt;
		result=is_valid_date(year,month,day);&lt;br /&gt;
		result=result and is_valid_date(year,month,day2);&lt;br /&gt;
&lt;br /&gt;
	elseif 0 ~= year and 0 ~= month and 0 ~= day and 0 == year2 and 0 ~= month2 and 0 ~= day2 then	-- YMD-md (day month range)&lt;br /&gt;
		result=is_valid_date(year,month,day);&lt;br /&gt;
		result=result and is_valid_date(year,month2,day2);&lt;br /&gt;
&lt;br /&gt;
	elseif 0 ~= year and 0 ~= month and 0 ~= day and 0 ~= year2 and 0 ~= month2 and 0 ~= day2 then	-- YMD-ymd (day month year range)&lt;br /&gt;
		result=is_valid_date(year,month,day);&lt;br /&gt;
		result=result and is_valid_date(year2,month2,day2);&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if false == result then return false; end&lt;br /&gt;
&lt;br /&gt;
	if nil ~= tCOinS_date then													-- this table only passed into this function when testing |date= parameter values&lt;br /&gt;
		make_COinS_date ({year=year, month=month, day=day, year2=year2, month2=month2, day2=day2}, tCOinS_date);	-- make an ISO 8601 date string for COinS&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return true, anchor_year;													-- format is good and date string represents a real date&lt;br /&gt;
end	&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; D A T E S &amp;gt;--------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Cycle the date-holding parameters in passed table date_parameters_list through check_date() to check compliance with MOS:DATE. For all valid dates, check_date() returns&lt;br /&gt;
true. The |date= parameter test is unique, it is the only date holding parameter from which values for anchor_year (used in CITEREF identifiers) and COinS_date (used in&lt;br /&gt;
the COinS metadata) are derived.  The |date= parameter is the only date-holding parameter that is allowed to contain the no-date keywords &amp;quot;n.d.&amp;quot; or &amp;quot;nd&amp;quot; (without quotes).&lt;br /&gt;
&lt;br /&gt;
Unlike most error messages created in this module, only one error message is created by this function. Because all of the date holding parameters are processed serially,&lt;br /&gt;
a single error message is created as the dates are tested.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function dates(date_parameters_list, tCOinS_date)&lt;br /&gt;
	local anchor_year;		-- will return as nil if the date being tested is not |date=&lt;br /&gt;
	local COinS_date;		-- will return as nil if the date being tested is not |date=&lt;br /&gt;
	local embargo_date;															-- if embargo date is a good dmy, mdy, ymd date then holds original value else reset to 9999&lt;br /&gt;
	local error_message = &amp;quot;&amp;quot;;&lt;br /&gt;
	local good_date = false;&lt;br /&gt;
	&lt;br /&gt;
	for k, v in pairs(date_parameters_list) do									-- for each date-holding parameter in the list&lt;br /&gt;
		if is_set(v) then														-- if the parameter has a value&lt;br /&gt;
			if v:match(&amp;quot;^c%. [1-9]%d%d%d?%a?$&amp;quot;) then							-- special case for c. year or with or without CITEREF disambiguator - only |date= and |year=&lt;br /&gt;
				v = mw.ustring.gsub (v, &#039;%d&#039;, cfg.date_names.local_digits);&lt;br /&gt;
				local year = v:match(&amp;quot;c%. ([1-9]%d%d%d?)%a?&amp;quot;);					-- get the year portion so it can be tested&lt;br /&gt;
				if &#039;date&#039;==k then&lt;br /&gt;
					anchor_year, COinS_date = v:match(&amp;quot;((c%. [1-9]%d%d%d?)%a?)&amp;quot;);	-- anchor year and COinS_date only from |date= parameter&lt;br /&gt;
					good_date = is_valid_year(year);&lt;br /&gt;
				elseif &#039;year&#039;==k then&lt;br /&gt;
					good_date = is_valid_year(year);&lt;br /&gt;
				end&lt;br /&gt;
			elseif &#039;date&#039;==k then												-- if the parameter is |date=&lt;br /&gt;
				if v:match(&amp;quot;^n%.d%.%a?$&amp;quot;) then									-- if |date=n.d. with or without a CITEREF disambiguator&lt;br /&gt;
					good_date, anchor_year, COinS_date = true, v:match(&amp;quot;((n%.d%.)%a?)&amp;quot;);	--&amp;quot;n.d.&amp;quot;; no error when date parameter is set to no date&lt;br /&gt;
				elseif v:match(&amp;quot;^nd%a?$&amp;quot;) then									-- if |date=nd with or without a CITEREF disambiguator&lt;br /&gt;
					good_date, anchor_year, COinS_date = true, v:match(&amp;quot;((nd)%a?)&amp;quot;);	--&amp;quot;nd&amp;quot;;	no error when date parameter is set to no date&lt;br /&gt;
				else&lt;br /&gt;
					good_date, anchor_year, COinS_date = check_date (v, tCOinS_date);	-- go test the date&lt;br /&gt;
				end&lt;br /&gt;
			elseif &#039;year&#039;==k then												-- if the parameter is |year= it should hold only a year value&lt;br /&gt;
				if v:match(&amp;quot;^[1-9]%d%d%d?%a?$&amp;quot;) then							-- if |year= 3 or 4 digits only with or without a CITEREF disambiguator&lt;br /&gt;
					good_date, anchor_year, COinS_date = true, v:match(&amp;quot;((%d+)%a?)&amp;quot;);&lt;br /&gt;
				end&lt;br /&gt;
			elseif &#039;access-date&#039;==k then										-- if the parameter is |date=&lt;br /&gt;
				good_date = check_date (v, nil, true);							-- go test the date; nil is a placeholder; true is the test_accessdate flag&lt;br /&gt;
			elseif &#039;embargo&#039;==k then											-- if the parameter is |embargo=&lt;br /&gt;
				good_date = check_date (v);										-- go test the date&lt;br /&gt;
				if true == good_date then										-- if the date is a valid date&lt;br /&gt;
					good_date, embargo_date = is_valid_embargo_date (v);		-- is |embargo= date a single dmy, mdy, or ymd formatted date? yes:returns embargo; no: returns 9999&lt;br /&gt;
				end&lt;br /&gt;
			else																-- any other date-holding parameter&lt;br /&gt;
				good_date = check_date (v);										-- go test the date&lt;br /&gt;
			end&lt;br /&gt;
			if false==good_date then											-- assemble one error message so we don&#039;t add the tracking category multiple times&lt;br /&gt;
				if is_set(error_message) then									-- once we&#039;ve added the first portion of the error message ...&lt;br /&gt;
					error_message=error_message .. &amp;quot;, &amp;quot;;						-- ... add a comma space separator&lt;br /&gt;
				end&lt;br /&gt;
				error_message=error_message .. &amp;quot;&amp;amp;#124;&amp;quot; .. k .. &amp;quot;=&amp;quot;;			-- add the failed parameter&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return anchor_year, embargo_date, error_message;											-- and done&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; Y E A R _ D A T E _ C H E C K &amp;gt;------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Compare the value provided in |year= with the year value(s) provided in |date=.  This function returns a numeric value:&lt;br /&gt;
	0 - year value does not match the year value in date&lt;br /&gt;
	1 - (default) year value matches the year value in date or one of the year values when date contains two years&lt;br /&gt;
	2 - year value matches the year value in date when date is in the form YYYY-MM-DD and year is disambiguated (|year=YYYYx)&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function year_date_check (year_string, date_string)&lt;br /&gt;
	local year;&lt;br /&gt;
	local date1;&lt;br /&gt;
	local date2;&lt;br /&gt;
	local result = 1;															-- result of the test; assume that the test passes&lt;br /&gt;
	&lt;br /&gt;
	year = year_string:match (&#039;(%d%d%d%d?)&#039;);&lt;br /&gt;
&lt;br /&gt;
	if date_string:match (&#039;%d%d%d%d%-%d%d%-%d%d&#039;) and year_string:match (&#039;%d%d%d%d%a&#039;) then	--special case where both date and year are required YYYY-MM-DD and YYYYx&lt;br /&gt;
		date1 = date_string:match (&#039;(%d%d%d%d)&#039;);&lt;br /&gt;
		year = year_string:match (&#039;(%d%d%d%d)&#039;);&lt;br /&gt;
		if year ~= date1 then&lt;br /&gt;
			result = 0;															-- years don&#039;t match&lt;br /&gt;
		else&lt;br /&gt;
			result = 2;															-- years match; but because disambiguated, don&#039;t add to maint cat&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
	elseif date_string:match (&amp;quot;%d%d%d%d?.-%d%d%d%d?&amp;quot;) then						-- any of the standard range formats of date with two three- or four-digit years&lt;br /&gt;
		date1, date2 = date_string:match (&amp;quot;(%d%d%d%d?).-(%d%d%d%d?)&amp;quot;);&lt;br /&gt;
		if year ~= date1 and year ~= date2 then&lt;br /&gt;
			result = 0;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	elseif mw.ustring.match(date_string, &amp;quot;%d%d%d%d[%-–]%d%d&amp;quot;) then								-- YYYY-YY date ranges&lt;br /&gt;
		local century;&lt;br /&gt;
		date1, century, date2 = mw.ustring.match(date_string, &amp;quot;((%d%d)%d%d)[%-–]+(%d%d)&amp;quot;);&lt;br /&gt;
		date2 = century..date2;													-- convert YY to YYYY&lt;br /&gt;
		if year ~= date1 and year ~= date2 then&lt;br /&gt;
			result = 0;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	elseif date_string:match (&amp;quot;%d%d%d%d?&amp;quot;) then									-- any of the standard formats of date with one year&lt;br /&gt;
		date1 = date_string:match (&amp;quot;(%d%d%d%d?)&amp;quot;);&lt;br /&gt;
		if year ~= date1 then&lt;br /&gt;
			result = 0;&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		result = 0;																-- no recognizable year in date&lt;br /&gt;
	end&lt;br /&gt;
	return result;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; R E F O R M A T   T A B L E S &amp;gt;------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
These table are used exclusively for reformatting dates&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local source_patterns = {						-- this table holds patterns that match allowed date formats used to extract date components&lt;br /&gt;
	[&#039;dmy&#039;] = &#039;^(%d%d?)%s+(%a+)%s+(%d%d%d%d)$&#039;,&lt;br /&gt;
	[&#039;mdy&#039;] = &#039;^(%a+)%s+(%d%d?),%s+(%d%d%d%d)$&#039;,&lt;br /&gt;
	[&#039;ymd&#039;] = &#039;^(%d%d%d%d)%-(%d%d)-(%d%d)$&#039;,&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
local short_formats = {							-- this table holds format strings used by os.date() for short month names&lt;br /&gt;
	[&#039;dmy&#039;] = &#039;%e %b %Y&#039;,&lt;br /&gt;
	[&#039;mdy&#039;] = &#039;%b %e, %Y&#039;,&lt;br /&gt;
	[&#039;ymd&#039;] = &#039;%F&#039;,&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
local long_formats = {							-- this table holds format strings used by os.date() for long month names&lt;br /&gt;
	[&#039;dmy&#039;] = &#039;%e %B %Y&#039;,&lt;br /&gt;
	[&#039;mdy&#039;] = &#039;%B %e, %Y&#039;,&lt;br /&gt;
	[&#039;ymd&#039;] = &#039;%F&#039;,&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; G E T _ D M Y _ D A T E _ P A R T S &amp;gt;------------------------------------------&lt;br /&gt;
&lt;br /&gt;
extracts year, month and day from DMY formatted date, places them in the source_date table, and returns.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function get_dmy_date_parts (date, source_date)&lt;br /&gt;
	source_date.day, source_date.month, source_date.year = date:match (source_patterns[&#039;dmy&#039;]);	-- get date components as strings&lt;br /&gt;
	source_date.month = get_month_number (source_date.month);					-- get month number&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; G E T _ M D Y _ D A T E _ P A R T S &amp;gt;------------------------------------------&lt;br /&gt;
&lt;br /&gt;
extracts year, month and day from MDY formatted date, places them in the source_date table, and returns.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function get_mdy_date_parts (date, source_date)&lt;br /&gt;
	source_date.month, source_date.day, source_date.year = date:match (source_patterns[&#039;mdy&#039;]);	-- get date components as strings&lt;br /&gt;
	source_date.month = get_month_number (source_date.month);					-- get month number&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; G E T _ Y M D _ D A T E _ P A R T S &amp;gt;------------------------------------------&lt;br /&gt;
&lt;br /&gt;
extracts year, month and day from YMD formatted date, places them in the source_date table, and returns.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function get_ymd_date_parts (date, source_date)&lt;br /&gt;
	source_date.year, source_date.month, source_date.day = date:match (source_patterns[&#039;ymd&#039;]);	-- get date components as strings&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; R E F O R M A T _ D A T E S &amp;gt;--------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Reformats existing dates into the format specified by format and short.&lt;br /&gt;
&lt;br /&gt;
format is one of several keywords: dmy, dmy-all, mdy, mdy-all, ymd, ymd-all.  The all version includes access- and&lt;br /&gt;
archive-dates; otherwise these dates are not reformatted&lt;br /&gt;
&lt;br /&gt;
Date ranges, season dates, proper name dates are not currently supported.&lt;br /&gt;
&lt;br /&gt;
For i18n:  This code works only at en.wiki because os.date() doesn&#039;t support any languages other than English.&lt;br /&gt;
mw.getContentLanguage():formatDate() will work at non-English wikis only when the date format is yyyy-mm-dd. This is&lt;br /&gt;
the same issue that plagues is_valid_accessdate()&lt;br /&gt;
&lt;br /&gt;
It is possible that a solution like that written for ht:Module:Citation/CS1/Date_validation date_name_xlate() could be applied to this problem&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function reformat_dates (date_parameters_list, format, short)&lt;br /&gt;
	local all = false;															-- set to false to skip access- and archive-dates&lt;br /&gt;
	local format_str;&lt;br /&gt;
	local source_date = {};&lt;br /&gt;
	&lt;br /&gt;
	if format:match(&#039;%a+%-all&#039;) then&lt;br /&gt;
		format = format:match(&#039;(%a+)%-all&#039;);									-- extract the format&lt;br /&gt;
		all = true;																-- set to true to format access- and archive-dates&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	for param_name, param_val in pairs (date_parameters_list) do				-- for each date-holding parameter in the list&lt;br /&gt;
		if is_set (param_val) then												-- if the parameter has a value&lt;br /&gt;
			if not all and in_array (param_name, {&#039;access-date&#039;, &#039;archive-date&#039;}) then	-- if access- or archive-date and format not xxx-all&lt;br /&gt;
				param_val = &#039;&#039;;													-- set to empty string so we don&#039;t process this date&lt;br /&gt;
			end&lt;br /&gt;
			for source, pattern in pairs (source_patterns) do&lt;br /&gt;
				if param_val:match (pattern) then&lt;br /&gt;
					if &#039;ymd&#039; == source then&lt;br /&gt;
						get_ymd_date_parts (param_val, source_date);			-- get the date parts into the source_date table&lt;br /&gt;
					elseif &#039;dmy&#039; == source then&lt;br /&gt;
						get_dmy_date_parts (param_val, source_date);			-- get the date parts into the source_date table&lt;br /&gt;
					elseif &#039;mdy&#039; == source then&lt;br /&gt;
						get_mdy_date_parts (param_val, source_date);			-- get the date parts into the source_date table&lt;br /&gt;
					end&lt;br /&gt;
&lt;br /&gt;
					if &#039;ymd&#039; == format and 1582 &amp;gt; tonumber(source_date.year) then	-- ymd format dates not allowed before 1582&lt;br /&gt;
						return false;											-- abandon reformatting&lt;br /&gt;
					end&lt;br /&gt;
					&lt;br /&gt;
					if short then&lt;br /&gt;
						format_str = short_formats[format];&lt;br /&gt;
					else&lt;br /&gt;
						format_str = long_formats[format];&lt;br /&gt;
					end&lt;br /&gt;
																				-- convert date and save;&lt;br /&gt;
					date_parameters_list[param_name] = mw.text.trim (os.date (format_str, os.time(source_date)));	-- strip leading space when single digit day and %e is first format&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return true;																-- declare success and done&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; D A T E _ H Y P H E N _ T O _ D A S H &amp;gt;----------------------------------------&lt;br /&gt;
&lt;br /&gt;
Loops through the list of date-holding parameters and converts any hyphen to an ndash.  Not called if the cs1|2&lt;br /&gt;
template has any date errors.&lt;br /&gt;
&lt;br /&gt;
Modifies the date_parameters_list and returns true if hyphens are replaced, else returns false.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function date_hyphen_to_dash (date_parameters_list)&lt;br /&gt;
	local result = false;&lt;br /&gt;
	local n;&lt;br /&gt;
	for param_name, param_val in pairs(date_parameters_list) do					-- for each date-holding parameter in the list&lt;br /&gt;
		if not param_val:match (&#039;%d%d%d%d%-%d%d%-%d%d&#039;) then					-- for those that are not ymd dates&lt;br /&gt;
			param_val, n = param_val:gsub (&#039;%-&#039;, &#039;–&#039;);							-- replace any hyphen with ndash&lt;br /&gt;
			if 0 ~= n then&lt;br /&gt;
				date_parameters_list[param_name] = param_val;					-- update the list&lt;br /&gt;
				result = true;&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return result;																-- so we know if any hyphens were replaced&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; D A T E _ N A M E _ X L A T E &amp;gt;------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Attempts to translate English month names to local-language month names using names supplied by MediaWiki&#039;s&lt;br /&gt;
date parser function.  This is simple name-for-name replacement and may not work for all languages.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function	date_name_xlate (date_parameters_list)&lt;br /&gt;
	local xlate;&lt;br /&gt;
	local mode;																	-- long or short month names&lt;br /&gt;
	local modified = false;&lt;br /&gt;
	local date;&lt;br /&gt;
	&lt;br /&gt;
	for param_name, param_val in pairs(date_parameters_list) do					-- for each date-holding parameter in the list&lt;br /&gt;
		if is_set(param_val) then												-- if the parameter has a value&lt;br /&gt;
			date = param_val;&lt;br /&gt;
			for month in mw.ustring.gmatch (date, &#039;%a+&#039;) do						-- iterate through all dates in the date (single date or date range)&lt;br /&gt;
				if cfg.date_names.en.long[month] then&lt;br /&gt;
					mode = &#039;F&#039;;													-- English name is long so use long local name&lt;br /&gt;
				elseif cfg.date_names.en.short[month] then&lt;br /&gt;
					mode = &#039;M&#039;;													-- English name is short so use short local name&lt;br /&gt;
				else&lt;br /&gt;
					mode = nil;													-- not an English month name; could be local language month name or an English season name&lt;br /&gt;
				end&lt;br /&gt;
		&lt;br /&gt;
				if mode then															-- might be a season&lt;br /&gt;
					xlate = mw.getContentLanguage():formatDate(mode, &#039;1&#039; .. month);		-- translate the month name to this local language&lt;br /&gt;
					date = mw.ustring.gsub (date, month, xlate);						-- replace the English with the translation&lt;br /&gt;
					date_parameters_list[param_name] = date;							-- save the translated date&lt;br /&gt;
					modified = true;&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return modified;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E T _ S E L E C T E D _ M O D U L E S &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
Sets local imported functions table to same (live or sandbox) as that used by the other modules.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function set_selected_modules (cfg_table_ptr, utilities_page_ptr)&lt;br /&gt;
	is_set = utilities_page_ptr.is_set;											-- import functions from selected Module:Citation/CS1/Utilities module&lt;br /&gt;
	in_array = utilities_page_ptr.in_array;										-- import functions from selected Module:Citation/CS1/Utilities module&lt;br /&gt;
	cfg = cfg_table_ptr;														-- import tables from selected Module:Citation/CS1/Configuration&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
return {																		-- return exported functions&lt;br /&gt;
	dates = dates,&lt;br /&gt;
	year_date_check = year_date_check,&lt;br /&gt;
	reformat_dates = reformat_dates,&lt;br /&gt;
	date_hyphen_to_dash = date_hyphen_to_dash,&lt;br /&gt;
	date_name_xlate = date_name_xlate,&lt;br /&gt;
	set_selected_modules = set_selected_modules&lt;br /&gt;
	}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Configuration&amp;diff=1187</id>
		<title>Module:Citation/CS1/Configuration</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/Configuration&amp;diff=1187"/>
		<updated>2018-04-07T11:49:51Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;br /&gt;
local citation_config = {};&lt;br /&gt;
&lt;br /&gt;
-- override &amp;lt;code&amp;gt;...&amp;lt;/code&amp;gt; styling to remove color, border, and padding.  &amp;lt;code&amp;gt; css is specified here:&lt;br /&gt;
-- https://git.wikimedia.org/blob/mediawiki%2Fcore.git/69cd73811f7aadd093050dbf20ed70ef0b42a713/skins%2Fcommon%2FcommonElements.css#L199&lt;br /&gt;
local code_style=&amp;quot;color:inherit; border:inherit; padding:inherit;&amp;quot;;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; U N C A T E G O R I Z E D _ N A M E S P A C E S &amp;gt;------------------------------&lt;br /&gt;
&lt;br /&gt;
List of namespaces that should not be included in citation error categories.  Same as setting notracking = true by default&lt;br /&gt;
&lt;br /&gt;
Note: Namespace names should use underscores instead of spaces.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
local uncategorized_namespaces = { &#039;User&#039;, &#039;Talk&#039;, &#039;User_talk&#039;, &#039;Wikipedia_talk&#039;, &#039;File_talk&#039;, &#039;Template_talk&#039;,&lt;br /&gt;
	&#039;Help_talk&#039;, &#039;Category_talk&#039;, &#039;Portal_talk&#039;, &#039;Book_talk&#039;, &#039;Draft&#039;, &#039;Draft_talk&#039;, &#039;Education_Program_talk&#039;,&lt;br /&gt;
	&#039;Module_talk&#039;, &#039;MediaWiki_talk&#039; };&lt;br /&gt;
&lt;br /&gt;
local uncategorized_subpages = {&#039;/[Ss]andbox&#039;, &#039;/[Tt]estcases&#039;};		-- list of Lua patterns found in page names of pages we should not categorize&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; M E S S A G E S &amp;gt;--------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Translation table&lt;br /&gt;
&lt;br /&gt;
The following contains fixed text that may be output as part of a citation.&lt;br /&gt;
This is separated from the main body to aid in future translations of this&lt;br /&gt;
module.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local messages = {&lt;br /&gt;
	[&#039;archived-dead&#039;] = &#039;Archived from $1 on $2&#039;,&lt;br /&gt;
	[&#039;archived-not-dead&#039;] = &#039;$1 from the original on $2&#039;,&lt;br /&gt;
	[&#039;archived-missing&#039;] = &#039;Archived from the original$1 on $2&#039;,&lt;br /&gt;
	[&#039;archived&#039;] = &#039;Archived&#039;,&lt;br /&gt;
	[&#039;by&#039;] = &#039;By&#039;,																-- contributions to authored works: introduction, foreword, afterword&lt;br /&gt;
	[&#039;cartography&#039;] = &#039;Cartography by $1&#039;,&lt;br /&gt;
	[&#039;editor&#039;] = &#039;ed.&#039;,&lt;br /&gt;
	[&#039;editors&#039;] = &#039;eds.&#039;,&lt;br /&gt;
	[&#039;edition&#039;] = &#039;($1 ed.)&#039;,&lt;br /&gt;
	[&#039;episode&#039;] = &#039;Episode $1&#039;,&lt;br /&gt;
	[&#039;et al&#039;] = &#039;et al.&#039;,&lt;br /&gt;
	[&#039;in&#039;] = &#039;In&#039;,																-- edited works&lt;br /&gt;
	[&#039;inactive&#039;] = &#039;inactive&#039;,&lt;br /&gt;
	[&#039;inset&#039;] = &#039;$1 inset&#039;,&lt;br /&gt;
	[&#039;interview&#039;] = &#039;Interview with $1&#039;,										&lt;br /&gt;
	[&#039;lay summary&#039;] = &#039;Lay summary&#039;,&lt;br /&gt;
	[&#039;newsgroup&#039;] = &#039;[[Usenet newsgroup|Newsgroup]]:&amp;amp;nbsp;$1&#039;,&lt;br /&gt;
	[&#039;original&#039;] = &#039;the original&#039;,&lt;br /&gt;
	[&#039;published&#039;] = &#039; (published $1)&#039;,&lt;br /&gt;
	[&#039;retrieved&#039;] = &#039;Retrieved $1&#039;,&lt;br /&gt;
	[&#039;season&#039;] = &#039;Season $1&#039;,&lt;br /&gt;
	[&#039;section&#039;] = &#039;§ $1&#039;,&lt;br /&gt;
	[&#039;sections&#039;] = &#039;§§ $1&#039;,&lt;br /&gt;
	[&#039;series&#039;] = &#039;Series $1&#039;,&lt;br /&gt;
	[&#039;translated&#039;] = &#039;Translated by $1&#039;,&lt;br /&gt;
	[&#039;type&#039;] = &#039; ($1)&#039;,															-- for titletype&lt;br /&gt;
	[&#039;written&#039;] = &#039;Written at $1&#039;,&lt;br /&gt;
&lt;br /&gt;
	[&#039;vol&#039;] = &#039;$1 Vol.&amp;amp;nbsp;$2&#039;,												-- $1 is sepc; bold journal style volume is in presentation{}&lt;br /&gt;
	[&#039;vol-no&#039;] = &#039;$1 Vol.&amp;amp;nbsp;$2 no.&amp;amp;nbsp;$3&#039;,									-- sepc, volume, issue&lt;br /&gt;
	[&#039;issue&#039;] = &#039;$1 No.&amp;amp;nbsp;$2&#039;,												-- $1 is sepc&lt;br /&gt;
&lt;br /&gt;
	[&#039;j-vol&#039;] = &#039;$1 $2&#039;,														-- sepc, volume; bold journal volume is in presentation{}&lt;br /&gt;
	[&#039;j-issue&#039;] = &#039; ($1)&#039;,&lt;br /&gt;
&lt;br /&gt;
	[&#039;nopp&#039;] = &#039;$1 $2&#039;;															-- page(s) without prefix; $1 is sepc&lt;br /&gt;
&lt;br /&gt;
	[&#039;p-prefix&#039;] = &amp;quot;$1 p.&amp;amp;nbsp;$2&amp;quot;,												-- $1 is sepc&lt;br /&gt;
	[&#039;pp-prefix&#039;] = &amp;quot;$1 pp.&amp;amp;nbsp;$2&amp;quot;,											-- $1 is sepc&lt;br /&gt;
	[&#039;j-page(s)&#039;] = &#039;: $1&#039;,														-- same for page and pages&lt;br /&gt;
&lt;br /&gt;
	[&#039;sheet&#039;] = &#039;$1 Sheet&amp;amp;nbsp;$2&#039;,												-- $1 is sepc&lt;br /&gt;
	[&#039;sheets&#039;] = &#039;$1 Sheets&amp;amp;nbsp;$2&#039;,											-- $1 is sepc&lt;br /&gt;
	[&#039;j-sheet&#039;] = &#039;: Sheet&amp;amp;nbsp;$1&#039;,&lt;br /&gt;
	[&#039;j-sheets&#039;] = &#039;: Sheets&amp;amp;nbsp;$1&#039;,&lt;br /&gt;
	&lt;br /&gt;
	[&#039;subscription&#039;] = &#039;&amp;lt;span style=&amp;quot;font-size:90%; color:#555&amp;quot;&amp;gt;(Subscription required (&amp;lt;span title=&amp;quot;The site requires a paid subscription to access this page.&amp;quot; style=&amp;quot;border-bottom:1px dotted;cursor:help&amp;quot;&amp;gt;help&amp;lt;/span&amp;gt;))&amp;lt;/span&amp;gt;&#039; ..&lt;br /&gt;
		&#039;[[Category:Pages containing links to subscription-only content]]&#039;,&lt;br /&gt;
	&lt;br /&gt;
	[&#039;registration&#039;]=&#039;&amp;lt;span style=&amp;quot;font-size:90%; color:#555&amp;quot;&amp;gt;(Registration required (&amp;lt;span title=&amp;quot;The site requires registration to access this page.&amp;quot; style=&amp;quot;border-bottom:1px dotted;cursor:help&amp;quot;&amp;gt;help&amp;lt;/span&amp;gt;))&amp;lt;/span&amp;gt;&#039; ..&lt;br /&gt;
		&#039;[[Category:Pages with login required references or sources]]&#039;,&lt;br /&gt;
	&lt;br /&gt;
	[&#039;language&#039;] = &#039;(in $1)&#039;,&lt;br /&gt;
	[&#039;via&#039;] = &amp;quot; &amp;amp;ndash; via $1&amp;quot;,&lt;br /&gt;
	[&#039;event&#039;] = &#039;Event occurs at&#039;,&lt;br /&gt;
	[&#039;minutes&#039;] = &#039;minutes in&#039;,&lt;br /&gt;
	&lt;br /&gt;
	[&#039;parameter-separator&#039;] = &#039;, &#039;,&lt;br /&gt;
	[&#039;parameter-final-separator&#039;] = &#039;, and &#039;,&lt;br /&gt;
	[&#039;parameter-pair-separator&#039;] = &#039; and &#039;,&lt;br /&gt;
	&lt;br /&gt;
	-- Determines the location of the help page&lt;br /&gt;
	[&#039;help page link&#039;] = &#039;Help:CS1 errors&#039;,&lt;br /&gt;
	[&#039;help page label&#039;] = &#039;help&#039;,&lt;br /&gt;
	&lt;br /&gt;
	-- Internal errors (should only occur if configuration is bad)&lt;br /&gt;
	[&#039;undefined_error&#039;] = &#039;Called with an undefined error condition&#039;,&lt;br /&gt;
	[&#039;unknown_manual_ID&#039;] = &#039;Unrecognized manual ID mode&#039;,&lt;br /&gt;
	[&#039;unknown_ID_mode&#039;] = &#039;Unrecognized ID mode&#039;,&lt;br /&gt;
	[&#039;unknown_argument_map&#039;] = &#039;Argument map not defined for this variable&#039;,&lt;br /&gt;
	[&#039;bare_url_no_origin&#039;] = &#039;Bare url found but origin indicator is nil or empty&#039;,&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; P R E S E N T A T I O N &amp;gt;------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Fixed presentation markup.  Originally part of citation_config.messages it has been moved into its own, more semantically&lt;br /&gt;
correct place.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local presentation = &lt;br /&gt;
	{&lt;br /&gt;
	-- Error output&lt;br /&gt;
	-- .error class is specified at https://git.wikimedia.org/blob/mediawiki%2Fcore.git/9553bd02a5595da05c184f7521721fb1b79b3935/skins%2Fcommon%2Fshared.css#L538&lt;br /&gt;
	-- .citation-comment class is specified at Help:CS1_errors#Controlling_error_message_display&lt;br /&gt;
	[&#039;hidden-error&#039;] = &#039;&amp;lt;span style=&amp;quot;display:none;font-size:100%&amp;quot; class=&amp;quot;error citation-comment&amp;quot;&amp;gt;$1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
	[&#039;visible-error&#039;] = &#039;&amp;lt;span style=&amp;quot;font-size:100%&amp;quot; class=&amp;quot;error citation-comment&amp;quot;&amp;gt;$1&amp;lt;/span&amp;gt;&#039;,&lt;br /&gt;
&lt;br /&gt;
	[&#039;accessdate&#039;] = &#039;&amp;lt;span class=&amp;quot;reference-accessdate&amp;quot;&amp;gt;$1$2&amp;lt;/span&amp;gt;&#039;,			-- to allow editors to hide accessdate using personal css&lt;br /&gt;
&lt;br /&gt;
	[&#039;bdi&#039;] = &#039;&amp;lt;bdi$1&amp;gt;$2&amp;lt;/bdi&amp;gt;&#039;,												-- bidirectional isolation used with |script-title= and the like&lt;br /&gt;
&lt;br /&gt;
	[&#039;cite&#039;] = &#039;&amp;lt;cite class=&amp;quot;$1&amp;quot;&amp;gt;$2&amp;lt;/cite&amp;gt;&#039;;									-- |ref= not set so no id=&amp;quot;...&amp;quot; attribute&lt;br /&gt;
	[&#039;cite-id&#039;] = &#039;&amp;lt;cite id=&amp;quot;$1&amp;quot; class=&amp;quot;$2&amp;quot;&amp;gt;$3&amp;lt;/cite&amp;gt;&#039;;							-- for use when |ref= is set&lt;br /&gt;
&lt;br /&gt;
	[&#039;format&#039;] = &#039; &amp;lt;span style=&amp;quot;font-size:85%;&amp;quot;&amp;gt;($1)&amp;lt;/span&amp;gt;&#039;,					-- for |format=, |chapter-format=, etc&lt;br /&gt;
	&lt;br /&gt;
																				-- various access levels, for |access=, |doi-access=, |arxiv=, ...&lt;br /&gt;
																				-- narrow no-break space &amp;amp;#8239; may work better than nowrap css. Or not? browser support?&lt;br /&gt;
&lt;br /&gt;
	[&#039;access-signal&#039;] = &#039;&amp;lt;span class=&amp;quot;plainlinks&amp;quot;&amp;gt;$1&amp;amp;#8239;$2&amp;lt;/span&amp;gt;&#039;,			-- external link with appropriate lock icon&lt;br /&gt;
		[&#039;free&#039;] = &#039;[[File:Lock-green.svg|9px|link=|alt=Freely accessible|Freely accessible]]&#039;,&lt;br /&gt;
		[&#039;registration&#039;] = &#039;[[File:Lock-blue-alt-2.svg|9px|link=|alt=Free registration required|Free registration required]]&#039;,&lt;br /&gt;
		[&#039;limited&#039;] = &#039;[[File:Lock-blue-alt-2.svg|9px|link=|alt=Free access subject to limited trial, subscription normally required|Free access subject to limited trial, subscription normally required]]&#039;,&lt;br /&gt;
		[&#039;subscription&#039;] = &#039;[[File:Lock-red-alt.svg|9px|link=|alt=Paid subscription required|Paid subscription required]]&#039;,&lt;br /&gt;
&lt;br /&gt;
	[&#039;italic-title&#039;] = &amp;quot;&#039;&#039;$1&#039;&#039;&amp;quot;,&lt;br /&gt;
&lt;br /&gt;
	[&#039;kern-left&#039;] = &#039;&amp;lt;span style=&amp;quot;padding-left:0.2em;&amp;quot;&amp;gt;$1&amp;lt;/span&amp;gt;$2&#039;,			-- spacing to use when title contains leading single or double quote mark&lt;br /&gt;
	[&#039;kern-right&#039;] = &#039;$1&amp;lt;span style=&amp;quot;padding-right:0.2em;&amp;quot;&amp;gt;$2&amp;lt;/span&amp;gt;&#039;,			-- spacing to use when title contains trailing single or double quote mark&lt;br /&gt;
&lt;br /&gt;
																				-- these for simple wikilinked titles [[&amp;quot;text]], [[text&amp;quot;]] and [[&amp;quot;text&amp;quot;]]&lt;br /&gt;
																				-- span wraps entire wikilink&lt;br /&gt;
	[&#039;kern-wl-left&#039;] = &#039;&amp;lt;span style=&amp;quot;padding-left:0.2em;&amp;quot;&amp;gt;$1&amp;lt;/span&amp;gt;&#039;,			-- when title contains leading single or double quote mark&lt;br /&gt;
	[&#039;kern-wl-right&#039;] = &#039;&amp;lt;span style=&amp;quot;padding-right:0.2em;&amp;quot;&amp;gt;$1&amp;lt;/span&amp;gt;&#039;,			-- when title contains trailing single or double quote mark&lt;br /&gt;
	[&#039;kern-wl-both&#039;] = &#039;&amp;lt;span style=&amp;quot;padding-left:0.2em;padding-right:0.2em;&amp;quot;&amp;gt;$1&amp;lt;/span&amp;gt;&#039;,	-- when title contains leading and trailing single or double quote marks&lt;br /&gt;
&lt;br /&gt;
	[&#039;nowrap1&#039;] = &#039;&amp;lt;span class=&amp;quot;nowrap&amp;quot;&amp;gt;$1&amp;lt;/span&amp;gt;&#039;,								-- for nowrapping an item: &amp;lt;span ...&amp;gt;yyyy-mm-dd&amp;lt;/span&amp;gt;&lt;br /&gt;
	[&#039;nowrap2&#039;] = &#039;&amp;lt;span class=&amp;quot;nowrap&amp;quot;&amp;gt;$1&amp;lt;/span&amp;gt; $2&#039;,							-- for nowrapping portions of an item: &amp;lt;span ...&amp;gt;dd mmmm&amp;lt;/span&amp;gt; yyyy (note white space)&lt;br /&gt;
&lt;br /&gt;
	[&#039;ocins&#039;] = &#039;&amp;lt;span title=&amp;quot;$1&amp;quot; class=&amp;quot;Z3988&amp;quot;&amp;gt;&amp;lt;span style=&amp;quot;display:none;&amp;quot;&amp;gt;&amp;amp;nbsp;&amp;lt;/span&amp;gt;&amp;lt;/span&amp;gt;&#039;,		-- Note: Using display: none on the COinS span breaks some clients&lt;br /&gt;
&lt;br /&gt;
	[&#039;parameter&#039;] = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
&lt;br /&gt;
	[&#039;quoted-text&#039;] = &#039;&amp;lt;q&amp;gt;$1&amp;lt;/q&amp;gt;&#039;,												-- for wrapping |quote= content&lt;br /&gt;
	[&#039;quoted-title&#039;] = &#039;&amp;quot;$1&amp;quot;&#039;,&lt;br /&gt;
&lt;br /&gt;
	[&#039;trans-italic-title&#039;] = &amp;quot;&amp;amp;#91;&#039;&#039;$1&#039;&#039;&amp;amp;#93;&amp;quot;,&lt;br /&gt;
	[&#039;trans-quoted-title&#039;] = &amp;quot;&amp;amp;#91;$1&amp;amp;#93;&amp;quot;,&lt;br /&gt;
	[&#039;vol-bold&#039;] = &#039;$1 &amp;lt;b&amp;gt;$2&amp;lt;/b&amp;gt;&#039;,												-- sepc, volume; for bold journal cites; for other cites [&#039;vol&#039;] in messages{}&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
	&lt;br /&gt;
--[[--------------------------&amp;lt; A L I A S E S &amp;gt;----------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Aliases table for commonly passed parameters&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local aliases = {&lt;br /&gt;
	[&#039;AccessDate&#039;] = {&#039;access-date&#039;, &#039;accessdate&#039;},&lt;br /&gt;
	[&#039;Agency&#039;] = &#039;agency&#039;,&lt;br /&gt;
	[&#039;AirDate&#039;] = {&#039;air-date&#039;, &#039;airdate&#039;},&lt;br /&gt;
	[&#039;ArchiveDate&#039;] = {&#039;archive-date&#039;, &#039;archivedate&#039;},&lt;br /&gt;
	[&#039;ArchiveFormat&#039;] = &#039;archive-format&#039;,&lt;br /&gt;
	[&#039;ArchiveURL&#039;] = {&#039;archive-url&#039;, &#039;archiveurl&#039;},&lt;br /&gt;
	[&#039;ASINTLD&#039;] = {&#039;ASIN-TLD&#039;, &#039;asin-tld&#039;},&lt;br /&gt;
	[&#039;At&#039;] = &#039;at&#039;,&lt;br /&gt;
	[&#039;Authors&#039;] = {&#039;authors&#039;, &#039;people&#039;, &#039;host&#039;, &#039;credits&#039;},&lt;br /&gt;
	[&#039;BookTitle&#039;] = {&#039;book-title&#039;, &#039;booktitle&#039;},&lt;br /&gt;
	[&#039;Cartography&#039;] = &#039;cartography&#039;,&lt;br /&gt;
	[&#039;Chapter&#039;] = {&#039;chapter&#039;, &#039;contribution&#039;, &#039;entry&#039;, &#039;article&#039;, &#039;section&#039;},&lt;br /&gt;
	[&#039;ChapterFormat&#039;] = {&#039;chapter-format&#039;, &#039;contribution-format&#039;, &#039;section-format&#039;};&lt;br /&gt;
	[&#039;ChapterURL&#039;] = {&#039;chapter-url&#039;, &#039;chapterurl&#039;, &#039;contribution-url&#039;, &#039;contributionurl&#039;, &#039;section-url&#039;, &#039;sectionurl&#039;},&lt;br /&gt;
	[&#039;ChapterUrlAccess&#039;] = &#039;chapter-url-access&#039;,&lt;br /&gt;
	[&#039;Class&#039;] = &#039;class&#039;,														-- cite arxiv and arxiv identifiers&lt;br /&gt;
	[&#039;Collaboration&#039;] = &#039;collaboration&#039;,&lt;br /&gt;
	[&#039;Conference&#039;] = {&#039;conference&#039;, &#039;event&#039;},&lt;br /&gt;
	[&#039;ConferenceFormat&#039;] = {&#039;conference-format&#039;, &#039;event-format&#039;},&lt;br /&gt;
	[&#039;ConferenceURL&#039;] = {&#039;conference-url&#039;, &#039;conferenceurl&#039;, &#039;event-url&#039;, &#039;eventurl&#039;},&lt;br /&gt;
	[&#039;Contribution&#039;] = &#039;contribution&#039;,											-- introduction, foreword, afterword, etc; required when |contributor= set&lt;br /&gt;
	[&#039;Date&#039;] = &#039;date&#039;,&lt;br /&gt;
	[&#039;DeadURL&#039;] = {&#039;dead-url&#039;, &#039;deadurl&#039;},&lt;br /&gt;
	[&#039;Degree&#039;] = &#039;degree&#039;,&lt;br /&gt;
	[&#039;DF&#039;] = &#039;df&#039;,&lt;br /&gt;
	[&#039;DisplayAuthors&#039;] = {&#039;display-authors&#039;, &#039;displayauthors&#039;},&lt;br /&gt;
	[&#039;DisplayEditors&#039;] = {&#039;display-editors&#039;, &#039;displayeditors&#039;},&lt;br /&gt;
	[&#039;Docket&#039;] = &#039;docket&#039;,&lt;br /&gt;
	[&#039;DoiBroken&#039;] = {&#039;doi-broken&#039;, &#039;doi-broken-date&#039;, &#039;doi-inactive-date&#039;},&lt;br /&gt;
	[&#039;Edition&#039;] = &#039;edition&#039;,&lt;br /&gt;
	[&#039;Editors&#039;] = &#039;editors&#039;,&lt;br /&gt;
	[&#039;Embargo&#039;] = &#039;embargo&#039;,&lt;br /&gt;
	[&#039;Encyclopedia&#039;] = {&#039;encyclopedia&#039;, &#039;encyclopaedia&#039;},						-- this one only used by citation&lt;br /&gt;
	[&#039;Episode&#039;] = &#039;episode&#039;,													-- cite serial only TODO: make available to cite episode?&lt;br /&gt;
	[&#039;Format&#039;] = &#039;format&#039;,&lt;br /&gt;
	[&#039;ID&#039;] = {&#039;id&#039;, &#039;ID&#039;},&lt;br /&gt;
	[&#039;IgnoreISBN&#039;] = {&#039;ignore-isbn-error&#039;, &#039;ignoreisbnerror&#039;},&lt;br /&gt;
	[&#039;Inset&#039;] = &#039;inset&#039;,&lt;br /&gt;
	[&#039;Issue&#039;] = {&#039;issue&#039;, &#039;number&#039;},&lt;br /&gt;
	[&#039;Interviewers&#039;] = &#039;interviewers&#039;,&lt;br /&gt;
	[&#039;Language&#039;] = {&#039;language&#039;, &#039;in&#039;},&lt;br /&gt;
	[&#039;LastAuthorAmp&#039;] = {&#039;last-author-amp&#039;, &#039;lastauthoramp&#039;},&lt;br /&gt;
	[&#039;LayDate&#039;] = {&#039;lay-date&#039;, &#039;laydate&#039;},&lt;br /&gt;
	[&#039;LayFormat&#039;] = &#039;lay-format&#039;,&lt;br /&gt;
	[&#039;LaySource&#039;] = {&#039;lay-source&#039;, &#039;laysource&#039;},&lt;br /&gt;
	[&#039;LayURL&#039;] = {&#039;lay-url&#039;, &#039;lay-summary&#039;, &#039;layurl&#039;, &#039;laysummary&#039;},&lt;br /&gt;
	[&#039;MailingList&#039;] = {&#039;mailinglist&#039;, &#039;mailing-list&#039;},							-- cite mailing list only&lt;br /&gt;
	[&#039;Map&#039;] = &#039;map&#039;,															-- cite map only&lt;br /&gt;
	[&#039;MapFormat&#039;] = &#039;map-format&#039;,												-- cite map only&lt;br /&gt;
	[&#039;MapURL&#039;] = {&#039;mapurl&#039;, &#039;map-url&#039;},											-- cite map only&lt;br /&gt;
	[&#039;MessageID&#039;] = &#039;message-id&#039;,&lt;br /&gt;
	[&#039;Minutes&#039;] = &#039;minutes&#039;,&lt;br /&gt;
	[&#039;Mode&#039;] = &#039;mode&#039;,&lt;br /&gt;
	[&#039;NameListFormat&#039;] = &#039;name-list-format&#039;,&lt;br /&gt;
	[&#039;Network&#039;] = &#039;network&#039;,&lt;br /&gt;
	[&#039;NoPP&#039;] = {&#039;no-pp&#039;, &#039;nopp&#039;},&lt;br /&gt;
	[&#039;NoTracking&#039;] = {&#039;template-doc-demo&#039;, &#039;no-cat&#039;, &#039;nocat&#039;,&lt;br /&gt;
		&#039;no-tracking&#039;, &#039;notracking&#039;},&lt;br /&gt;
	[&#039;Number&#039;] = &#039;number&#039;,														-- this case only for cite techreport&lt;br /&gt;
	[&#039;OrigYear&#039;] = {&#039;orig-year&#039;, &#039;origyear&#039;},&lt;br /&gt;
	[&#039;Others&#039;] = &#039;others&#039;,&lt;br /&gt;
	[&#039;Page&#039;] = {&#039;p&#039;, &#039;page&#039;},&lt;br /&gt;
	[&#039;Pages&#039;] = {&#039;pp&#039;, &#039;pages&#039;},&lt;br /&gt;
	[&#039;Periodical&#039;] = {&#039;journal&#039;, &#039;newspaper&#039;, &#039;magazine&#039;, &#039;work&#039;,&lt;br /&gt;
		&#039;website&#039;,  &#039;periodical&#039;, &#039;encyclopedia&#039;, &#039;encyclopaedia&#039;, &#039;dictionary&#039;, &#039;mailinglist&#039;},&lt;br /&gt;
	[&#039;Place&#039;] = {&#039;place&#039;, &#039;location&#039;},&lt;br /&gt;
	[&#039;PostScript&#039;] = &#039;postscript&#039;,&lt;br /&gt;
	[&#039;PublicationDate&#039;] = {&#039;publicationdate&#039;, &#039;publication-date&#039;},&lt;br /&gt;
	[&#039;PublicationPlace&#039;] = {&#039;publication-place&#039;, &#039;publicationplace&#039;},&lt;br /&gt;
	[&#039;PublisherName&#039;] = {&#039;publisher&#039;, &#039;distributor&#039;, &#039;institution&#039;, &#039;newsgroup&#039;},&lt;br /&gt;
	[&#039;Quote&#039;] = {&#039;quote&#039;, &#039;quotation&#039;},&lt;br /&gt;
	[&#039;Ref&#039;] = &#039;ref&#039;,&lt;br /&gt;
	[&#039;RegistrationRequired&#039;] = &#039;registration&#039;,&lt;br /&gt;
	[&#039;Scale&#039;] = &#039;scale&#039;,&lt;br /&gt;
	[&#039;ScriptChapter&#039;] = &#039;script-chapter&#039;,&lt;br /&gt;
	[&#039;ScriptTitle&#039;] = &#039;script-title&#039;,&lt;br /&gt;
	[&#039;Section&#039;] = &#039;section&#039;,&lt;br /&gt;
	[&#039;Season&#039;] = &#039;season&#039;,&lt;br /&gt;
	[&#039;Sections&#039;] = &#039;sections&#039;,													-- cite map only&lt;br /&gt;
	[&#039;Series&#039;] = {&#039;series&#039;, &#039;version&#039;},&lt;br /&gt;
	[&#039;SeriesSeparator&#039;] = &#039;series-separator&#039;,&lt;br /&gt;
	[&#039;SeriesLink&#039;] = {&#039;series-link&#039;, &#039;serieslink&#039;},&lt;br /&gt;
	[&#039;SeriesNumber&#039;] = {&#039;series-number&#039;, &#039;series-no&#039;, &#039;seriesnumber&#039;, &#039;seriesno&#039;},&lt;br /&gt;
	[&#039;Sheet&#039;] = &#039;sheet&#039;,														-- cite map only&lt;br /&gt;
	[&#039;Sheets&#039;] = &#039;sheets&#039;,														-- cite map only&lt;br /&gt;
	[&#039;Station&#039;] = &#039;station&#039;,&lt;br /&gt;
	[&#039;SubscriptionRequired&#039;] = &#039;subscription&#039;,&lt;br /&gt;
	[&#039;Time&#039;] = &#039;time&#039;,&lt;br /&gt;
	[&#039;TimeCaption&#039;] = {&#039;time-caption&#039;, &#039;timecaption&#039;},&lt;br /&gt;
	[&#039;Title&#039;] = &#039;title&#039;,&lt;br /&gt;
	[&#039;TitleLink&#039;] = {&#039;title-link&#039;, &#039;episode-link&#039;, &#039;titlelink&#039;, &#039;episodelink&#039;},&lt;br /&gt;
	[&#039;TitleNote&#039;] = &#039;department&#039;,&lt;br /&gt;
	[&#039;TitleType&#039;] = {&#039;type&#039;, &#039;medium&#039;},&lt;br /&gt;
	[&#039;TransChapter&#039;] = &#039;trans-chapter&#039;,&lt;br /&gt;
	[&#039;TransMap&#039;] = &#039;trans-map&#039;,													-- cite map only&lt;br /&gt;
	[&#039;Transcript&#039;] = &#039;transcript&#039;,&lt;br /&gt;
	[&#039;TranscriptFormat&#039;] = &#039;transcript-format&#039;,&lt;br /&gt;
	[&#039;TranscriptURL&#039;] = {&#039;transcript-url&#039;, &#039;transcripturl&#039;},&lt;br /&gt;
	[&#039;TransTitle&#039;] = &#039;trans-title&#039;,&lt;br /&gt;
	[&#039;URL&#039;] = {&#039;url&#039;, &#039;URL&#039;},&lt;br /&gt;
	[&#039;UrlAccess&#039;] = {&#039;url-access&#039;},&lt;br /&gt;
	[&#039;Vauthors&#039;] = &#039;vauthors&#039;,&lt;br /&gt;
	[&#039;Veditors&#039;] = &#039;veditors&#039;,&lt;br /&gt;
	[&#039;Via&#039;] = &#039;via&#039;,&lt;br /&gt;
	[&#039;Volume&#039;] = &#039;volume&#039;,&lt;br /&gt;
	[&#039;Year&#039;] = &#039;year&#039;,&lt;br /&gt;
&lt;br /&gt;
	[&#039;AuthorList-First&#039;] = {&amp;quot;first#&amp;quot;, &amp;quot;given#&amp;quot;, &amp;quot;author-first#&amp;quot;, &amp;quot;author#-first&amp;quot;},&lt;br /&gt;
	[&#039;AuthorList-Last&#039;] = {&amp;quot;last#&amp;quot;, &amp;quot;author#&amp;quot;, &amp;quot;surname#&amp;quot;, &amp;quot;author-last#&amp;quot;, &amp;quot;author#-last&amp;quot;, &amp;quot;subject#&amp;quot;},&lt;br /&gt;
	[&#039;AuthorList-Link&#039;] = {&amp;quot;authorlink#&amp;quot;, &amp;quot;author-link#&amp;quot;, &amp;quot;author#-link&amp;quot;, &amp;quot;subjectlink#&amp;quot;, &amp;quot;author#link&amp;quot;, &amp;quot;subject-link#&amp;quot;, &amp;quot;subject#-link&amp;quot;, &amp;quot;subject#link&amp;quot;},&lt;br /&gt;
	[&#039;AuthorList-Mask&#039;] = {&amp;quot;author-mask#&amp;quot;, &amp;quot;authormask#&amp;quot;, &amp;quot;author#mask&amp;quot;, &amp;quot;author#-mask&amp;quot;},&lt;br /&gt;
	&lt;br /&gt;
	[&#039;ContributorList-First&#039;] = {&#039;contributor-first#&#039;, &#039;contributor#-first&#039;, &#039;contributor-given#&#039;, &#039;contributor#-given&#039;},&lt;br /&gt;
	[&#039;ContributorList-Last&#039;] = {&#039;contributor#&#039;, &#039;contributor-last#&#039;, &#039;contributor#-last&#039;, &#039;contributor-surname#&#039;, &#039;contributor#-surname&#039;},&lt;br /&gt;
	[&#039;ContributorList-Link&#039;] = {&#039;contributor-link#&#039;, &#039;contributor#-link&#039;},&lt;br /&gt;
	[&#039;ContributorList-Mask&#039;] = {&#039;contributor-mask#&#039;, &#039;contributor#-mask&#039;},&lt;br /&gt;
&lt;br /&gt;
	[&#039;EditorList-First&#039;] = {&amp;quot;editor-first#&amp;quot;, &amp;quot;editor#-first&amp;quot;, &amp;quot;editor-given#&amp;quot;, &amp;quot;editor#-given&amp;quot;},&lt;br /&gt;
	[&#039;EditorList-Last&#039;] = {&amp;quot;editor#&amp;quot;, &amp;quot;editor-last#&amp;quot;, &amp;quot;editor#-last&amp;quot;, &amp;quot;editor-surname#&amp;quot;, &amp;quot;editor#-surname&amp;quot;},&lt;br /&gt;
	[&#039;EditorList-Link&#039;] = {&amp;quot;editor-link#&amp;quot;, &amp;quot;editor#-link&amp;quot;, &amp;quot;editorlink#&amp;quot;, &amp;quot;editor#link&amp;quot;},&lt;br /&gt;
	[&#039;EditorList-Mask&#039;] = {&amp;quot;editor-mask#&amp;quot;, &amp;quot;editor#-mask&amp;quot;, &amp;quot;editormask#&amp;quot;, &amp;quot;editor#mask&amp;quot;},&lt;br /&gt;
	&lt;br /&gt;
	[&#039;InterviewerList-First&#039;] = {&#039;interviewer-first#&#039;, &#039;interviewer#-first&#039;},&lt;br /&gt;
	[&#039;InterviewerList-Last&#039;] = {&#039;interviewer#&#039;, &#039;interviewer-last#&#039;, &#039;interviewer#-last&#039;},&lt;br /&gt;
	[&#039;InterviewerList-Link&#039;] = {&#039;interviewer-link#&#039;, &#039;interviewer#-link&#039;},&lt;br /&gt;
	[&#039;InterviewerList-Mask&#039;] = {&#039;interviewer-mask#&#039;, &#039;interviewer#-mask&#039;},&lt;br /&gt;
&lt;br /&gt;
	[&#039;TranslatorList-First&#039;] = {&#039;translator-first#&#039;, &#039;translator#-first&#039;, &#039;translator-given#&#039;, &#039;translator#-given&#039;},&lt;br /&gt;
	[&#039;TranslatorList-Last&#039;] = {&#039;translator#&#039;, &#039;translator-last#&#039;, &#039;translator#-last&#039;, &#039;translator-surname#&#039;, &#039;translator#-surname&#039;},&lt;br /&gt;
	[&#039;TranslatorList-Link&#039;] = {&#039;translator-link#&#039;, &#039;translator#-link&#039;},&lt;br /&gt;
	[&#039;TranslatorList-Mask&#039;] = {&#039;translator-mask#&#039;, &#039;translator#-mask&#039;},&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S P E C I A L   C A S E   T R A N S L A T I O N S &amp;gt;----------------------------&lt;br /&gt;
&lt;br /&gt;
This table is primarily here to support internationalization.  Translations in this table are used, for example,&lt;br /&gt;
when an error message, category name, etc is extracted from the English alias key.  There may be other cases where&lt;br /&gt;
this translation table may be useful.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local special_case_translation = {&lt;br /&gt;
	[&#039;AuthorList&#039;] = &amp;quot;authors list&amp;quot;,											-- these for multiple names maint categories&lt;br /&gt;
	[&#039;ContributorList&#039;] = &amp;quot;contributors list&amp;quot;,&lt;br /&gt;
	[&#039;EditorList&#039;] = &amp;quot;editors list&amp;quot;,&lt;br /&gt;
	[&#039;InterviewerList&#039;] = &amp;quot;interviewers list&amp;quot;,&lt;br /&gt;
	[&#039;TranslatorList&#039;] = &amp;quot;translators list&amp;quot;,&lt;br /&gt;
	&lt;br /&gt;
	[&#039;authors&#039;] = &amp;quot;authors&amp;quot;,													-- used in get_display_authors_editors()&lt;br /&gt;
	[&#039;editors&#039;] = &amp;quot;editors&amp;quot;,&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; D E F A U L T S &amp;gt;--------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Default parameter values&lt;br /&gt;
&lt;br /&gt;
TODO: keep this?  Only one default?&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local defaults = {&lt;br /&gt;
	[&#039;DeadURL&#039;] = &#039;yes&#039;,&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; D A T E _ N A M E S &amp;gt;----------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
This table of tables lists local language date names and fallback English date names.  The code in Date_validation&lt;br /&gt;
will look first in the local table for valid date names.  If date names are not found in the local table, the code&lt;br /&gt;
will look in the English table.&lt;br /&gt;
&lt;br /&gt;
Because citations can be copied to the local wiki from en.wiki, the English is required when the date-name translation&lt;br /&gt;
function date_name_xlate() is used.&lt;br /&gt;
&lt;br /&gt;
In these tables, season numbering is defined by ISO DIS 8601:2016 part 2 §4.7 &#039;Divisions of a year&#039;.  The standard&lt;br /&gt;
defines various divisions using numbers 21-41.  cs1|2 only supports generic seasons.  ISO DIS 8601:2016 does support&lt;br /&gt;
the distinction between north and south hemispere seasons but cs1|2 has no way to make that distinction.&lt;br /&gt;
&lt;br /&gt;
The standard does not address &#039;named&#039; dates so, for the purposes of cs1|2, Christmas is defined here as 99, which&lt;br /&gt;
should be out of the ISO DIS 8601:2016 range of uses for a while.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local date_names = {&lt;br /&gt;
	[&#039;en&#039;] = {			-- English&lt;br /&gt;
		[&#039;long&#039;]	= {[&#039;January&#039;]=1, [&#039;February&#039;]=2, [&#039;March&#039;]=3, [&#039;April&#039;]=4, [&#039;May&#039;]=5, [&#039;June&#039;]=6, [&#039;July&#039;]=7, [&#039;August&#039;]=8, [&#039;September&#039;]=9, [&#039;October&#039;]=10, [&#039;November&#039;]=11, [&#039;December&#039;]=12};&lt;br /&gt;
		[&#039;short&#039;]	= {[&#039;Jan&#039;]=1, [&#039;Feb&#039;]=2, [&#039;Mar&#039;]=3, [&#039;Apr&#039;]=4, [&#039;May&#039;]=5, [&#039;Jun&#039;]=6, [&#039;Jul&#039;]=7, [&#039;Aug&#039;]=8, [&#039;Sep&#039;]=9, [&#039;Oct&#039;]=10, [&#039;Nov&#039;]=11, [&#039;Dec&#039;]=12};&lt;br /&gt;
		[&#039;season&#039;]	= {[&#039;Winter&#039;]=24, [&#039;Spring&#039;]=21, [&#039;Summer&#039;]=22, [&#039;Fall&#039;]=23, [&#039;Autumn&#039;]=23};&lt;br /&gt;
		[&#039;named&#039;]	= {[&#039;Christmas&#039;]=99};&lt;br /&gt;
		},&lt;br /&gt;
	[&#039;local&#039;] = {		-- replace these English date names with the local language equivalents&lt;br /&gt;
		[&#039;long&#039;]	= {[&#039;January&#039;]=1, [&#039;February&#039;]=2, [&#039;March&#039;]=3, [&#039;April&#039;]=4, [&#039;May&#039;]=5, [&#039;June&#039;]=6, [&#039;July&#039;]=7, [&#039;August&#039;]=8, [&#039;September&#039;]=9, [&#039;October&#039;]=10, [&#039;November&#039;]=11, [&#039;December&#039;]=12};&lt;br /&gt;
		[&#039;short&#039;]	= {[&#039;Jan&#039;]=1, [&#039;Feb&#039;]=2, [&#039;Mar&#039;]=3, [&#039;Apr&#039;]=4, [&#039;May&#039;]=5, [&#039;Jun&#039;]=6, [&#039;Jul&#039;]=7, [&#039;Aug&#039;]=8, [&#039;Sep&#039;]=9, [&#039;Oct&#039;]=10, [&#039;Nov&#039;]=11, [&#039;Dec&#039;]=12};&lt;br /&gt;
		[&#039;season&#039;]	= {[&#039;Winter&#039;]=24, [&#039;Spring&#039;]=21, [&#039;Summer&#039;]=22, [&#039;Fall&#039;]=23, [&#039;Autumn&#039;]=23};&lt;br /&gt;
		[&#039;named&#039;]	= {[&#039;Christmas&#039;]=99};&lt;br /&gt;
		},&lt;br /&gt;
	[&#039;local_digits&#039;] = {[&#039;0&#039;] = &#039;0&#039;, [&#039;1&#039;] = &#039;1&#039;, [&#039;2&#039;] = &#039;2&#039;, [&#039;3&#039;] = &#039;3&#039;, [&#039;4&#039;] = &#039;4&#039;, [&#039;5&#039;] = &#039;5&#039;, [&#039;6&#039;] = &#039;6&#039;, [&#039;7&#039;] = &#039;7&#039;, [&#039;8&#039;] = &#039;8&#039;, [&#039;9&#039;] = &#039;9&#039;};	-- used to convert local language digits to Western 0-9&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; V O L U M E ,  I S S U E ,  P A G E S &amp;gt;----------------------------------------&lt;br /&gt;
&lt;br /&gt;
These tables hold cite class values (from the template invocation) and identify those templates that support&lt;br /&gt;
|volume=, |issue=, and |page(s)= parameters.  Cite conference and cite map require further qualification which&lt;br /&gt;
is handled in the main module.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local templates_using_volume = {&#039;citation&#039;, &#039;audio-visual&#039;, &#039;book&#039;, &#039;conference&#039;, &#039;encyclopaedia&#039;, &#039;interview&#039;, &#039;journal&#039;, &#039;magazine&#039;, &#039;map&#039;, &#039;news&#039;, &#039;report&#039;, &#039;techreport&#039;, &#039;thesis&#039;}&lt;br /&gt;
local templates_using_issue = {&#039;citation&#039;, &#039;conference&#039;, &#039;episode&#039;, &#039;interview&#039;, &#039;journal&#039;, &#039;magazine&#039;, &#039;map&#039;, &#039;news&#039;}&lt;br /&gt;
local templates_not_using_page = {&#039;audio-visual&#039;, &#039;episode&#039;, &#039;mailinglist&#039;, &#039;newsgroup&#039;, &#039;podcast&#039;, &#039;serial&#039;, &#039;sign&#039;, &#039;speech&#039;}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; K E Y W O R D S &amp;gt;--------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
This table holds keywords for those parameters that have defined sets of acceptible keywords.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local keywords = {&lt;br /&gt;
	[&#039;yes_true_y&#039;] = {&#039;yes&#039;, &#039;true&#039;, &#039;y&#039;},										-- ignore-isbn-error, last-author-amp, no-tracking, nopp, registration, subscription&lt;br /&gt;
--	[&#039;deadurl&#039;] = {&#039;yes&#039;, &#039;true&#039;, &#039;y&#039;, &#039;no&#039;, &#039;unfit&#039;, &#039;usurped&#039;, &#039;unfit no archive&#039;, &#039;usurped no archive&#039;},		-- hidden 2016-04-10; see Help_talk:Citation_Style_1#Recycled_urls&lt;br /&gt;
	[&#039;deadurl&#039;] = {&#039;yes&#039;, &#039;true&#039;, &#039;y&#039;, &#039;no&#039;, &#039;unfit&#039;, &#039;usurped&#039;, &#039;bot: unknown&#039;},&lt;br /&gt;
	[&#039;mode&#039;] = {&#039;cs1&#039;, &#039;cs2&#039;, &#039;mla&#039;},&lt;br /&gt;
	[&#039;name-list-format&#039;] = {&#039;vanc&#039;},&lt;br /&gt;
	[&#039;contribution&#039;] = {&#039;afterword&#039;, &#039;foreword&#039;, &#039;introduction&#039;, &#039;preface&#039;},	-- generic contribution titles that are rendered unquoted in the &#039;chapter&#039; position&lt;br /&gt;
	[&#039;date-format&#039;] = {&#039;dmy&#039;, &#039;dmy-all&#039;, &#039;mdy&#039;, &#039;mdy-all&#039;, &#039;ymd&#039;, &#039;ymd-all&#039;},&lt;br /&gt;
	[&#039;url-access&#039;] = {&#039;subscription&#039;, &#039;limited&#039;, &#039;registration&#039;}, 	   -- access level of a URL (subscription required, limited access, free registration required), free to read by default&lt;br /&gt;
    [&#039;id-access&#039;] = {&#039;free&#039;},                                          -- access level of an identifier (free to read), subscription required (or no full text) by default&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S T R I P M A R K E R S &amp;gt;------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Common pattern definition location for stripmarkers so that we don&#039;t have to go hunting for them if (when)&lt;br /&gt;
MediaWiki changes their form.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local stripmarkers = {&lt;br /&gt;
	[&#039;any&#039;] = &#039;\127[^\127]*UNIQ%-%-(%a+)%-[%a%d]+%-QINU[^\127]*\127&#039;,			-- capture returns name of stripmarker&lt;br /&gt;
	[&#039;math&#039;] = &#039;\127[^\127]*UNIQ%-%-math%-[%a%d]+%-QINU[^\127]*\127&#039;			-- math stripmarkers used in coins_cleanup() and coins_replace_math_stripmarker()&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I N V I S I B L E _ C H A R A C T E R S &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
This table holds non-printing or invisible characters indexed either by name or by Unicode group. Values are decimal&lt;br /&gt;
representations of UTF-8 codes.  The table is organized as a table of tables because the lua pairs keyword returns&lt;br /&gt;
table data in an arbitrary order.  Here, we want to process the table from top to bottom because the entries at&lt;br /&gt;
the top of the table are also found in the ranges specified by the entries at the bottom of the table.&lt;br /&gt;
&lt;br /&gt;
This list contains patterns for templates like {{&#039;}} which isn&#039;t an error but transcludes characters that are&lt;br /&gt;
invisible.  These kinds of patterns must be recognized by the functions that use this list.&lt;br /&gt;
&lt;br /&gt;
Also here is a pattern that recognizes stripmarkers that begin and end with the delete characters.  The nowiki&lt;br /&gt;
stripmarker is not an error but some others are because the parameter values that include them become part of the&lt;br /&gt;
template&#039;s metadata before stripmarker replacement.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local invisible_chars = {&lt;br /&gt;
	{&#039;replacement&#039;, &#039;\239\191\189&#039;},											-- U+FFFD, EF BF BD&lt;br /&gt;
	{&#039;zero width joiner&#039;, &#039;\226\128\141&#039;},										-- U+200D, E2 80 8D&lt;br /&gt;
	{&#039;zero width space&#039;, &#039;\226\128\139&#039;},										-- U+200B, E2 80 8B&lt;br /&gt;
	{&#039;hair space&#039;, &#039;\226\128\138&#039;},												-- U+200A, E2 80 8A&lt;br /&gt;
	{&#039;soft hyphen&#039;, &#039;\194\173&#039;},												-- U+00AD, C2 AD&lt;br /&gt;
	{&#039;horizontal tab&#039;, &#039;\009&#039;},													-- U+0009 (HT), 09&lt;br /&gt;
	{&#039;line feed&#039;, &#039;\010&#039;},														-- U+000A (LF), 0A&lt;br /&gt;
	{&#039;carriage return&#039;, &#039;\013&#039;},												-- U+000D (CR), 0D&lt;br /&gt;
	{&#039;stripmarker&#039;, stripmarkers.any},											-- stripmarker; may or may not be an error; capture returns the stripmaker type&lt;br /&gt;
	{&#039;delete&#039;, &#039;\127&#039;},															-- U+007F (DEL), 7F; must be done after stripmarker test&lt;br /&gt;
	{&#039;C0 control&#039;, &#039;[\000-\008\011\012\014-\031]&#039;},								-- U+0000–U+001F (NULL–US), 00–1F (except HT, LF, CR (09, 0A, 0D))&lt;br /&gt;
	{&#039;C1 control&#039;, &#039;[\194\128-\194\159]&#039;},										-- U+0080–U+009F (XXX–APC), C2 80 – C2 9F&lt;br /&gt;
--	{&#039;Specials&#039;, &#039;[\239\191\185-\239\191\191]&#039;},								-- U+FFF9-U+FFFF, EF BF B9 – EF BF BF&lt;br /&gt;
--	{&#039;Private use area&#039;, &#039;[\238\128\128-\239\163\191]&#039;},						-- U+E000–U+F8FF, EE 80 80 – EF A3 BF&lt;br /&gt;
--	{&#039;Supplementary Private Use Area-A&#039;, &#039;[\243\176\128\128-\243\191\191\189]&#039;},	-- U+F0000–U+FFFFD, F3 B0 80 80 – F3 BF BF BD&lt;br /&gt;
--	{&#039;Supplementary Private Use Area-B&#039;, &#039;[\244\128\128\128-\244\143\191\189]&#039;},	-- U+100000–U+10FFFD, F4 80 80 80 – F4 8F BF BD&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-- Indic script makes use of zero width joiner as a character modifier so zwj characters must be left in.  This&lt;br /&gt;
-- pattern covers all of the unicode characters for these languages:&lt;br /&gt;
--	Devanagari					0900–097F – https://unicode.org/charts/PDF/U0900.pdf&lt;br /&gt;
--		Devanagari extended		A8E0–A8FF – https://unicode.org/charts/PDF/UA8E0.pdf&lt;br /&gt;
--	Bengali						0980–09FF – https://unicode.org/charts/PDF/U0980.pdf&lt;br /&gt;
--	Gurmukhi					0A00–0A7F – https://unicode.org/charts/PDF/U0A00.pdf&lt;br /&gt;
--	Gujarati					0A80–0AFF – https://unicode.org/charts/PDF/U0A80.pdf&lt;br /&gt;
--	Oriya						0B00–0B7F – https://unicode.org/charts/PDF/U0B00.pdf&lt;br /&gt;
--	Tamil						0B80–0BFF – https://unicode.org/charts/PDF/U0B80.pdf&lt;br /&gt;
--	Telugu						0C00–0C7F – https://unicode.org/charts/PDF/U0C00.pdf&lt;br /&gt;
--	Kannada						0C80–0CFF – https://unicode.org/charts/PDF/U0C80.pdf&lt;br /&gt;
--	Malayalam					0D00–0D7F – https://unicode.org/charts/PDF/U0D00.pdf&lt;br /&gt;
-- plus the not-necessarily Indic scripts for Sinhala and Burmese:&lt;br /&gt;
--  Sinhala						0D80-0DFF - https://unicode.org/charts/PDF/U0D80.pdf&lt;br /&gt;
--	Myanmar						1000-109F - https://unicode.org/charts/PDF/U1000.pdf&lt;br /&gt;
--		Myanmar extended A		AA60-AA7F - https://unicode.org/charts/PDF/UAA60.pdf&lt;br /&gt;
--		Myanmar extended B		A9E0-A9FF - https://unicode.org/charts/PDF/UA9E0.pdf&lt;br /&gt;
-- the pattern is used by has_invisible_chars() and coins_cleanup()&lt;br /&gt;
-- TODO: find a better place for this?&lt;br /&gt;
&lt;br /&gt;
local indic_script = &#039;[\224\164\128-\224\181\191\224\163\160-\224\183\191\225\128\128-\225\130\159\234\167\160-\234\167\191\234\169\160-\234\169\191]&#039;;&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; L A N G U A G E S &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
This table is used to hold ISO 639-1 two-character language codes that apply only to |script-title= and |script-chapter=&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local script_lang_codes = {&lt;br /&gt;
	&#039;am&#039;, &#039;ar&#039;, &#039;be&#039;, &#039;bg&#039;, &#039;bn&#039;, &#039;bs&#039;, &#039;dv&#039;, &#039;el&#039;, &#039;fa&#039;,						-- ISO 639-1 codes only for |script-title= and |script-chapter=&lt;br /&gt;
	&#039;gu&#039;, &#039;he&#039;, &#039;hy&#039;, &#039;ja&#039;, &#039;ka&#039;, &#039;kn&#039;, &#039;ko&#039;, &#039;ku&#039;,&lt;br /&gt;
	&#039;mk&#039;, &#039;ml&#039;, &#039;mn&#039;, &#039;mr&#039;, &#039;my&#039;, &#039;ps&#039;, &#039;ru&#039;, &#039;sd&#039;,&lt;br /&gt;
	&#039;sr&#039;, &#039;tg&#039;, &#039;th&#039;, &#039;uk&#039;, &#039;ug&#039;, &#039;ur&#039;, &#039;yi&#039;, &#039;zh&#039;&lt;br /&gt;
	};&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; M A I N T E N A N C E _ C A T E G O R I E S &amp;gt;----------------------------------&lt;br /&gt;
&lt;br /&gt;
Here we name maintenance categories to be used in maintenance messages.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local maint_cats = {&lt;br /&gt;
	[&#039;ASIN&#039;] = &#039;CS1 maint: ASIN uses ISBN&#039;,&lt;br /&gt;
	[&#039;authors&#039;] = &#039;CS1 maint: Uses authors parameter&#039;,&lt;br /&gt;
	[&#039;bot:_unknown&#039;] = &#039;CS1 maint: BOT: original-url status unknown&#039;,&lt;br /&gt;
	[&#039;date_format&#039;] = &#039;CS1 maint: Date format&#039;,&lt;br /&gt;
	[&#039;date_year&#039;] = &#039;CS1 maint: Date and year&#039;,&lt;br /&gt;
	[&#039;disp_auth_ed&#039;] = &#039;CS1 maint: display-$1&#039;,									-- $1 is authors or editors; gets value from special_case_translation table&lt;br /&gt;
	[&#039;editors&#039;] = &#039;CS1 maint: Uses editors parameter&#039;,&lt;br /&gt;
	[&#039;embargo&#039;] = &#039;CS1 maint: PMC embargo expired&#039;,&lt;br /&gt;
	[&#039;english&#039;] = &#039;CS1 maint: English language specified&#039;,&lt;br /&gt;
	[&#039;etal&#039;] = &#039;CS1 maint: Explicit use of et al.&#039;,&lt;br /&gt;
	[&#039;extra_text&#039;] = &#039;CS1 maint: Extra text&#039;,&lt;br /&gt;
	[&#039;extra_text_names&#039;] = &#039;CS1 maint: Extra text: $1&#039;,							-- $1 is &amp;lt;name&amp;gt;s list; gets value from special_case_translation table&lt;br /&gt;
	[&#039;ignore_isbn_err&#039;] = &#039;CS1 maint: Ignored ISBN errors&#039;,&lt;br /&gt;
	[&#039;interviewers&#039;] = &#039;CS1 maint: Uses interviewers parameter&#039;,&lt;br /&gt;
	[&#039;missing_pipe&#039;] = &#039;CS1 maint: Missing pipe&#039;,&lt;br /&gt;
	[&#039;mult_names&#039;] = &#039;CS1 maint: Multiple names: $1&#039;,							-- $1 is &amp;lt;name&amp;gt;s list; gets value from special_case_translation table&lt;br /&gt;
	[&#039;pmc_format&#039;] = &#039;CS1 maint: PMC format&#039;,&lt;br /&gt;
	[&#039;unfit&#039;] = &#039;CS1 maint: Unfit url&#039;,&lt;br /&gt;
	[&#039;unknown_lang&#039;] = &#039;CS1 maint: Unrecognized language&#039;,&lt;br /&gt;
	[&#039;untitled&#039;] = &#039;CS1 maint: Untitled periodical&#039;,&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; P R O P E R T I E S _ C A T E G O R I E S &amp;gt;------------------------------------&lt;br /&gt;
&lt;br /&gt;
Here we name properties categories&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local prop_cats = {&lt;br /&gt;
	[&#039;foreign_lang_source&#039;] = &#039;CS1 $1-language sources ($2)&#039;,					-- |language= categories; $1 is language name, $2 is ISO639-1 code&lt;br /&gt;
	[&#039;foreign_lang_source_2&#039;] = &#039;CS1 foreign language sources (ISO 639-2)|$1&#039;,	-- |language= category; a cat for ISO639-2 languages; $1 is the ISO 639-2 code&lt;br /&gt;
	[&#039;script&#039;] = &#039;CS1 uses foreign language script&#039;,							-- when language specified by |script-title=xx: doesn&#039;t have its own category&lt;br /&gt;
	[&#039;script_with_name&#039;] = &#039;CS1 uses $1-language script ($2)&#039;,					-- |script-title=xx: has matching category; $1 is language name, $2 is ISO639-1 code&lt;br /&gt;
	[&#039;jul_greg_uncertainty&#039;] = &#039;CS1: Julian–Gregorian uncertainty&#039;,				-- probably temporary cat to identify scope of template with dates 1 October 1582 – 1 January 1926&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; T I T L E _ T Y P E S &amp;gt;--------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Here we map a template&#039;s CitationClass to TitleType (default values for |type= parameter)&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local title_types = {&lt;br /&gt;
	[&#039;AV-media-notes&#039;] = &#039;Media notes&#039;,&lt;br /&gt;
	[&#039;interview&#039;] = &#039;Interview&#039;,&lt;br /&gt;
	[&#039;mailinglist&#039;] = &#039;Mailing list&#039;,&lt;br /&gt;
	[&#039;map&#039;] = &#039;Map&#039;,&lt;br /&gt;
	[&#039;podcast&#039;] = &#039;Podcast&#039;,&lt;br /&gt;
	[&#039;pressrelease&#039;] = &#039;Press release&#039;,&lt;br /&gt;
	[&#039;report&#039;] = &#039;Report&#039;,&lt;br /&gt;
	[&#039;techreport&#039;] = &#039;Technical report&#039;,&lt;br /&gt;
	[&#039;thesis&#039;] = &#039;Thesis&#039;,&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; E R R O R _ C O N D I T I O N S &amp;gt;----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Error condition table&lt;br /&gt;
&lt;br /&gt;
The following contains a list of IDs for various error conditions defined in the code.  For each ID, we specify a&lt;br /&gt;
text message to display, an error category to include, and whether the error message should be wrapped as a hidden comment.&lt;br /&gt;
&lt;br /&gt;
Anchor changes require identical changes to matching anchor in Help:CS1 errors&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local error_conditions = {&lt;br /&gt;
	accessdate_missing_url = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;access-date=&amp;lt;/code&amp;gt; requires &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;url=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;accessdate_missing_url&#039;,&lt;br /&gt;
		category = &#039;Pages using citations with accessdate and no URL&#039;,&lt;br /&gt;
		hidden = true },&lt;br /&gt;
	archive_missing_date = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;archive-url=&amp;lt;/code&amp;gt; requires &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;archive-date=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;archive_missing_date&#039;,&lt;br /&gt;
		category = &#039;Pages with archiveurl citation errors&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	archive_missing_url = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;archive-url=&amp;lt;/code&amp;gt; requires &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;url=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;archive_missing_url&#039;,&lt;br /&gt;
		category = &#039;Pages with archiveurl citation errors&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	archive_url = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;archive-url=&amp;lt;/code&amp;gt; is malformed: $1&#039;,&lt;br /&gt;
		anchor = &#039;archive_url&#039;,&lt;br /&gt;
		category = &#039;Pages with archiveurl citation errors&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	arxiv_missing = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;arxiv=&amp;lt;/code&amp;gt; required&#039;,&lt;br /&gt;
		anchor = &#039;arxiv_missing&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: arXiv&#039;,											-- same as bad arxiv&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	arxiv_params_not_supported = {&lt;br /&gt;
		message = &#039;Unsupported parameter(s) in cite arXiv&#039;,&lt;br /&gt;
		anchor = &#039;arxiv_params_not_supported&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: arXiv&#039;,											-- same as bad arxiv&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_arxiv = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;arxiv=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_arxiv&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: arXiv&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_asin = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;asin=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_asin&#039;,&lt;br /&gt;
		category =&#039;CS1 errors: ASIN&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_bibcode = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;bibcode=&amp;lt;/code&amp;gt; $1&#039;,&lt;br /&gt;
		anchor = &#039;bad_bibcode&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: bibcode&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_biorxiv = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;biorxiv=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_biorxiv&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: bioRxiv&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_citeseerx = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;citeseerx=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_citeseerx&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: citeseerx&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_date = {&lt;br /&gt;
		message = &#039;Check date values in: &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;$1&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;bad_date&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: dates&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_doi = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;doi=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_doi&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: DOI&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_hdl = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;hdl=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_hdl&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: HDL&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_isbn = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;isbn=&amp;lt;/code&amp;gt; value: $1&#039;,&lt;br /&gt;
		anchor = &#039;bad_isbn&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: ISBN&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_ismn = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;ismn=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_ismn&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: ISMN&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_issn = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1issn=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_issn&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: ISSN&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_jfm = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;jfm=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_jfm&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: JFM&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_lccn = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;lccn=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_lccn&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: LCCN&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_usenet_id = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;message-id=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_message_id&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: message-id&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_mr = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;mr=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_mr&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: MR&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_ol = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;ol=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_ol&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: OL&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_paramlink = {															-- for |title-link=, |author/editor/translator-link=, |series-link=, |episode-link=&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_paramlink&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: parameter link&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_pmc = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;pmc=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_pmc&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: PMC&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_pmid = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;pmid=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_pmid&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: PMID&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_oclc = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;oclc=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_oclc&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: OCLC&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_ssrn = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;ssrn=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_ssrn&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: SSRN&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_url = {&lt;br /&gt;
		message = &#039;Check $1 value&#039;,&lt;br /&gt;
		anchor = &#039;bad_url&#039;,&lt;br /&gt;
		category = &#039;Pages with URL errors&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bad_zbl = {&lt;br /&gt;
		message = &#039;Check &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;zbl=&amp;lt;/code&amp;gt; value&#039;,&lt;br /&gt;
		anchor = &#039;bad_zbl&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: ZBL&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	bare_url_missing_title = {&lt;br /&gt;
		message = &#039;$1 missing title&#039;,&lt;br /&gt;
		anchor = &#039;bare_url_missing_title&#039;,&lt;br /&gt;
		category = &#039;Pages with citations having bare URLs&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	biorxiv_missing = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;biorxiv=&amp;lt;/code&amp;gt; required&#039;,&lt;br /&gt;
		anchor = &#039;biorxiv_missing&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: bioRxiv&#039;,										-- same as bad bioRxiv&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	chapter_ignored = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt; ignored&#039;,&lt;br /&gt;
		anchor = &#039;chapter_ignored&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: chapter ignored&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	citation_missing_title = {&lt;br /&gt;
		message = &#039;Missing or empty &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;citation_missing_title&#039;,&lt;br /&gt;
		category = &#039;Pages with citations lacking titles&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	citeseerx_missing = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;citeseerx=&amp;lt;/code&amp;gt; required&#039;,&lt;br /&gt;
		anchor = &#039;citeseerx_missing&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: citeseerx&#039;,										-- same as bad citeseerx&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	cite_web_url = {															-- this error applies to cite web and to cite podcast&lt;br /&gt;
		message = &#039;Missing or empty &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;url=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;cite_web_url&#039;,&lt;br /&gt;
		category = &#039;Pages using web citations with no URL&#039;,&lt;br /&gt;
		hidden = true },&lt;br /&gt;
	contributor_ignored = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;contributor=&amp;lt;/code&amp;gt; ignored&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;contributor_ignored&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: contributor&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	contributor_missing_required_param = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;contributor=&amp;lt;/code&amp;gt; requires &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;contributor_missing_required_param&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: contributor&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	deprecated_params = {&lt;br /&gt;
		message = &#039;Cite uses deprecated parameter &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;deprecated_params&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: deprecated parameters&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	empty_citation = {&lt;br /&gt;
		message = &#039;Empty citation&#039;,&lt;br /&gt;
		anchor = &#039;empty_citation&#039;,&lt;br /&gt;
		category = &#039;Pages with empty citations&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	first_missing_last = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;first$2=&amp;lt;/code&amp;gt; missing &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;last$2=&amp;lt;/code&amp;gt; in $1&#039;,&lt;br /&gt;
		anchor = &#039;first_missing_last&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: missing author or editor&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	format_missing_url = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt; requires &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$2=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;format_missing_url&#039;,&lt;br /&gt;
		category = &#039;Pages using citations with format and no URL&#039;,&lt;br /&gt;
		hidden = true },&lt;br /&gt;
	invalid_param_val = {&lt;br /&gt;
		message = &#039;Invalid &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=$2&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;invalid_param_val&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: invalid parameter value&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	invisible_char = {&lt;br /&gt;
		message = &#039;$1 in $2 at position $3&#039;,&lt;br /&gt;
		anchor = &#039;invisible_char&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: invisible characters&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	missing_name = {&lt;br /&gt;
		message = &#039;Missing &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;last$2=&amp;lt;/code&amp;gt; in $1&#039;,&lt;br /&gt;
		anchor = &#039;missing_name&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: missing author or editor&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	param_access_requires_param = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1-access=&amp;lt;/code&amp;gt; requires &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;param_access_requires_param&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: param-access&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	param_has_ext_link = {&lt;br /&gt;
		message = &#039;External link in &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;$1&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;param_has_ext_link&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: external links&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	parameter_ignored = {&lt;br /&gt;
		message = &#039;Unknown parameter &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt; ignored&#039;,&lt;br /&gt;
		anchor = &#039;parameter_ignored&#039;,&lt;br /&gt;
		category = &#039;Pages with citations using unsupported parameters&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	parameter_ignored_suggest = {&lt;br /&gt;
		message = &#039;Unknown parameter &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt; ignored (&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$2=&amp;lt;/code&amp;gt; suggested)&#039;,&lt;br /&gt;
		anchor = &#039;parameter_ignored_suggest&#039;,&lt;br /&gt;
		category = &#039;Pages with citations using unsupported parameters&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	redundant_parameters = {&lt;br /&gt;
		message = &#039;More than one of $1 specified&#039;,&lt;br /&gt;
		anchor = &#039;redundant_parameters&#039;,&lt;br /&gt;
		category = &#039;Pages with citations having redundant parameters&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	text_ignored = {&lt;br /&gt;
		message = &#039;Text &amp;quot;$1&amp;quot; ignored&#039;,&lt;br /&gt;
		anchor = &#039;text_ignored&#039;,&lt;br /&gt;
		category = &#039;Pages with citations using unnamed parameters&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	trans_missing_title = {&lt;br /&gt;
		message = &#039;&amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;trans-$1=&amp;lt;/code&amp;gt; requires &amp;lt;code style=&amp;quot;&#039;..code_style..&#039;&amp;quot;&amp;gt;&amp;amp;#124;$1=&amp;lt;/code&amp;gt;&#039;,&lt;br /&gt;
		anchor = &#039;trans_missing_title&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: translated title&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	vancouver = {&lt;br /&gt;
		message = &#039;Vancouver style error: $1&#039;,&lt;br /&gt;
		anchor = &#039;vancouver&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: Vancouver style&#039;,&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	wikilink_in_url = {&lt;br /&gt;
		message = &#039;URL–wikilink conflict&#039;,										-- uses ndash&lt;br /&gt;
		anchor = &#039;wikilink_in_url&#039;,&lt;br /&gt;
		category = &#039;CS1 errors: URL–wikilink conflict&#039;,							-- uses ndash&lt;br /&gt;
		hidden = false },&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I D _ H A N D L E R S &amp;gt;--------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
The following contains a list of values for various defined identifiers.  For each identifier we specify a&lt;br /&gt;
variety of information necessary to properly render the identifier in the citation.&lt;br /&gt;
&lt;br /&gt;
	parameters: a list of parameter aliases for this identifier&lt;br /&gt;
	link: Wikipedia article name&lt;br /&gt;
	label: the alternate name to apply to link&lt;br /&gt;
	mode: 	&#039;manual&#039; when there is a specific function in the code to handle the identifier;&lt;br /&gt;
			&#039;external&#039; for identifiers that link outside of Wikipedia;&lt;br /&gt;
	prefix: the first part of a url that will be concatenated with a second part which usually contains the identifier&lt;br /&gt;
	encode: true if uri should be percent encoded; otherwise false&lt;br /&gt;
	COinS: identifier link or keyword for use in COinS:&lt;br /&gt;
		for identifiers registered at info-uri.info use: info:....&lt;br /&gt;
		for identifiers that have COinS keywords, use the keyword: rft.isbn, rft.issn, rft.eissn&lt;br /&gt;
		for others make a url using the value in prefix, use the keyword: pre (not checked; any text other than &#039;info&#039; or &#039;rft&#039; works here)&lt;br /&gt;
		set to nil to leave the identifier out of the COinS&lt;br /&gt;
	separator: character or text between label and the identifier in the rendered citation&lt;br /&gt;
	access: use this parameter to set the access level for all instances of this identifier.&lt;br /&gt;
			the value must be a valid access level for an identifier (see [&#039;id-access&#039;] in this file).&lt;br /&gt;
	custom_access: to enable custom access level for an identifier, set this parameter&lt;br /&gt;
			to the parameter that should control it (normally &#039;id-access&#039;)&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local id_handlers = {&lt;br /&gt;
	[&#039;ARXIV&#039;] = {&lt;br /&gt;
		parameters = {&#039;arxiv&#039;, &#039;eprint&#039;},&lt;br /&gt;
		link = &#039;arXiv&#039;,&lt;br /&gt;
		label = &#039;arXiv&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//arxiv.org/abs/&#039;, 											-- protocol relative tested 2013-09-04&lt;br /&gt;
		encode = false,&lt;br /&gt;
		COinS = &#039;info:arxiv&#039;,&lt;br /&gt;
		separator = &#039;:&#039;,&lt;br /&gt;
		access = &#039;free&#039;,														-- free to read&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ASIN&#039;] = {&lt;br /&gt;
		parameters = { &#039;asin&#039;, &#039;ASIN&#039; },&lt;br /&gt;
		link = &#039;Amazon Standard Identification Number&#039;,&lt;br /&gt;
		label = &#039;ASIN&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//www.amazon.&#039;,&lt;br /&gt;
		COinS = nil,															-- no COinS for this id (needs thinking on implementation because |asin-tld=)&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
		encode = false;&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;BIBCODE&#039;] = {&lt;br /&gt;
		parameters = {&#039;bibcode&#039;},&lt;br /&gt;
		link = &#039;Bibcode&#039;,&lt;br /&gt;
		label = &#039;Bibcode&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;http://adsabs.harvard.edu/abs/&#039;,&lt;br /&gt;
		encode = false,&lt;br /&gt;
		COinS = &#039;info:bibcode&#039;,&lt;br /&gt;
		separator = &#039;:&#039;,&lt;br /&gt;
		custom_access = &#039;bibcode-access&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;BIORXIV&#039;] = {&lt;br /&gt;
		parameters = {&#039;biorxiv&#039;},&lt;br /&gt;
		link = &#039;bioRxiv&#039;,&lt;br /&gt;
		label = &#039;bioRxiv&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//doi.org/10.1101/&#039;,&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		access = &#039;free&#039;,														-- free to read&lt;br /&gt;
		encode = true,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;CITESEERX&#039;] = {&lt;br /&gt;
		parameters = {&#039;citeseerx&#039;},&lt;br /&gt;
		link = &#039;CiteSeerX&#039;,&lt;br /&gt;
		label = &#039;CiteSeerX&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,														-- manual for custom validation of the &amp;quot;doi&amp;quot;&lt;br /&gt;
		prefix = &#039;//citeseerx.ist.psu.edu/viewdoc/summary?doi=&#039;,&lt;br /&gt;
		COinS =  &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		access = &#039;free&#039;,														-- free to read&lt;br /&gt;
		encode = true,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;DOI&#039;] = {&lt;br /&gt;
		parameters = { &#039;doi&#039;, &#039;DOI&#039; },&lt;br /&gt;
		link = &#039;Digital object identifier&#039;,&lt;br /&gt;
		label = &#039;doi&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//doi.org/&#039;,&lt;br /&gt;
		COinS = &#039;info:doi&#039;,&lt;br /&gt;
		separator = &#039;:&#039;,&lt;br /&gt;
		encode = true,&lt;br /&gt;
		custom_access = &#039;doi-access&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;EISSN&#039;] = {&lt;br /&gt;
		parameters = {&#039;eissn&#039;, &#039;EISSN&#039;},&lt;br /&gt;
		link = &#039;International_Standard_Serial_Number#Electronic_ISSN&#039;,&lt;br /&gt;
		label = &#039;eISSN&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//www.worldcat.org/issn/&#039;,&lt;br /&gt;
		COinS = &#039;rft.eissn&#039;,&lt;br /&gt;
		encode = false,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;HDL&#039;] = {&lt;br /&gt;
		parameters = { &#039;hdl&#039;, &#039;HDL&#039; },&lt;br /&gt;
		link = &#039;Handle System&#039;,&lt;br /&gt;
		label = &#039;hdl&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//hdl.handle.net/&#039;,&lt;br /&gt;
		COinS = &#039;info:hdl&#039;,&lt;br /&gt;
		separator = &#039;:&#039;,&lt;br /&gt;
		encode = true,&lt;br /&gt;
		custom_access = &#039;hdl-access&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ISBN&#039;] = {&lt;br /&gt;
		parameters = {&#039;isbn&#039;, &#039;ISBN&#039;, &#039;isbn13&#039;, &#039;ISBN13&#039;},&lt;br /&gt;
		link = &#039;International Standard Book Number&#039;,&lt;br /&gt;
		label = &#039;ISBN&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;Special:BookSources/&#039;,&lt;br /&gt;
		COinS = &#039;rft.isbn&#039;,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ISMN&#039;] = {&lt;br /&gt;
		parameters = {&#039;ismn&#039;, &#039;ISMN&#039;},&lt;br /&gt;
		link = &#039;International Standard Music Number&#039;,&lt;br /&gt;
		label = &#039;ISMN&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;&#039;,															-- not currently used;&lt;br /&gt;
		COinS = &#039;nil&#039;,															-- nil because we can&#039;t use pre or rft or info:&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ISSN&#039;] = {&lt;br /&gt;
		parameters = {&#039;issn&#039;, &#039;ISSN&#039;},&lt;br /&gt;
		link = &#039;International Standard Serial Number&#039;,&lt;br /&gt;
		label = &#039;ISSN&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//www.worldcat.org/issn/&#039;,&lt;br /&gt;
		COinS = &#039;rft.issn&#039;,&lt;br /&gt;
		encode = false,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;JFM&#039;] = {&lt;br /&gt;
		parameters = {&#039;jfm&#039;, &#039;JFM&#039;},&lt;br /&gt;
		link = &#039;Jahrbuch über die Fortschritte der Mathematik&#039;,&lt;br /&gt;
		label = &#039;JFM&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//zbmath.org/?format=complete&amp;amp;q=an:&#039;,&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		encode = true,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;JSTOR&#039;] = {&lt;br /&gt;
		parameters = {&#039;jstor&#039;, &#039;JSTOR&#039;},&lt;br /&gt;
		link = &#039;JSTOR&#039;,&lt;br /&gt;
		label = &#039;JSTOR&#039;,&lt;br /&gt;
		mode = &#039;external&#039;,&lt;br /&gt;
		prefix = &#039;//www.jstor.org/stable/&#039;, 									-- protocol relative tested 2013-09-04&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		encode = false,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
		custom_access = &#039;jstor-access&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;LCCN&#039;] = {&lt;br /&gt;
		parameters = {&#039;LCCN&#039;, &#039;lccn&#039;},&lt;br /&gt;
		link = &#039;Library of Congress Control Number&#039;,&lt;br /&gt;
		label = &#039;LCCN&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//lccn.loc.gov/&#039;, 											-- protocol relative tested 2015-12-28&lt;br /&gt;
		COinS = &#039;info:lccn&#039;,													-- use prefix value&lt;br /&gt;
		encode = false,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;MR&#039;] = {&lt;br /&gt;
		parameters = {&#039;MR&#039;, &#039;mr&#039;},&lt;br /&gt;
		link = &#039;Mathematical Reviews&#039;,&lt;br /&gt;
		label = &#039;MR&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//www.ams.org/mathscinet-getitem?mr=&#039;, 						-- protocol relative tested 2013-09-04&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		encode = true,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;OCLC&#039;] = {&lt;br /&gt;
		parameters = {&#039;OCLC&#039;, &#039;oclc&#039;},&lt;br /&gt;
		link = &#039;OCLC&#039;,&lt;br /&gt;
		label = &#039;OCLC&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//www.worldcat.org/oclc/&#039;,&lt;br /&gt;
		COinS = &#039;info:oclcnum&#039;,&lt;br /&gt;
		encode = true,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;OL&#039;] = {&lt;br /&gt;
		parameters = { &#039;ol&#039;, &#039;OL&#039; },&lt;br /&gt;
		link = &#039;Open Library&#039;,&lt;br /&gt;
		label = &#039;OL&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//openlibrary.org/&#039;,&lt;br /&gt;
		COinS = nil,															-- no COinS for this id (needs thinking on implementation because /authors/books/works/OL)&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
		encode = true,&lt;br /&gt;
		custom_access = &#039;ol-access&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;OSTI&#039;] = {&lt;br /&gt;
		parameters = {&#039;OSTI&#039;, &#039;osti&#039;},&lt;br /&gt;
		link = &#039;Office of Scientific and Technical Information&#039;,&lt;br /&gt;
		label = &#039;OSTI&#039;,&lt;br /&gt;
		mode = &#039;external&#039;,&lt;br /&gt;
		prefix = &#039;//www.osti.gov/energycitations/product.biblio.jsp?osti_id=&#039;,	-- protocol relative tested 2013-09-04&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		encode = true,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
		custom_access = &#039;osti-access&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;PMC&#039;] = {&lt;br /&gt;
		parameters = {&#039;PMC&#039;, &#039;pmc&#039;},&lt;br /&gt;
		link = &#039;PubMed Central&#039;,&lt;br /&gt;
		label = &#039;PMC&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//www.ncbi.nlm.nih.gov/pmc/articles/PMC&#039;,&lt;br /&gt;
		suffix = &amp;quot; &amp;quot;,&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		encode = true,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
		access = &#039;free&#039;,														-- free to read&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;PMID&#039;] = {&lt;br /&gt;
		parameters = {&#039;PMID&#039;, &#039;pmid&#039;},&lt;br /&gt;
		link = &#039;PubMed Identifier&#039;,&lt;br /&gt;
		label = &#039;PMID&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//www.ncbi.nlm.nih.gov/pubmed/&#039;,&lt;br /&gt;
		COinS = &#039;info:pmid&#039;,&lt;br /&gt;
		encode = false,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;RFC&#039;] = {&lt;br /&gt;
		parameters = {&#039;RFC&#039;, &#039;rfc&#039;},&lt;br /&gt;
		link = &#039;Request for Comments&#039;,&lt;br /&gt;
		label = &#039;RFC&#039;,&lt;br /&gt;
		mode = &#039;external&#039;,&lt;br /&gt;
		prefix = &#039;//tools.ietf.org/html/rfc&#039;,&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		encode = false,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
		access = &#039;free&#039;,														-- free to read&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;SSRN&#039;] = {&lt;br /&gt;
		parameters = {&#039;SSRN&#039;, &#039;ssrn&#039;},&lt;br /&gt;
		link = &#039;Social Science Research Network&#039;,&lt;br /&gt;
		label = &#039;SSRN&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//ssrn.com/abstract=&#039;, 										-- protocol relative tested 2013-09-04&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		encode = true,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
		access = &#039;free&#039;,														-- always free to read&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;USENETID&#039;] = {&lt;br /&gt;
		parameters = {&#039;message-id&#039;},&lt;br /&gt;
		link = &#039;Usenet&#039;,&lt;br /&gt;
		label = &#039;Usenet:&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;news:&#039;,&lt;br /&gt;
		encode = false,&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	[&#039;ZBL&#039;] = {&lt;br /&gt;
		parameters = {&#039;ZBL&#039;, &#039;zbl&#039;},&lt;br /&gt;
		link = &#039;Zentralblatt MATH&#039;,&lt;br /&gt;
		label = &#039;Zbl&#039;,&lt;br /&gt;
		mode = &#039;manual&#039;,&lt;br /&gt;
		prefix = &#039;//zbmath.org/?format=complete&amp;amp;q=an:&#039;,&lt;br /&gt;
		COinS = &#039;pre&#039;,															-- use prefix value&lt;br /&gt;
		encode = true,&lt;br /&gt;
		separator = &#039;&amp;amp;nbsp;&#039;,&lt;br /&gt;
	},&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
return 	{&lt;br /&gt;
	aliases = aliases,&lt;br /&gt;
	special_case_translation = special_case_translation,&lt;br /&gt;
	defaults = defaults,&lt;br /&gt;
	date_names = date_names,&lt;br /&gt;
	error_conditions = error_conditions,&lt;br /&gt;
	id_handlers = id_handlers,&lt;br /&gt;
	keywords = keywords,&lt;br /&gt;
	stripmarkers=stripmarkers,&lt;br /&gt;
	invisible_chars = invisible_chars,&lt;br /&gt;
	indic_script = indic_script,&lt;br /&gt;
	maint_cats = maint_cats,&lt;br /&gt;
	messages = messages,&lt;br /&gt;
	presentation = presentation,&lt;br /&gt;
	prop_cats = prop_cats,&lt;br /&gt;
	script_lang_codes = script_lang_codes,&lt;br /&gt;
	title_types = title_types,&lt;br /&gt;
	uncategorized_namespaces = uncategorized_namespaces,&lt;br /&gt;
	uncategorized_subpages = uncategorized_subpages,&lt;br /&gt;
	templates_using_volume = templates_using_volume,&lt;br /&gt;
	templates_using_issue = templates_using_issue,&lt;br /&gt;
	templates_not_using_page = templates_not_using_page,&lt;br /&gt;
	}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/COinS&amp;diff=1185</id>
		<title>Module:Citation/CS1/COinS</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1/COinS&amp;diff=1185"/>
		<updated>2018-04-07T11:49:50Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;br /&gt;
local coins = {};&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; F O R W A R D   D E C L A R A T I O N S &amp;gt;--------------------------------------&lt;br /&gt;
]]&lt;br /&gt;
local is_set, in_array, remove_wiki_link;										-- functions in Module:Citation/CS1/Utilities&lt;br /&gt;
&lt;br /&gt;
local cfg;																		-- table of configuration tables that are defined in Module:Citation/CS1/Configuration&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S T R I P _ A P O S T R O P H E _ M A R K U P &amp;gt;--------------------------------&lt;br /&gt;
&lt;br /&gt;
Strip wiki italic and bold markup from argument so that it doesn&#039;t contaminate COinS metadata.&lt;br /&gt;
This function strips common patterns of apostrophe markup.  We presume that editors who have taken the time to&lt;br /&gt;
markup a title have, as a result, provided valid markup. When they don&#039;t, some single apostrophes are left behind.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function strip_apostrophe_markup (argument)&lt;br /&gt;
	if not is_set (argument) then return argument; end&lt;br /&gt;
&lt;br /&gt;
	if argument:find ( &amp;quot;&#039;&#039;&amp;quot;, 1, true ) == nil then								-- Is there at least one double apostrophe?  If not, exit.&lt;br /&gt;
		return argument;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	while true do&lt;br /&gt;
		if argument:find ( &amp;quot;&#039;&#039;&#039;&#039;&#039;&amp;quot;, 1, true ) then								-- bold italic (5)&lt;br /&gt;
			argument=argument:gsub(&amp;quot;%&#039;%&#039;%&#039;%&#039;%&#039;&amp;quot;, &amp;quot;&amp;quot;);							-- remove all instances of it&lt;br /&gt;
		elseif argument:find ( &amp;quot;&#039;&#039;&#039;&#039;&amp;quot;, 1, true ) then							-- italic start and end without content (4)&lt;br /&gt;
			argument=argument:gsub(&amp;quot;%&#039;%&#039;%&#039;%&#039;&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
		elseif argument:find ( &amp;quot;&#039;&#039;&#039;&amp;quot;, 1, true ) then							-- bold (3)&lt;br /&gt;
			argument=argument:gsub(&amp;quot;%&#039;%&#039;%&#039;&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
		elseif argument:find ( &amp;quot;&#039;&#039;&amp;quot;, 1, true ) then								-- italic (2)&lt;br /&gt;
			argument=argument:gsub(&amp;quot;%&#039;%&#039;&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
		else&lt;br /&gt;
			break;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return argument;															-- done&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; M A K E _ C O I N S _ T I T L E &amp;gt;----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Makes a title for COinS from Title and / or ScriptTitle (or any other name-script pairs)&lt;br /&gt;
&lt;br /&gt;
Apostrophe markup (bold, italics) is stripped from each value so that the COinS metadata isn&#039;t corrupted with strings&lt;br /&gt;
of %27%27...&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function make_coins_title (title, script)&lt;br /&gt;
	if is_set (title) then&lt;br /&gt;
		title = strip_apostrophe_markup (title);								-- strip any apostrophe markup&lt;br /&gt;
	else&lt;br /&gt;
		title=&#039;&#039;;																-- if not set, make sure title is an empty string&lt;br /&gt;
	end&lt;br /&gt;
	if is_set (script) then&lt;br /&gt;
		script = script:gsub (&#039;^%l%l%s*:%s*&#039;, &#039;&#039;);								-- remove language prefix if present (script value may now be empty string)&lt;br /&gt;
		script = strip_apostrophe_markup (script);								-- strip any apostrophe markup&lt;br /&gt;
	else&lt;br /&gt;
		script=&#039;&#039;;																-- if not set, make sure script is an empty string&lt;br /&gt;
	end&lt;br /&gt;
	if is_set (title) and is_set (script) then&lt;br /&gt;
		script = &#039; &#039; .. script;													-- add a space before we concatenate&lt;br /&gt;
	end&lt;br /&gt;
	return title .. script;														-- return the concatenation&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; E S C A P E _ L U A _ M A G I C _ C H A R S &amp;gt;----------------------------------&lt;br /&gt;
&lt;br /&gt;
Returns a string where all of lua&#039;s magic characters have been escaped.  This is important because functions like&lt;br /&gt;
string.gsub() treat their pattern and replace strings as patterns, not literal strings.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function escape_lua_magic_chars (argument)&lt;br /&gt;
	argument = argument:gsub(&amp;quot;%%&amp;quot;, &amp;quot;%%%%&amp;quot;);										-- replace % with %%&lt;br /&gt;
	argument = argument:gsub(&amp;quot;([%^%$%(%)%.%[%]%*%+%-%?])&amp;quot;, &amp;quot;%%%1&amp;quot;);				-- replace all other lua magic pattern characters&lt;br /&gt;
	return argument;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; G E T _ C O I N S _ P A G E S &amp;gt;------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Extract page numbers from external wikilinks in any of the |page=, |pages=, or |at= parameters for use in COinS.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function get_coins_pages (pages)&lt;br /&gt;
	local pattern;&lt;br /&gt;
	if not is_set (pages) then return pages; end								-- if no page numbers then we&#039;re done&lt;br /&gt;
	&lt;br /&gt;
	while true do&lt;br /&gt;
		pattern = pages:match(&amp;quot;%[(%w*:?//[^ ]+%s+)[%w%d].*%]&amp;quot;);					-- pattern is the opening bracket, the url and following space(s): &amp;quot;[url &amp;quot;&lt;br /&gt;
		if nil == pattern then break; end										-- no more urls&lt;br /&gt;
		pattern = escape_lua_magic_chars (pattern);								-- pattern is not a literal string; escape lua&#039;s magic pattern characters&lt;br /&gt;
		pages = pages:gsub(pattern, &amp;quot;&amp;quot;);										-- remove as many instances of pattern as possible&lt;br /&gt;
	end&lt;br /&gt;
	pages = pages:gsub(&amp;quot;[%[%]]&amp;quot;, &amp;quot;&amp;quot;);											-- remove the brackets&lt;br /&gt;
	pages = pages:gsub(&amp;quot;–&amp;quot;, &amp;quot;-&amp;quot; );							-- replace endashes with hyphens&lt;br /&gt;
	pages = pages:gsub(&amp;quot;&amp;amp;%w+;&amp;quot;, &amp;quot;-&amp;quot; );						-- and replace html entities (&amp;amp;ndash; etc.) with hyphens; do we need to replace numerical entities like &amp;amp;#32; and the like?&lt;br /&gt;
	return pages;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; C O I N S _ R E P L A C E _ M A T H _ S T R I P M A R K E R &amp;gt;------------------&lt;br /&gt;
&lt;br /&gt;
There are three options for math markup rendering that depend on the editor&#039;s math preference settings.  These&lt;br /&gt;
settings are at [[Special:Preferences#mw-prefsection-rendering]] and are&lt;br /&gt;
	PNG images&lt;br /&gt;
	TeX source&lt;br /&gt;
	MathML with SVG or PNG fallback&lt;br /&gt;
&lt;br /&gt;
All three are heavy with html and css which doesn&#039;t belong in the metadata.&lt;br /&gt;
&lt;br /&gt;
Without this function, the metadata saved in the raw wikitext contained the rendering determined by the settings&lt;br /&gt;
of the last editor to save the page.&lt;br /&gt;
&lt;br /&gt;
This function gets the rendered form of an equation according to the editor&#039;s preference before the page is saved.  It&lt;br /&gt;
then searches the rendering for the text equivalent of the rendered equation and replaces the rendering with that so&lt;br /&gt;
that the page is saved without extraneous html/css markup and with a reasonably readable text form of the equation.&lt;br /&gt;
&lt;br /&gt;
When a replacement is made, this function returns true and the value with replacement; otherwise false and the intital&lt;br /&gt;
value.  To replace multipe equations it is necesary to call this function from within a loop.&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function coins_replace_math_stripmarker (value)&lt;br /&gt;
	local stripmarker = cfg.stripmarkers[&#039;math&#039;];&lt;br /&gt;
	local rendering = value:match (stripmarker);								-- is there a math stripmarker&lt;br /&gt;
&lt;br /&gt;
	if not rendering then														-- when value doesn&#039;t have a math stripmarker, abandon this test&lt;br /&gt;
		return false, value;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	rendering = mw.text.unstripNoWiki (rendering);								-- convert stripmarker into rendered value (or nil? &#039;&#039;? when math render error)&lt;br /&gt;
	&lt;br /&gt;
	if rendering:match (&#039;alt=&amp;quot;[^&amp;quot;]+&amp;quot;&#039;) then										-- if PNG math option&lt;br /&gt;
		rendering = rendering:match (&#039;alt=&amp;quot;([^&amp;quot;]+)&amp;quot;&#039;);							-- extract just the math text&lt;br /&gt;
	elseif rendering:match (&#039;$%s+.+%s+%$&#039;) then									-- if TeX math option; $ is legit character that is escapes as \$&lt;br /&gt;
		rendering = rendering:match (&#039;$%s+(.+)%s+%$&#039;)							-- extract just the math text&lt;br /&gt;
	elseif rendering:match (&#039;&amp;lt;annotation[^&amp;gt;]+&amp;gt;.+&amp;lt;/annotation&amp;gt;&#039;) then			-- if MathML math option&lt;br /&gt;
		rendering = rendering:match (&#039;&amp;lt;annotation[^&amp;gt;]+&amp;gt;(.+)&amp;lt;/annotation&amp;gt;&#039;)		-- extract just the math text&lt;br /&gt;
	else&lt;br /&gt;
		return false, value;													-- had math stripmarker but not one of the three defined forms&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return true, value:gsub (stripmarker, rendering, 1);&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C O I N S _ C L E A N U P &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Cleanup parameter values for the metadata by removing or replacing invisible characters and certain html entities.&lt;br /&gt;
&lt;br /&gt;
2015-12-10: there is a bug in mw.text.unstripNoWiki ().  It replaces math stripmarkers with the appropriate content&lt;br /&gt;
when it shouldn&#039;t.  See https://phabricator.wikimedia.org/T121085 and Wikipedia_talk:Lua#stripmarkers_and_mw.text.unstripNoWiki.28.29&lt;br /&gt;
&lt;br /&gt;
TODO: move the replacement patterns and replacement values into a table in /Configuration similar to the invisible&lt;br /&gt;
characters table?&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function coins_cleanup (value)&lt;br /&gt;
	local replaced = true;														-- default state to get the do loop running&lt;br /&gt;
&lt;br /&gt;
	while replaced do															-- loop until all math stripmarkers replaced&lt;br /&gt;
		replaced, value = coins_replace_math_stripmarker (value);				-- replace math stripmarker with text representation of the equation&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	value = value:gsub (cfg.stripmarkers[&#039;math&#039;], &amp;quot;MATH RENDER ERROR&amp;quot;);						-- one or more couldn&#039;t be replaced; insert vague error message&lt;br /&gt;
	&lt;br /&gt;
	value = mw.text.unstripNoWiki (value);										-- replace nowiki stripmarkers with their content&lt;br /&gt;
	value = value:gsub (&#039;&amp;lt;span class=&amp;quot;nowrap&amp;quot; style=&amp;quot;padding%-left:0%.1em;&amp;quot;&amp;gt;&amp;amp;#39;(s?)&amp;lt;/span&amp;gt;&#039;, &amp;quot;&#039;%1&amp;quot;);	-- replace {{&#039;}} or {{&#039;s}} with simple apostrophe or apostrophe-s&lt;br /&gt;
	value = value:gsub (&#039;&amp;amp;nbsp;&#039;, &#039; &#039;);											-- replace &amp;amp;nbsp; entity with plain space&lt;br /&gt;
	value = value:gsub (&#039;\226\128\138&#039;, &#039; &#039;);									-- replace hair space with plain space&lt;br /&gt;
	if not mw.ustring.find (value, cfg.indic_script) then						-- don&#039;t remove zero width joiner characters from indic script&lt;br /&gt;
		value = value:gsub (&#039;&amp;amp;zwj;&#039;, &#039;&#039;);											-- remove &amp;amp;zwj; entities&lt;br /&gt;
		value = mw.ustring.gsub (value, &#039;[\226\128\141\226\128\139\194\173]&#039;, &#039;&#039;);	-- remove zero-width joiner, zero-width space, soft hyphen&lt;br /&gt;
	end&lt;br /&gt;
	value = value:gsub (&#039;[\009\010\013]&#039;, &#039; &#039;);									-- replace horizontal tab, line feed, carriage return with plain space&lt;br /&gt;
	return value;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C O I N S &amp;gt;--------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
COinS metadata (see &amp;lt;http://ocoins.info/&amp;gt;) allows automated tools to parse the citation information.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function COinS(data, class)&lt;br /&gt;
	if &#039;table&#039; ~= type(data) or nil == next(data) then&lt;br /&gt;
		return &#039;&#039;;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	for k, v in pairs (data) do													-- spin through all of the metadata parameter values&lt;br /&gt;
		if &#039;ID_list&#039; ~= k and &#039;Authors&#039; ~= k then								-- except the ID_list and Author tables (author nowiki stripmarker done when Author table processed)&lt;br /&gt;
			data[k] = coins_cleanup (v);&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local ctx_ver = &amp;quot;Z39.88-2004&amp;quot;;&lt;br /&gt;
	&lt;br /&gt;
	-- treat table strictly as an array with only set values.&lt;br /&gt;
	local OCinSoutput = setmetatable( {}, {&lt;br /&gt;
		__newindex = function(self, key, value)&lt;br /&gt;
			if is_set(value) then&lt;br /&gt;
				rawset( self, #self+1, table.concat{ key, &#039;=&#039;, mw.uri.encode( remove_wiki_link( value ) ) } );&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	});&lt;br /&gt;
	&lt;br /&gt;
	if in_array (class, {&#039;arxiv&#039;, &#039;biorxiv&#039;, &#039;citeseerx&#039;, &#039;journal&#039;, &#039;news&#039;}) or (in_array (class, {&#039;conference&#039;, &#039;interview&#039;, &#039;map&#039;, &#039;press release&#039;, &#039;web&#039;}) and is_set(data.Periodical)) or &lt;br /&gt;
		(&#039;citation&#039; == class and is_set(data.Periodical) and not is_set (data.Encyclopedia)) then&lt;br /&gt;
			OCinSoutput.rft_val_fmt = &amp;quot;info:ofi/fmt:kev:mtx:journal&amp;quot;;			-- journal metadata identifier&lt;br /&gt;
			if in_array (class, {&#039;arxiv&#039;, &#039;biorxiv&#039;, &#039;citeseerx&#039;}) then			-- set genre according to the type of citation template we are rendering&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &amp;quot;preprint&amp;quot;;							-- cite arxiv, cite biorxiv, cite citeseerx&lt;br /&gt;
			elseif &#039;conference&#039; == class then&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &amp;quot;conference&amp;quot;;						-- cite conference (when Periodical set)&lt;br /&gt;
			elseif &#039;web&#039; == class then&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &amp;quot;unknown&amp;quot;;							-- cite web (when Periodical set)&lt;br /&gt;
			else&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &amp;quot;article&amp;quot;;							-- journal and other &#039;periodical&#039; articles&lt;br /&gt;
			end&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.jtitle&amp;quot;] = data.Periodical;						-- journal only&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.atitle&amp;quot;] = data.Title;								-- &#039;periodical&#039; article titles&lt;br /&gt;
&lt;br /&gt;
																				-- these used only for periodicals&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.ssn&amp;quot;] = data.Season;								-- keywords: winter, spring, summer, fall&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.chron&amp;quot;] = data.Chron;								-- free-form date components&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.volume&amp;quot;] = data.Volume;							-- does not apply to books&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.issue&amp;quot;] = data.Issue;&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.pages&amp;quot;] = data.Pages;								-- also used in book metadata&lt;br /&gt;
&lt;br /&gt;
	elseif &#039;thesis&#039; ~= class then												-- all others except cite thesis are treated as &#039;book&#039; metadata; genre distinguishes&lt;br /&gt;
		OCinSoutput.rft_val_fmt = &amp;quot;info:ofi/fmt:kev:mtx:book&amp;quot;;					-- book metadata identifier&lt;br /&gt;
		if &#039;report&#039; == class or &#039;techreport&#039; == class then						-- cite report and cite techreport&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &amp;quot;report&amp;quot;;&lt;br /&gt;
		elseif &#039;conference&#039; == class then										-- cite conference when Periodical not set&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &amp;quot;conference&amp;quot;;&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.atitle&amp;quot;] = data.Chapter;							-- conference paper as chapter in proceedings (book)&lt;br /&gt;
		elseif in_array (class, {&#039;book&#039;, &#039;citation&#039;, &#039;encyclopaedia&#039;, &#039;interview&#039;, &#039;map&#039;}) then&lt;br /&gt;
			if is_set (data.Chapter) then&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &amp;quot;bookitem&amp;quot;;&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.atitle&amp;quot;] = data.Chapter;						-- book chapter, encyclopedia article, interview in a book, or map title&lt;br /&gt;
			else&lt;br /&gt;
				if &#039;map&#039; == class or &#039;interview&#039; == class then&lt;br /&gt;
					OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &#039;unknown&#039;;						-- standalone map or interview&lt;br /&gt;
				else&lt;br /&gt;
					OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &#039;book&#039;;							-- book and encyclopedia&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		else	--{&#039;audio-visual&#039;, &#039;AV-media-notes&#039;, &#039;DVD-notes&#039;, &#039;episode&#039;, &#039;interview&#039;, &#039;mailinglist&#039;, &#039;map&#039;, &#039;newsgroup&#039;, &#039;podcast&#039;, &#039;press release&#039;, &#039;serial&#039;, &#039;sign&#039;, &#039;speech&#039;, &#039;web&#039;}&lt;br /&gt;
			OCinSoutput[&amp;quot;rft.genre&amp;quot;] = &amp;quot;unknown&amp;quot;;&lt;br /&gt;
		end&lt;br /&gt;
		OCinSoutput[&amp;quot;rft.btitle&amp;quot;] = data.Title;									-- book only&lt;br /&gt;
		OCinSoutput[&amp;quot;rft.place&amp;quot;] = data.PublicationPlace;						-- book only&lt;br /&gt;
		OCinSoutput[&amp;quot;rft.series&amp;quot;] = data.Series;								-- book only&lt;br /&gt;
		OCinSoutput[&amp;quot;rft.pages&amp;quot;] = data.Pages;									-- book, journal&lt;br /&gt;
		OCinSoutput[&amp;quot;rft.edition&amp;quot;] = data.Edition;								-- book only&lt;br /&gt;
		OCinSoutput[&amp;quot;rft.pub&amp;quot;] = data.PublisherName;							-- book and dissertation&lt;br /&gt;
		&lt;br /&gt;
	else																		-- cite thesis&lt;br /&gt;
		OCinSoutput.rft_val_fmt = &amp;quot;info:ofi/fmt:kev:mtx:dissertation&amp;quot;;			-- dissertation metadata identifier&lt;br /&gt;
		OCinSoutput[&amp;quot;rft.title&amp;quot;] = data.Title;									-- dissertation (also patent but that is not yet supported)&lt;br /&gt;
		OCinSoutput[&amp;quot;rft.degree&amp;quot;] = data.Degree;								-- dissertation only&lt;br /&gt;
		OCinSoutput[&#039;rft.inst&#039;] = data.PublisherName;							-- book and dissertation&lt;br /&gt;
	end&lt;br /&gt;
																				-- and now common parameters (as much as possible)&lt;br /&gt;
	OCinSoutput[&amp;quot;rft.date&amp;quot;] = data.Date;										-- book, journal, dissertation&lt;br /&gt;
	&lt;br /&gt;
	for k, v in pairs( data.ID_list ) do										-- what to do about these? For now assume that they are common to all?&lt;br /&gt;
--		if k == &#039;ISBN&#039; then v = clean_isbn( v ) end&lt;br /&gt;
		if k == &#039;ISBN&#039; then v = v:gsub( &amp;quot;[^-0-9X]&amp;quot;, &amp;quot;&amp;quot; ); end&lt;br /&gt;
		local id = cfg.id_handlers[k].COinS;&lt;br /&gt;
		if string.sub( id or &amp;quot;&amp;quot;, 1, 4 ) == &#039;info&#039; then							-- for ids that are in the info:registry&lt;br /&gt;
			OCinSoutput[&amp;quot;rft_id&amp;quot;] = table.concat{ id, &amp;quot;/&amp;quot;, v };&lt;br /&gt;
		elseif string.sub (id or &amp;quot;&amp;quot;, 1, 3 ) == &#039;rft&#039; then						-- for isbn, issn, eissn, etc that have defined COinS keywords&lt;br /&gt;
			OCinSoutput[ id ] = v;&lt;br /&gt;
		elseif id then															-- when cfg.id_handlers[k].COinS is not nil&lt;br /&gt;
			OCinSoutput[&amp;quot;rft_id&amp;quot;] = table.concat{ cfg.id_handlers[k].prefix, v };	-- others; provide a url&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
--[[	&lt;br /&gt;
	for k, v in pairs( data.ID_list ) do										-- what to do about these? For now assume that they are common to all?&lt;br /&gt;
		local id, value = cfg.id_handlers[k].COinS;&lt;br /&gt;
		if k == &#039;ISBN&#039; then value = clean_isbn( v ); else value = v; end&lt;br /&gt;
		if string.sub( id or &amp;quot;&amp;quot;, 1, 4 ) == &#039;info&#039; then&lt;br /&gt;
			OCinSoutput[&amp;quot;rft_id&amp;quot;] = table.concat{ id, &amp;quot;/&amp;quot;, v };&lt;br /&gt;
		else&lt;br /&gt;
			OCinSoutput[ id ] = value;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
]]&lt;br /&gt;
	local last, first;&lt;br /&gt;
	for k, v in ipairs( data.Authors ) do&lt;br /&gt;
		last, first = coins_cleanup (v.last), coins_cleanup (v.first or &#039;&#039;);	-- replace any nowiki strip markers, non-printing or invisible characers&lt;br /&gt;
		if k == 1 then															-- for the first author name only&lt;br /&gt;
			if is_set(last)  and is_set(first) then								-- set these COinS values if |first= and |last= specify the first author name&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.aulast&amp;quot;] = last;								-- book, journal, dissertation&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.aufirst&amp;quot;] = first;								-- book, journal, dissertation&lt;br /&gt;
			elseif is_set(last) then &lt;br /&gt;
				OCinSoutput[&amp;quot;rft.au&amp;quot;] = last;									-- book, journal, dissertation -- otherwise use this form for the first name&lt;br /&gt;
			end&lt;br /&gt;
		else																	-- for all other authors&lt;br /&gt;
			if is_set(last) and is_set(first) then&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.au&amp;quot;] = table.concat{ last, &amp;quot;, &amp;quot;, first };		-- book, journal, dissertation&lt;br /&gt;
			elseif is_set(last) then&lt;br /&gt;
				OCinSoutput[&amp;quot;rft.au&amp;quot;] = last;									-- book, journal, dissertation&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	OCinSoutput.rft_id = data.URL;&lt;br /&gt;
	OCinSoutput.rfr_id = table.concat{ &amp;quot;info:sid/&amp;quot;, mw.site.server:match( &amp;quot;[^/]*$&amp;quot; ), &amp;quot;:&amp;quot;, data.RawPage };&lt;br /&gt;
	OCinSoutput = setmetatable( OCinSoutput, nil );&lt;br /&gt;
	&lt;br /&gt;
	-- sort with version string always first, and combine.&lt;br /&gt;
	--table.sort( OCinSoutput );&lt;br /&gt;
	table.insert( OCinSoutput, 1, &amp;quot;ctx_ver=&amp;quot; .. ctx_ver );  -- such as &amp;quot;Z39.88-2004&amp;quot;&lt;br /&gt;
	return table.concat(OCinSoutput, &amp;quot;&amp;amp;&amp;quot;);&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E T _ S E L E C T E D _ M O D U L E S &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
Sets local cfg table and imported functions table to same (live or sandbox) as that used by the other modules.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function set_selected_modules (cfg_table_ptr, utilities_page_ptr)&lt;br /&gt;
	cfg = cfg_table_ptr;&lt;br /&gt;
&lt;br /&gt;
	is_set = utilities_page_ptr.is_set;											-- import functions from select Module:Citation/CS1/Utilities module&lt;br /&gt;
	in_array = utilities_page_ptr.in_array;&lt;br /&gt;
	remove_wiki_link = utilities_page_ptr.remove_wiki_link;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
return {&lt;br /&gt;
	make_coins_title = make_coins_title,&lt;br /&gt;
	get_coins_pages = get_coins_pages,&lt;br /&gt;
	COinS = COinS,&lt;br /&gt;
	set_selected_modules = set_selected_modules,&lt;br /&gt;
	}&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1&amp;diff=1183</id>
		<title>Module:Citation/CS1</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Citation/CS1&amp;diff=1183"/>
		<updated>2018-04-07T11:49:50Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;br /&gt;
local cs1 ={};&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; F O R W A R D   D E C L A R A T I O N S &amp;gt;--------------------------------------&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local dates, year_date_check, reformat_dates, date_hyphen_to_dash,				-- functions in Module:Citation/CS1/Date_validation&lt;br /&gt;
	date_name_xlate&lt;br /&gt;
&lt;br /&gt;
local is_set, in_array, substitute, error_comment, set_error, select_one,		-- functions in Module:Citation/CS1/Utilities&lt;br /&gt;
	add_maint_cat, wrap_style, safe_for_italics, is_wikilink, make_wikilink;&lt;br /&gt;
&lt;br /&gt;
local z ={};																	-- tables in Module:Citation/CS1/Utilities&lt;br /&gt;
&lt;br /&gt;
local extract_ids, extract_id_access_levels, build_id_list, is_embargoed;		-- functions in Module:Citation/CS1/Identifiers&lt;br /&gt;
&lt;br /&gt;
local make_coins_title, get_coins_pages, COinS;									-- functions in Module:Citation/CS1/COinS&lt;br /&gt;
&lt;br /&gt;
local cfg = {};																	-- table of configuration tables that are defined in Module:Citation/CS1/Configuration&lt;br /&gt;
local whitelist = {};															-- table of tables listing valid template parameter names; defined in Module:Citation/CS1/Whitelist&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; P A G E   S C O P E   V A R I A B L E S &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
delare variables here that have page-wide scope that are not brought in from other modules; thatare created here&lt;br /&gt;
and used here&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local added_deprecated_cat;														-- boolean flag so that the category is added only once&lt;br /&gt;
local added_prop_cats = {};														-- list of property categories that have been added to z.properties_cats&lt;br /&gt;
local added_vanc_errs;															-- boolean flag so we only emit one Vancouver error / category&lt;br /&gt;
&lt;br /&gt;
local Frame;																	-- holds the module&#039;s frame table&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; F I R S T _ S E T &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Locates and returns the first set value in a table of values where the order established in the table,&lt;br /&gt;
left-to-right (or top-to-bottom), is the order in which the values are evaluated.  Returns nil if none are set.&lt;br /&gt;
&lt;br /&gt;
This version replaces the original &#039;for _, val in pairs do&#039; and a similar version that used ipairs.  With the pairs&lt;br /&gt;
version the order of evaluation could not be guaranteed.  With the ipairs version, a nil value would terminate&lt;br /&gt;
the for-loop before it reached the actual end of the list.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function first_set (list, count)&lt;br /&gt;
	local i = 1;&lt;br /&gt;
	while i &amp;lt;= count do															-- loop through all items in list&lt;br /&gt;
		if is_set( list[i] ) then&lt;br /&gt;
			return list[i];														-- return the first set list member&lt;br /&gt;
		end&lt;br /&gt;
		i = i + 1;																-- point to next&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; A D D _ P R O P _ C A T &amp;gt;--------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Adds a category to z.properties_cats using names from the configuration file with additional text if any.&lt;br /&gt;
&lt;br /&gt;
foreign_lang_source and foreign_lang_source_2 keys have a language code appended to them so that multiple languages&lt;br /&gt;
may be categorized but multiples of the same language are not categorized.&lt;br /&gt;
&lt;br /&gt;
added_prop_cats is a table declared in page scope variables above&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function add_prop_cat (key, arguments)&lt;br /&gt;
	if not added_prop_cats [key] then&lt;br /&gt;
		added_prop_cats [key] = true;											-- note that we&#039;ve added this category&lt;br /&gt;
		key = key:gsub (&#039;(foreign_lang_source_?2?)%a%a%a?&#039;, &#039;%1&#039;);				-- strip lang code from keyname&lt;br /&gt;
		table.insert( z.properties_cats, substitute (cfg.prop_cats [key], arguments));		-- make name then add to table&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; A D D _ V A N C _ E R R O R &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Adds a single Vancouver system error message to the template&#039;s output regardless of how many error actually exist.&lt;br /&gt;
To prevent duplication, added_vanc_errs is nil until an error message is emitted.&lt;br /&gt;
&lt;br /&gt;
added_vanc_errs is a boolean declared in page scope variables above&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function add_vanc_error (source)&lt;br /&gt;
	if not added_vanc_errs then&lt;br /&gt;
		added_vanc_errs = true;													-- note that we&#039;ve added this category&lt;br /&gt;
		table.insert( z.message_tail, { set_error( &#039;vancouver&#039;, {source}, true ) } );&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ S C H E M E &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
does this thing that purports to be a uri scheme seem to be a valid scheme?  The scheme is checked to see if it&lt;br /&gt;
is in agreement with http://tools.ietf.org/html/std66#section-3.1 which says:&lt;br /&gt;
	Scheme names consist of a sequence of characters beginning with a&lt;br /&gt;
   letter and followed by any combination of letters, digits, plus&lt;br /&gt;
   (&amp;quot;+&amp;quot;), period (&amp;quot;.&amp;quot;), or hyphen (&amp;quot;-&amp;quot;).&lt;br /&gt;
&lt;br /&gt;
returns true if it does, else false&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_scheme (scheme)&lt;br /&gt;
	return scheme and scheme:match (&#039;^%a[%a%d%+%.%-]*:&#039;);						-- true if scheme is set and matches the pattern&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; I S _ D O M A I N _ N A M E &amp;gt;--------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Does this thing that purports to be a domain name seem to be a valid domain name?&lt;br /&gt;
&lt;br /&gt;
Syntax defined here: http://tools.ietf.org/html/rfc1034#section-3.5&lt;br /&gt;
BNF defined here: https://tools.ietf.org/html/rfc4234&lt;br /&gt;
Single character names are generally reserved; see https://tools.ietf.org/html/draft-ietf-dnsind-iana-dns-01#page-15;&lt;br /&gt;
	see also [[Single-letter second-level domain]]&lt;br /&gt;
list of tlds: https://www.iana.org/domains/root/db&lt;br /&gt;
&lt;br /&gt;
rfc952 (modified by rfc 1123) requires the first and last character of a hostname to be a letter or a digit.  Between&lt;br /&gt;
the first and last characters the name may use letters, digits, and the hyphen.&lt;br /&gt;
&lt;br /&gt;
Also allowed are IPv4 addresses. IPv6 not supported&lt;br /&gt;
&lt;br /&gt;
domain is expected to be stripped of any path so that the last character in the last character of the tld.  tld&lt;br /&gt;
is two or more alpha characters.  Any preceding &#039;//&#039; (from splitting a url with a scheme) will be stripped&lt;br /&gt;
here.  Perhaps not necessary but retained incase it is necessary for IPv4 dot decimal.&lt;br /&gt;
&lt;br /&gt;
There are several tests:&lt;br /&gt;
	the first character of the whole domain name including subdomains must be a letter or a digit&lt;br /&gt;
	internationalized domain name (ascii characters with .xn-- ASCII Compatible Encoding (ACE) prefix xn-- in the tld) see https://tools.ietf.org/html/rfc3490&lt;br /&gt;
	single-letter/digit second-level domains in the .org and .cash TLDs&lt;br /&gt;
	q, x, and z SL domains in the .com TLD&lt;br /&gt;
	i and q SL domains in the .net TLD&lt;br /&gt;
	single-letter SL domains in the ccTLDs (where the ccTLD is two letters)&lt;br /&gt;
	two-character SL domains in gTLDs (where the gTLD is two or more letters)&lt;br /&gt;
	three-plus-character SL domains in gTLDs (where the gTLD is two or more letters)&lt;br /&gt;
	IPv4 dot-decimal address format; TLD not allowed&lt;br /&gt;
&lt;br /&gt;
returns true if domain appears to be a proper name and tld or IPv4 address, else false&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function is_domain_name (domain)&lt;br /&gt;
	if not domain then&lt;br /&gt;
		return false;															-- if not set, abandon&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	domain = domain:gsub (&#039;^//&#039;, &#039;&#039;);											-- strip &#039;//&#039; from domain name if present; done here so we only have to do it once&lt;br /&gt;
	&lt;br /&gt;
	if not domain:match (&#039;^[%a%d]&#039;) then										-- first character must be letter or digit&lt;br /&gt;
		return false;&lt;br /&gt;
	end&lt;br /&gt;
																				-- Do most common case first&lt;br /&gt;
	if domain:match (&#039;%f[%a%d][%a%d][%a%d%-]+[%a%d]%.%a%a+$&#039;) then				-- three or more character hostname.hostname or hostname.tld&lt;br /&gt;
		return true;&lt;br /&gt;
	elseif domain:match (&#039;%f[%a%d][%a%d][%a%d%-]+[%a%d]%.xn%-%-[%a%d]+$&#039;) then	-- internationalized domain name with ACE prefix&lt;br /&gt;
		return true;&lt;br /&gt;
	elseif domain:match (&#039;%f[%a%d][%a%d]%.cash$&#039;) then							-- one character/digit .cash hostname&lt;br /&gt;
		return true;&lt;br /&gt;
	elseif domain:match (&#039;%f[%a%d][%a%d]%.org$&#039;) then							-- one character/digit .org hostname&lt;br /&gt;
		return true;&lt;br /&gt;
	elseif domain:match (&#039;%f[%a][qxz]%.com$&#039;) then								-- assigned one character .com hostname (x.com times out 2015-12-10)&lt;br /&gt;
		return true;&lt;br /&gt;
	elseif domain:match (&#039;%f[%a][iq]%.net$&#039;) then								-- assigned one character .net hostname (q.net registered but not active 2015-12-10)&lt;br /&gt;
		return true;&lt;br /&gt;
	elseif domain:match (&#039;%f[%a%d][%a%d]%.%a%a$&#039;) then							-- one character hostname and cctld (2 chars)&lt;br /&gt;
		return true;&lt;br /&gt;
	elseif domain:match (&#039;%f[%a%d][%a%d][%a%d]%.%a%a+$&#039;) then					-- two character hostname and tld&lt;br /&gt;
		return true;&lt;br /&gt;
	elseif domain:match (&#039;^%d%d?%d?%.%d%d?%d?%.%d%d?%d?%.%d%d?%d?&#039;) then		-- IPv4 address&lt;br /&gt;
		return true;&lt;br /&gt;
	else&lt;br /&gt;
		return false;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ U R L &amp;gt;------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
returns true if the scheme and domain parts of a url appear to be a valid url; else false.&lt;br /&gt;
&lt;br /&gt;
This function is the last step in the validation process.  This function is separate because there are cases that&lt;br /&gt;
are not covered by split_url(), for example is_parameter_ext_wikilink() which is looking for bracketted external&lt;br /&gt;
wikilinks.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_url (scheme, domain)&lt;br /&gt;
	if is_set (scheme) then														-- if scheme is set check it and domain&lt;br /&gt;
		return is_scheme (scheme) and is_domain_name (domain);&lt;br /&gt;
	else&lt;br /&gt;
		return is_domain_name (domain);											-- scheme not set when url is protocol relative&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S P L I T _ U R L &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Split a url into a scheme, authority indicator, and domain.&lt;br /&gt;
&lt;br /&gt;
First remove Fully Qualified Domain Name terminator (a dot following tld) (if any) and any path(/), query(?) or fragment(#).&lt;br /&gt;
&lt;br /&gt;
If protocol relative url, return nil scheme and domain else return nil for both scheme and domain.&lt;br /&gt;
&lt;br /&gt;
When not protocol relative, get scheme, authority indicator, and domain.  If there is an authority indicator (one&lt;br /&gt;
or more &#039;/&#039; characters immediately following the scheme&#039;s colon), make sure that there are only 2.&lt;br /&gt;
&lt;br /&gt;
Strip off any port and path;&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function split_url (url_str)&lt;br /&gt;
	local scheme, authority, domain;&lt;br /&gt;
	&lt;br /&gt;
	url_str = url_str:gsub (&#039;([%a%d])%.?[/%?#].*$&#039;, &#039;%1&#039;);						-- strip FQDN terminator and path(/), query(?), fragment (#) (the capture prevents false replacement of &#039;//&#039;)&lt;br /&gt;
&lt;br /&gt;
	if url_str:match (&#039;^//%S*&#039;) then											-- if there is what appears to be a protocol relative url&lt;br /&gt;
		domain = url_str:match (&#039;^//(%S*)&#039;)&lt;br /&gt;
	elseif url_str:match (&#039;%S-:/*%S+&#039;) then										-- if there is what appears to be a scheme, optional authority indicator, and domain name&lt;br /&gt;
		scheme, authority, domain = url_str:match (&#039;(%S-:)(/*)(%S+)&#039;);			-- extract the scheme, authority indicator, and domain portions&lt;br /&gt;
		authority = authority:gsub (&#039;//&#039;, &#039;&#039;, 1);								-- replace place 1 pair of &#039;/&#039; with nothing;&lt;br /&gt;
		if is_set(authority) then												-- if anything left (1 or 3+ &#039;/&#039; where authority should be) then&lt;br /&gt;
			return scheme;														-- return scheme only making domain nil which will cause an error message&lt;br /&gt;
		end&lt;br /&gt;
		domain = domain:gsub (&#039;(%a):%d+&#039;, &#039;%1&#039;);								-- strip port number if present&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return scheme, domain;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; L I N K _ P A R A M _ O K &amp;gt;---------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
checks the content of |title-link=, |series-link=, |author-link= etc for properly formatted content: no wikilinks, no urls&lt;br /&gt;
&lt;br /&gt;
Link parameters are to hold the title of a wikipedia article so none of the WP:TITLESPECIALCHARACTERS are allowed:&lt;br /&gt;
	# &amp;lt; &amp;gt; [ ] | { } _&lt;br /&gt;
except the underscore which is used as a space in wiki urls and # which is used for section links&lt;br /&gt;
&lt;br /&gt;
returns false when the value contains any of these characters.&lt;br /&gt;
&lt;br /&gt;
When there are no illegal characters, this function returns TRUE if value DOES NOT appear to be a valid url (the&lt;br /&gt;
|&amp;lt;param&amp;gt;-link= parameter is ok); else false when value appears to be a valid url (the |&amp;lt;param&amp;gt;-link= parameter is NOT ok).&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function link_param_ok (value)&lt;br /&gt;
	local scheme, domain;&lt;br /&gt;
	if value:find (&#039;[&amp;lt;&amp;gt;%[%]|{}]&#039;) then											-- if any prohibited characters&lt;br /&gt;
		return false;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	scheme, domain = split_url (value);											-- get scheme or nil and domain or nil from url; &lt;br /&gt;
	return not is_url (scheme, domain);											-- return true if value DOES NOT appear to be a valid url&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; L I N K _ T I T L E _ O K &amp;gt;---------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Use link_param_ok() to validate |&amp;lt;param&amp;gt;-link= value and its matching |&amp;lt;title&amp;gt;= value.&lt;br /&gt;
&lt;br /&gt;
|&amp;lt;title&amp;gt;= may be wikilinked but not when |&amp;lt;param&amp;gt;-link= has a value.  This function emits an error message when&lt;br /&gt;
that condition exists&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function link_title_ok (link, lorig, title, torig)&lt;br /&gt;
local orig;&lt;br /&gt;
&lt;br /&gt;
	if is_set (link) then 														-- don&#039;t bother if &amp;lt;param&amp;gt;-link doesn&#039;t have a value&lt;br /&gt;
		if not link_param_ok (link) then										-- check |&amp;lt;param&amp;gt;-link= markup&lt;br /&gt;
			orig = lorig;														-- identify the failing link parameter&lt;br /&gt;
		elseif title:find (&#039;%[%[&#039;) then											-- check |title= for wikilink markup&lt;br /&gt;
			orig = torig;														-- identify the failing |title= parameter&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set (orig) then&lt;br /&gt;
		table.insert( z.message_tail, { set_error( &#039;bad_paramlink&#039;, orig)});	-- url or wikilink in |title= with |title-link=;&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C H E C K _ U R L &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Determines whether a URL string appears to be valid.&lt;br /&gt;
&lt;br /&gt;
First we test for space characters.  If any are found, return false.  Then split the url into scheme and domain&lt;br /&gt;
portions, or for protocol relative (//example.com) urls, just the domain.  Use is_url() to validate the two&lt;br /&gt;
portions of the url.  If both are valid, or for protocol relative if domain is valid, return true, else false.&lt;br /&gt;
&lt;br /&gt;
Because it is different from a standard url, and because this module used external_link() to make external links&lt;br /&gt;
that work for standard and news: links, we validate newsgroup names here.  The specification for a newsgroup name&lt;br /&gt;
is at https://tools.ietf.org/html/rfc5536#section-3.1.4&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function check_url( url_str )&lt;br /&gt;
	if nil == url_str:match (&amp;quot;^%S+$&amp;quot;) then										-- if there are any spaces in |url=value it can&#039;t be a proper url&lt;br /&gt;
		return false;&lt;br /&gt;
	end&lt;br /&gt;
	local scheme, domain;&lt;br /&gt;
&lt;br /&gt;
	scheme, domain = split_url (url_str);										-- get scheme or nil and domain or nil from url;&lt;br /&gt;
	&lt;br /&gt;
	if &#039;news:&#039; == scheme then													-- special case for newsgroups&lt;br /&gt;
		return domain:match(&#039;^[%a%d%+%-_]+%.[%a%d%+%-_%.]*[%a%d%+%-_]$&#039;);&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return is_url (scheme, domain);												-- return true if value appears to be a valid url&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; I S _ P A R A M E T E R _ E X T _ W I K I L I N K &amp;gt;----------------------------&lt;br /&gt;
&lt;br /&gt;
Return true if a parameter value has a string that begins and ends with square brackets [ and ] and the first&lt;br /&gt;
non-space characters following the opening bracket appear to be a url.  The test will also find external wikilinks&lt;br /&gt;
that use protocol relative urls. Also finds bare urls.&lt;br /&gt;
&lt;br /&gt;
The frontier pattern prevents a match on interwiki links which are similar to scheme:path urls.  The tests that&lt;br /&gt;
find bracketed urls are required because the parameters that call this test (currently |title=, |chapter=, |work=,&lt;br /&gt;
and |publisher=) may have wikilinks and there are articles or redirects like &#039;//Hus&#039; so, while uncommon, |title=[[//Hus]]&lt;br /&gt;
is possible as might be [[en://Hus]].&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function is_parameter_ext_wikilink (value)&lt;br /&gt;
local scheme, domain;&lt;br /&gt;
&lt;br /&gt;
	if value:match (&#039;%f[%[]%[%a%S*:%S+.*%]&#039;) then								-- if ext wikilink with scheme and domain: [xxxx://yyyyy.zzz]&lt;br /&gt;
		scheme, domain = split_url (value:match (&#039;%f[%[]%[(%a%S*:%S+).*%]&#039;));&lt;br /&gt;
	elseif value:match (&#039;%f[%[]%[//%S+.*%]&#039;) then								-- if protocol relative ext wikilink: [//yyyyy.zzz]&lt;br /&gt;
		scheme, domain = split_url (value:match (&#039;%f[%[]%[(//%S+).*%]&#039;));&lt;br /&gt;
	elseif value:match (&#039;%a%S*:%S+&#039;) then										-- if bare url with scheme; may have leading or trailing plain text&lt;br /&gt;
		scheme, domain = split_url (value:match (&#039;(%a%S*:%S+)&#039;));&lt;br /&gt;
	elseif value:match (&#039;//%S+&#039;) then											-- if protocol relative bare url: //yyyyy.zzz; may have leading or trailing plain text&lt;br /&gt;
		scheme, domain = split_url (value:match (&#039;(//%S+)&#039;));					-- what is left should be the domain&lt;br /&gt;
	else&lt;br /&gt;
		return false;															-- didn&#039;t find anything that is obviously a url&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return is_url (scheme, domain);												-- return true if value appears to be a valid url&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; C H E C K _ F O R _ U R L &amp;gt;-----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
loop through a list of parameters and their values.  Look at the value and if it has an external link, emit an error message.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function check_for_url (parameter_list)&lt;br /&gt;
local error_message = &#039;&#039;;&lt;br /&gt;
	for k, v in pairs (parameter_list) do										-- for each parameter in the list&lt;br /&gt;
		if is_parameter_ext_wikilink (v) then									-- look at the value; if there is a url add an error message&lt;br /&gt;
			if is_set(error_message) then										-- once we&#039;ve added the first portion of the error message ...&lt;br /&gt;
				error_message=error_message .. &amp;quot;, &amp;quot;;							-- ... add a comma space separator&lt;br /&gt;
			end&lt;br /&gt;
			error_message=error_message .. &amp;quot;&amp;amp;#124;&amp;quot; .. k .. &amp;quot;=&amp;quot;;				-- add the failed parameter&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if is_set (error_message) then												-- done looping, if there is an error message, display it&lt;br /&gt;
		table.insert( z.message_tail, { set_error( &#039;param_has_ext_link&#039;, {error_message}, true ) } );&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S A F E _ F O R _ U R L &amp;gt;------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Escape sequences for content that will be used for URL descriptions&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function safe_for_url( str )&lt;br /&gt;
	if str:match( &amp;quot;%[%[.-%]%]&amp;quot; ) ~= nil then &lt;br /&gt;
		table.insert( z.message_tail, { set_error( &#039;wikilink_in_url&#039;, {}, true ) } );&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return str:gsub( &#039;[%[%]\n]&#039;, {	&lt;br /&gt;
		[&#039;[&#039;] = &#039;&amp;amp;#91;&#039;,&lt;br /&gt;
		[&#039;]&#039;] = &#039;&amp;amp;#93;&#039;,&lt;br /&gt;
		[&#039;\n&#039;] = &#039; &#039; } );&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; E X T E R N A L _ L I N K &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Format an external link with error checking&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function external_link( URL, label, source, access)&lt;br /&gt;
	local error_str = &amp;quot;&amp;quot;;&lt;br /&gt;
	local domain;&lt;br /&gt;
	local path;&lt;br /&gt;
	local base_url;&lt;br /&gt;
	&lt;br /&gt;
	if not is_set( label ) then&lt;br /&gt;
		label = URL;&lt;br /&gt;
		if is_set( source ) then&lt;br /&gt;
			error_str = set_error( &#039;bare_url_missing_title&#039;, { wrap_style (&#039;parameter&#039;, source) }, false, &amp;quot; &amp;quot; );&lt;br /&gt;
		else&lt;br /&gt;
			error( cfg.messages[&amp;quot;bare_url_no_origin&amp;quot;] );&lt;br /&gt;
		end			&lt;br /&gt;
	end&lt;br /&gt;
	if not check_url( URL ) then&lt;br /&gt;
		error_str = set_error( &#039;bad_url&#039;, {wrap_style (&#039;parameter&#039;, source)}, false, &amp;quot; &amp;quot; ) .. error_str;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	domain, path = URL:match (&#039;^([/%.%-%+:%a%d]+)([/%?#].*)$&#039;);					-- split the url into scheme plus domain and path&lt;br /&gt;
	if path then																-- if there is a path portion&lt;br /&gt;
		path = path:gsub (&#039;[%[%]]&#039;, {[&#039;[&#039;]=&#039;%5b&#039;,[&#039;]&#039;]=&#039;%5d&#039;});					-- replace &#039;[&#039; and &#039;]&#039; with their percent encoded values&lt;br /&gt;
		URL=domain..path;														-- and reassemble&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if is_set (access) then														-- access level (subscription, registration, limited)&lt;br /&gt;
		label = safe_for_url (label);											-- replace square brackets and newlines&lt;br /&gt;
&lt;br /&gt;
		base_url = table.concat (												-- assemble external link with access signal&lt;br /&gt;
			{&lt;br /&gt;
			&#039;&amp;lt;span class=&amp;quot;plainlinks&amp;quot;&amp;gt;[&#039;,										-- opening css and url markup&lt;br /&gt;
			URL,																-- the url&lt;br /&gt;
			&#039; &#039;,																-- the required space&lt;br /&gt;
			label,&lt;br /&gt;
			&#039;&amp;lt;span style=&amp;quot;padding-left:0.15em&amp;quot;&amp;gt;&#039;,								-- signal spacing css&lt;br /&gt;
			cfg.presentation[access],											-- the appropriate icon&lt;br /&gt;
			&#039;&amp;lt;/span&amp;gt;&#039;,															-- close signal spacing span&lt;br /&gt;
			&#039;]&amp;lt;/span&amp;gt;&#039;															-- close url markup and plain links span&lt;br /&gt;
			});&lt;br /&gt;
	else&lt;br /&gt;
		base_url = table.concat({ &amp;quot;[&amp;quot;, URL, &amp;quot; &amp;quot;, safe_for_url( label ), &amp;quot;]&amp;quot; });	-- no signal markup&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return table.concat({ base_url, error_str });&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; D E P R E C A T E D _ P A R A M E T E R &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
Categorize and emit an error message when the citation contains one or more deprecated parameters.  The function includes the&lt;br /&gt;
offending parameter name to the error message.  Only one error message is emitted regardless of the number of deprecated&lt;br /&gt;
parameters in the citation.&lt;br /&gt;
&lt;br /&gt;
added_deprecated_cat is a boolean declared in page scope variables above&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function deprecated_parameter(name)&lt;br /&gt;
	if not added_deprecated_cat then&lt;br /&gt;
		added_deprecated_cat = true;											-- note that we&#039;ve added this category&lt;br /&gt;
		table.insert( z.message_tail, { set_error( &#039;deprecated_params&#039;, {name}, true ) } );		-- add error message&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; K E R N _ Q U O T E S &amp;gt;--------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Apply kerning to open the space between the quote mark provided by the Module and a leading or trailing quote&lt;br /&gt;
mark contained in a |title= or |chapter= parameter&#039;s value.&lt;br /&gt;
&lt;br /&gt;
This function will positive kern either single or double quotes:&lt;br /&gt;
	&amp;quot;&#039;Unkerned title with leading and trailing single quote marks&#039;&amp;quot;&lt;br /&gt;
	&amp;quot; &#039;Kerned title with leading and trailing single quote marks&#039; &amp;quot; (in real life the kerning isn&#039;t as wide as this example)&lt;br /&gt;
Double single quotes (italic or bold wikimarkup) are not kerned.&lt;br /&gt;
&lt;br /&gt;
Replaces unicode quotemarks in plain text or in the label portion of a [[L|D]] style wikilink with typewriter&lt;br /&gt;
quote marks regardless of the need for kerning.  Unicode quote marks are not replaced in simple [[D]] wikilinks.&lt;br /&gt;
&lt;br /&gt;
Call this function for chapter titles, for website titles, etc; not for book titles.&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function kern_quotes (str)&lt;br /&gt;
	local cap=&#039;&#039;;&lt;br /&gt;
	local cap2=&#039;&#039;;&lt;br /&gt;
	local wl_type, label, link;&lt;br /&gt;
&lt;br /&gt;
	wl_type, label, link = is_wikilink (str);									-- wl_type is: 0, no wl (text in label variable); 1, [[D]]; 2, [[L|D]]&lt;br /&gt;
	&lt;br /&gt;
	if 1 == wl_type then														-- [[D]] simple wikilink with or without quote marks&lt;br /&gt;
		if mw.ustring.match (str, &#039;%[%[[\&amp;quot;“”\&#039;‘’].+[\&amp;quot;“”\&#039;‘’]%]%]&#039;) then		-- leading and trailing quote marks&lt;br /&gt;
			str = substitute (cfg.presentation[&#039;kern-wl-both&#039;], str);&lt;br /&gt;
		elseif mw.ustring.match (str, &#039;%[%[[\&amp;quot;“”\&#039;‘’].+%]%]&#039;)	then			-- leading quote marks&lt;br /&gt;
			str = substitute (cfg.presentation[&#039;kern-wl-left&#039;], str);&lt;br /&gt;
		elseif mw.ustring.match (str, &#039;%[%[.+[\&amp;quot;“”\&#039;‘’]%]%]&#039;) then				-- trailing quote marks&lt;br /&gt;
			str = substitute (cfg.presentation[&#039;kern-wl-right&#039;], str);&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	else																		-- plain text or [[L|D]]; text in label variable&lt;br /&gt;
		label= mw.ustring.gsub (label, &#039;[“”]&#039;, &#039;\&amp;quot;&#039;);							-- replace “” (U+201C &amp;amp; U+201D) with &amp;quot; (typewriter double quote mark)&lt;br /&gt;
		label= mw.ustring.gsub (label, &#039;[‘’]&#039;, &#039;\&#039;&#039;);							-- replace ‘’ (U+2018 &amp;amp; U+2019) with &#039; (typewriter single quote mark)&lt;br /&gt;
&lt;br /&gt;
		cap, cap2 = mw.ustring.match (label, &amp;quot;^([\&amp;quot;\&#039;])([^\&#039;].+)&amp;quot;);				-- match leading double or single quote but not doubled single quotes (italic markup)&lt;br /&gt;
		if is_set (cap) then&lt;br /&gt;
			label = substitute (cfg.presentation[&#039;kern-left&#039;], {cap, cap2});&lt;br /&gt;
		end&lt;br /&gt;
	&lt;br /&gt;
		cap, cap2 = mw.ustring.match (label, &amp;quot;^(.+[^\&#039;])([\&amp;quot;\&#039;])$&amp;quot;)				-- match trailing double or single quote but not doubled single quotes (italic markup)&lt;br /&gt;
		if is_set (cap) then&lt;br /&gt;
			label = substitute (cfg.presentation[&#039;kern-right&#039;], {cap, cap2});&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		if 2 == wl_type then&lt;br /&gt;
			str = make_wikilink (link, label);									-- reassemble the wikilink&lt;br /&gt;
		else&lt;br /&gt;
			str = label;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return str;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; F O R M A T _ S C R I P T _ V A L U E &amp;gt;----------------------------------------&lt;br /&gt;
&lt;br /&gt;
|script-title= holds title parameters that are not written in Latin based scripts: Chinese, Japanese, Arabic, Hebrew, etc. These scripts should&lt;br /&gt;
not be italicized and may be written right-to-left.  The value supplied by |script-title= is concatenated onto Title after Title has been wrapped&lt;br /&gt;
in italic markup.&lt;br /&gt;
&lt;br /&gt;
Regardless of language, all values provided by |script-title= are wrapped in &amp;lt;bdi&amp;gt;...&amp;lt;/bdi&amp;gt; tags to isolate rtl languages from the English left to right.&lt;br /&gt;
&lt;br /&gt;
|script-title= provides a unique feature.  The value in |script-title= may be prefixed with a two-character ISO639-1 language code and a colon:&lt;br /&gt;
	|script-title=ja:*** *** (where * represents a Japanese character)&lt;br /&gt;
Spaces between the two-character code and the colon and the colon and the first script character are allowed:&lt;br /&gt;
	|script-title=ja : *** ***&lt;br /&gt;
	|script-title=ja: *** ***&lt;br /&gt;
	|script-title=ja :*** ***&lt;br /&gt;
Spaces preceding the prefix are allowed: |script-title = ja:*** ***&lt;br /&gt;
&lt;br /&gt;
The prefix is checked for validity.  If it is a valid ISO639-1 language code, the lang attribute (lang=&amp;quot;ja&amp;quot;) is added to the &amp;lt;bdi&amp;gt; tag so that browsers can&lt;br /&gt;
know the language the tag contains.  This may help the browser render the script more correctly.  If the prefix is invalid, the lang attribute&lt;br /&gt;
is not added.  At this time there is no error message for this condition.&lt;br /&gt;
&lt;br /&gt;
Supports |script-title= and |script-chapter=&lt;br /&gt;
&lt;br /&gt;
TODO: error messages when prefix is invalid ISO639-1 code; when script_value has prefix but no script;&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function format_script_value (script_value)&lt;br /&gt;
	local lang=&#039;&#039;;																-- initialize to empty string&lt;br /&gt;
	local name;&lt;br /&gt;
	if script_value:match(&#039;^%l%l%s*:&#039;) then										-- if first 3 non-space characters are script language prefix&lt;br /&gt;
		lang = script_value:match(&#039;^(%l%l)%s*:%s*%S.*&#039;);						-- get the language prefix or nil if there is no script&lt;br /&gt;
		if not is_set (lang) then&lt;br /&gt;
			return &#039;&#039;;															-- script_value was just the prefix so return empty string&lt;br /&gt;
		end&lt;br /&gt;
																				-- if we get this far we have prefix and script&lt;br /&gt;
		name = mw.language.fetchLanguageName( lang, &amp;quot;en&amp;quot; );						-- get language name so that we can use it to categorize&lt;br /&gt;
		if is_set (name) then													-- is prefix a proper ISO 639-1 language code?&lt;br /&gt;
			script_value = script_value:gsub (&#039;^%l%l%s*:%s*&#039;, &#039;&#039;);				-- strip prefix from script&lt;br /&gt;
																				-- is prefix one of these language codes?&lt;br /&gt;
			if in_array (lang, cfg.script_lang_codes) then&lt;br /&gt;
				add_prop_cat (&#039;script_with_name&#039;, {name, lang})&lt;br /&gt;
			else&lt;br /&gt;
				add_prop_cat (&#039;script&#039;)&lt;br /&gt;
			end&lt;br /&gt;
			lang = &#039; lang=&amp;quot;&#039; .. lang .. &#039;&amp;quot; &#039;;									-- convert prefix into a lang attribute&lt;br /&gt;
		else&lt;br /&gt;
			lang = &#039;&#039;;															-- invalid so set lang to empty string&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	script_value = substitute (cfg.presentation[&#039;bdi&#039;], {lang, script_value});	-- isolate in case script is rtl&lt;br /&gt;
&lt;br /&gt;
	return script_value;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S C R I P T _ C O N C A T E N A T E &amp;gt;------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Initially for |title= and |script-title=, this function concatenates those two parameter values after the script value has been &lt;br /&gt;
wrapped in &amp;lt;bdi&amp;gt; tags.&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function script_concatenate (title, script)&lt;br /&gt;
	if is_set (script) then&lt;br /&gt;
		script = format_script_value (script);									-- &amp;lt;bdi&amp;gt; tags, lang atribute, categorization, etc; returns empty string on error&lt;br /&gt;
		if is_set (script) then&lt;br /&gt;
			title = title .. &#039; &#039; .. script;										-- concatenate title and script title&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return title;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; W R A P _ M S G &amp;gt;--------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Applies additional message text to various parameter values. Supplied string is wrapped using a message_list&lt;br /&gt;
configuration taking one argument.  Supports lower case text for {{citation}} templates.  Additional text taken&lt;br /&gt;
from citation_config.messages - the reason this function is similar to but separate from wrap_style().&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function wrap_msg (key, str, lower)&lt;br /&gt;
	if not is_set( str ) then&lt;br /&gt;
		return &amp;quot;&amp;quot;;&lt;br /&gt;
	end&lt;br /&gt;
	if true == lower then&lt;br /&gt;
		local msg;&lt;br /&gt;
		msg = cfg.messages[key]:lower();										-- set the message to lower case before &lt;br /&gt;
		return substitute( msg, str );										-- including template text&lt;br /&gt;
	else&lt;br /&gt;
		return substitute( cfg.messages[key], str );&lt;br /&gt;
	end		&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; F O R M A T _ C H A P T E R _ T I T L E &amp;gt;--------------------------------------&lt;br /&gt;
&lt;br /&gt;
Format the four chapter parameters: |script-chapter=, |chapter=, |trans-chapter=, and |chapter-url= into a single Chapter meta-&lt;br /&gt;
parameter (chapter_url_source used for error messages).&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function format_chapter_title (scriptchapter, chapter, transchapter, chapterurl, chapter_url_source, no_quotes, access)&lt;br /&gt;
	local chapter_error = &#039;&#039;;&lt;br /&gt;
	&lt;br /&gt;
	if not is_set (chapter) then&lt;br /&gt;
		chapter = &#039;&#039;;															-- to be safe for concatenation&lt;br /&gt;
	else&lt;br /&gt;
		if false == no_quotes then&lt;br /&gt;
			chapter = kern_quotes (chapter);									-- if necessary, separate chapter title&#039;s leading and trailing quote marks from Module provided quote marks&lt;br /&gt;
			chapter = wrap_style (&#039;quoted-title&#039;, chapter);&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	chapter = script_concatenate (chapter, scriptchapter)						-- &amp;lt;bdi&amp;gt; tags, lang atribute, categorization, etc; must be done after title is wrapped&lt;br /&gt;
&lt;br /&gt;
	if is_set (transchapter) then&lt;br /&gt;
		transchapter = wrap_style (&#039;trans-quoted-title&#039;, transchapter);&lt;br /&gt;
		if is_set (chapter) then&lt;br /&gt;
			chapter = chapter ..  &#039; &#039; .. transchapter;&lt;br /&gt;
		else																	-- here when transchapter without chapter or script-chapter&lt;br /&gt;
			chapter = transchapter;												-- &lt;br /&gt;
			chapter_error = &#039; &#039; .. set_error (&#039;trans_missing_title&#039;, {&#039;chapter&#039;});&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set (chapterurl) then&lt;br /&gt;
		chapter = external_link (chapterurl, chapter, chapter_url_source, access);		-- adds bare_url_missing_title error if appropriate&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return chapter .. chapter_error;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; H A S _ I N V I S I B L E _ C H A R S &amp;gt;----------------------------------------&lt;br /&gt;
&lt;br /&gt;
This function searches a parameter&#039;s value for nonprintable or invisible characters.  The search stops at the&lt;br /&gt;
first match.&lt;br /&gt;
&lt;br /&gt;
This function will detect the visible replacement character when it is part of the wikisource.&lt;br /&gt;
&lt;br /&gt;
Detects but ignores nowiki and math stripmarkers.  Also detects other named stripmarkers (gallery, math, pre, ref)&lt;br /&gt;
and identifies them with a slightly different error message.  See also coins_cleanup().&lt;br /&gt;
&lt;br /&gt;
Detects but ignores the character pattern that results from the transclusion of {{&#039;}} templates.&lt;br /&gt;
&lt;br /&gt;
Output of this function is an error message that identifies the character or the Unicode group, or the stripmarker&lt;br /&gt;
that was detected along with its position (or, for multi-byte characters, the position of its first byte) in the&lt;br /&gt;
parameter value.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function has_invisible_chars (param, v)&lt;br /&gt;
	local position = &#039;&#039;;														-- position of invisible char or starting position of stripmarker&lt;br /&gt;
	local dummy;																-- end of matching string; not used but required to hold end position when a capture is returned&lt;br /&gt;
	local capture;																-- used by stripmarker detection to hold name of the stripmarker&lt;br /&gt;
	local i=1;&lt;br /&gt;
	local stripmarker, apostrophe;&lt;br /&gt;
	&lt;br /&gt;
	capture = string.match (v, &#039;[%w%p ]*&#039;);										-- Test for values that are simple ASCII text and bypass other tests if true&lt;br /&gt;
	if capture == v then														-- if same there are no unicode characters&lt;br /&gt;
		return;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	while cfg.invisible_chars[i] do&lt;br /&gt;
		local char=cfg.invisible_chars[i][1]									-- the character or group name&lt;br /&gt;
		local pattern=cfg.invisible_chars[i][2]									-- the pattern used to find it&lt;br /&gt;
		position, dummy, capture = mw.ustring.find (v, pattern)					-- see if the parameter value contains characters that match the pattern&lt;br /&gt;
		&lt;br /&gt;
		if position and (char == &#039;zero width joiner&#039;) then						-- if we found a zero width joiner character&lt;br /&gt;
			if mw.ustring.find (v, cfg.indic_script) then						-- its ok if one of the indic scripts&lt;br /&gt;
				position = nil;													-- unset position&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		if position then&lt;br /&gt;
			if &#039;nowiki&#039; == capture or &#039;math&#039; == capture then 					-- nowiki, math stripmarker (not an error condition)&lt;br /&gt;
				stripmarker = true;												-- set a flag&lt;br /&gt;
			elseif true == stripmarker and &#039;delete&#039; == char then				-- because stripmakers begin and end with the delete char, assume that we&#039;ve found one end of a stripmarker&lt;br /&gt;
				position = nil;													-- unset&lt;br /&gt;
			else&lt;br /&gt;
				local err_msg;&lt;br /&gt;
				if capture then&lt;br /&gt;
					err_msg = capture .. &#039; &#039; .. char;&lt;br /&gt;
				else&lt;br /&gt;
					err_msg = char .. &#039; &#039; .. &#039;character&#039;;&lt;br /&gt;
				end&lt;br /&gt;
&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;invisible_char&#039;, {err_msg, wrap_style (&#039;parameter&#039;, param), position}, true ) } );	-- add error message&lt;br /&gt;
				return;															-- and done with this parameter&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		i=i+1;																	-- bump our index&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; A R G U M E N T _ W R A P P E R &amp;gt;----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Argument wrapper.  This function provides support for argument mapping defined in the configuration file so that&lt;br /&gt;
multiple names can be transparently aliased to single internal variable.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function argument_wrapper( args )&lt;br /&gt;
	local origin = {};&lt;br /&gt;
	&lt;br /&gt;
	return setmetatable({&lt;br /&gt;
		ORIGIN = function( self, k )&lt;br /&gt;
			local dummy = self[k]; --force the variable to be loaded.&lt;br /&gt;
			return origin[k];&lt;br /&gt;
		end&lt;br /&gt;
	},&lt;br /&gt;
	{&lt;br /&gt;
		__index = function ( tbl, k )&lt;br /&gt;
			if origin[k] ~= nil then&lt;br /&gt;
				return nil;&lt;br /&gt;
			end&lt;br /&gt;
			&lt;br /&gt;
			local args, list, v = args, cfg.aliases[k];&lt;br /&gt;
			&lt;br /&gt;
			if type( list ) == &#039;table&#039; then&lt;br /&gt;
				v, origin[k] = select_one( args, list, &#039;redundant_parameters&#039; );&lt;br /&gt;
				if origin[k] == nil then&lt;br /&gt;
					origin[k] = &#039;&#039;; -- Empty string, not nil&lt;br /&gt;
				end&lt;br /&gt;
			elseif list ~= nil then&lt;br /&gt;
				v, origin[k] = args[list], list;&lt;br /&gt;
			else&lt;br /&gt;
				-- maybe let through instead of raising an error?&lt;br /&gt;
				-- v, origin[k] = args[k], k;&lt;br /&gt;
				error( cfg.messages[&#039;unknown_argument_map&#039;] );&lt;br /&gt;
			end&lt;br /&gt;
			&lt;br /&gt;
			-- Empty strings, not nil;&lt;br /&gt;
			if v == nil then&lt;br /&gt;
				v = cfg.defaults[k] or &#039;&#039;;&lt;br /&gt;
				origin[k] = &#039;&#039;;&lt;br /&gt;
			end&lt;br /&gt;
			&lt;br /&gt;
			tbl = rawset( tbl, k, v );&lt;br /&gt;
			return v;&lt;br /&gt;
		end,&lt;br /&gt;
	});&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; V A L I D A T E &amp;gt;--------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Looks for a parameter&#039;s name in one of several whitelists.&lt;br /&gt;
&lt;br /&gt;
Parameters in the whitelist can have three values:&lt;br /&gt;
	true - active, supported parameters&lt;br /&gt;
	false - deprecated, supported parameters&lt;br /&gt;
	nil - unsupported parameters&lt;br /&gt;
	&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function validate( name, cite_class )&lt;br /&gt;
	local name = tostring( name );&lt;br /&gt;
	local state;&lt;br /&gt;
	&lt;br /&gt;
	if in_array (cite_class, {&#039;arxiv&#039;, &#039;biorxiv&#039;, &#039;citeseerx&#039;}) then			-- limited parameter sets allowed for these templates&lt;br /&gt;
		state = whitelist.limited_basic_arguments[ name ];&lt;br /&gt;
		if true == state then return true; end									-- valid actively supported parameter&lt;br /&gt;
		if false == state then&lt;br /&gt;
			deprecated_parameter (name);										-- parameter is deprecated but still supported&lt;br /&gt;
			return true;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		if &#039;arxiv&#039; == cite_class then											-- basic parameters unique to these templates&lt;br /&gt;
			state = whitelist.arxiv_basic_arguments[name];&lt;br /&gt;
		end&lt;br /&gt;
		if &#039;biorxiv&#039; == cite_class then&lt;br /&gt;
			state = whitelist.biorxiv_basic_arguments[name];&lt;br /&gt;
		end&lt;br /&gt;
		if &#039;citeseerx&#039; == cite_class then&lt;br /&gt;
			state = whitelist.citeseerx_basic_arguments[name];&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		if true == state then return true; end									-- valid actively supported parameter&lt;br /&gt;
		if false == state then&lt;br /&gt;
			deprecated_parameter (name);										-- parameter is deprecated but still supported&lt;br /&gt;
			return true;&lt;br /&gt;
		end&lt;br /&gt;
																				-- limited enumerated parameters list&lt;br /&gt;
		name = name:gsub( &amp;quot;%d+&amp;quot;, &amp;quot;#&amp;quot; );											-- replace digit(s) with # (last25 becomes last#)&lt;br /&gt;
		state = whitelist.limited_numbered_arguments[ name ];&lt;br /&gt;
		if true == state then return true; end									-- valid actively supported parameter&lt;br /&gt;
		if false == state then&lt;br /&gt;
			deprecated_parameter (name);										-- parameter is deprecated but still supported&lt;br /&gt;
			return true;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		return false;															-- not supported because not found or name is set to nil&lt;br /&gt;
	end																			-- end limited parameter-set templates&lt;br /&gt;
		&lt;br /&gt;
	state = whitelist.basic_arguments[ name ];									-- all other templates; all normal parameters allowed&lt;br /&gt;
											&lt;br /&gt;
	if true == state then return true; end										-- valid actively supported parameter&lt;br /&gt;
	if false == state then&lt;br /&gt;
		deprecated_parameter (name);											-- parameter is deprecated but still supported&lt;br /&gt;
		return true;&lt;br /&gt;
	end&lt;br /&gt;
																				-- all enumerated parameters allowed&lt;br /&gt;
	name = name:gsub( &amp;quot;%d+&amp;quot;, &amp;quot;#&amp;quot; );												-- replace digit(s) with # (last25 becomes last#&lt;br /&gt;
	state = whitelist.numbered_arguments[ name ];&lt;br /&gt;
&lt;br /&gt;
	if true == state then return true; end										-- valid actively supported parameter&lt;br /&gt;
	if false == state then&lt;br /&gt;
		deprecated_parameter (name);											-- parameter is deprecated but still supported&lt;br /&gt;
		return true;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return false;																-- not supported because not found or name is set to nil&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; N O W R A P _ D A T E &amp;gt;--------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
When date is YYYY-MM-DD format wrap in nowrap span: &amp;lt;span ...&amp;gt;YYYY-MM-DD&amp;lt;/span&amp;gt;.  When date is DD MMMM YYYY or is&lt;br /&gt;
MMMM DD, YYYY then wrap in nowrap span: &amp;lt;span ...&amp;gt;DD MMMM&amp;lt;/span&amp;gt; YYYY or &amp;lt;span ...&amp;gt;MMMM DD,&amp;lt;/span&amp;gt; YYYY&lt;br /&gt;
&lt;br /&gt;
DOES NOT yet support MMMM YYYY or any of the date ranges.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function nowrap_date (date)&lt;br /&gt;
	local cap=&#039;&#039;;&lt;br /&gt;
	local cap2=&#039;&#039;;&lt;br /&gt;
&lt;br /&gt;
	if date:match(&amp;quot;^%d%d%d%d%-%d%d%-%d%d$&amp;quot;) then&lt;br /&gt;
		date = substitute (cfg.presentation[&#039;nowrap1&#039;], date);&lt;br /&gt;
	&lt;br /&gt;
	elseif date:match(&amp;quot;^%a+%s*%d%d?,%s+%d%d%d%d$&amp;quot;) or date:match (&amp;quot;^%d%d?%s*%a+%s+%d%d%d%d$&amp;quot;) then&lt;br /&gt;
		cap, cap2 = string.match (date, &amp;quot;^(.*)%s+(%d%d%d%d)$&amp;quot;);&lt;br /&gt;
		date = substitute (cfg.presentation[&#039;nowrap2&#039;], {cap, cap2});&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return date;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E T _ T I T L E T Y P E &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
This function sets default title types (equivalent to the citation including |type=&amp;lt;default value&amp;gt;) for those templates that have defaults.&lt;br /&gt;
Also handles the special case where it is desirable to omit the title type from the rendered citation (|type=none).&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function set_titletype (cite_class, title_type)&lt;br /&gt;
	if is_set(title_type) then&lt;br /&gt;
		if &amp;quot;none&amp;quot; == title_type then&lt;br /&gt;
			title_type = &amp;quot;&amp;quot;;													-- if |type=none then type parameter not displayed&lt;br /&gt;
		end&lt;br /&gt;
		return title_type;														-- if |type= has been set to any other value use that value&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return cfg.title_types [cite_class] or &#039;&#039;;									-- set template&#039;s default title type; else empty string for concatenation&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; H Y P H E N _ T O _ D A S H &amp;gt;--------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Converts a hyphen to a dash&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function hyphen_to_dash( str )&lt;br /&gt;
	if not is_set(str) or str:match( &amp;quot;[%[%]{}&amp;lt;&amp;gt;]&amp;quot; ) ~= nil then&lt;br /&gt;
		return str;&lt;br /&gt;
	end	&lt;br /&gt;
	return str:gsub( &#039;-&#039;, &#039;–&#039; );&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S A F E _ J O I N &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Joins a sequence of strings together while checking for duplicate separation characters.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function safe_join( tbl, duplicate_char )&lt;br /&gt;
	--[[&lt;br /&gt;
	Note: we use string functions here, rather than ustring functions.&lt;br /&gt;
	&lt;br /&gt;
	This has considerably faster performance and should work correctly as &lt;br /&gt;
	long as the duplicate_char is strict ASCII.  The strings&lt;br /&gt;
	in tbl may be ASCII or UTF8.&lt;br /&gt;
	]]&lt;br /&gt;
	&lt;br /&gt;
	local str = &#039;&#039;;																-- the output string&lt;br /&gt;
	local comp = &#039;&#039;;															-- what does &#039;comp&#039; mean?&lt;br /&gt;
	local end_chr = &#039;&#039;;&lt;br /&gt;
	local trim;&lt;br /&gt;
	for _, value in ipairs( tbl ) do&lt;br /&gt;
		if value == nil then value = &#039;&#039;; end&lt;br /&gt;
		&lt;br /&gt;
		if str == &#039;&#039; then														-- if output string is empty&lt;br /&gt;
			str = value;														-- assign value to it (first time through the loop)&lt;br /&gt;
		elseif value ~= &#039;&#039; then&lt;br /&gt;
			if value:sub(1,1) == &#039;&amp;lt;&#039; then										-- Special case of values enclosed in spans and other markup.&lt;br /&gt;
				comp = value:gsub( &amp;quot;%b&amp;lt;&amp;gt;&amp;quot;, &amp;quot;&amp;quot; );								-- remove html markup (&amp;lt;span&amp;gt;string&amp;lt;/span&amp;gt; -&amp;gt; string)&lt;br /&gt;
			else&lt;br /&gt;
				comp = value;&lt;br /&gt;
			end&lt;br /&gt;
																				-- typically duplicate_char is sepc&lt;br /&gt;
			if comp:sub(1,1) == duplicate_char then								-- is first charactier same as duplicate_char? why test first character?&lt;br /&gt;
																				--   Because individual string segments often (always?) begin with terminal punct for th&lt;br /&gt;
																				--   preceding segment: &#039;First element&#039; .. &#039;sepc next element&#039; .. etc?&lt;br /&gt;
				trim = false;&lt;br /&gt;
				end_chr = str:sub(-1,-1);										-- get the last character of the output string&lt;br /&gt;
				-- str = str .. &amp;quot;&amp;lt;HERE(enchr=&amp;quot; .. end_chr.. &amp;quot;)&amp;quot;					-- debug stuff?&lt;br /&gt;
				if end_chr == duplicate_char then								-- if same as separator&lt;br /&gt;
					str = str:sub(1,-2);										-- remove it&lt;br /&gt;
				elseif end_chr == &amp;quot;&#039;&amp;quot; then										-- if it might be wikimarkup&lt;br /&gt;
					if str:sub(-3,-1) == duplicate_char .. &amp;quot;&#039;&#039;&amp;quot; then			-- if last three chars of str are sepc&#039;&#039; &lt;br /&gt;
						str = str:sub(1, -4) .. &amp;quot;&#039;&#039;&amp;quot;;							-- remove them and add back &#039;&#039;&lt;br /&gt;
					elseif str:sub(-5,-1) == duplicate_char .. &amp;quot;]]&#039;&#039;&amp;quot; then		-- if last five chars of str are sepc]]&#039;&#039; &lt;br /&gt;
						trim = true;											-- why? why do this and next differently from previous?&lt;br /&gt;
					elseif str:sub(-4,-1) == duplicate_char .. &amp;quot;]&#039;&#039;&amp;quot; then		-- if last four chars of str are sepc]&#039;&#039; &lt;br /&gt;
						trim = true;											-- same question&lt;br /&gt;
					end&lt;br /&gt;
				elseif end_chr == &amp;quot;]&amp;quot; then										-- if it might be wikimarkup&lt;br /&gt;
					if str:sub(-3,-1) == duplicate_char .. &amp;quot;]]&amp;quot; then			-- if last three chars of str are sepc]] wikilink &lt;br /&gt;
						trim = true;&lt;br /&gt;
					elseif str:sub(-3,-1) == duplicate_char .. &#039;&amp;quot;]&#039; then		-- if last three chars of str are sepc&amp;quot;] quoted external link &lt;br /&gt;
						trim = true;&lt;br /&gt;
					elseif str:sub(-2,-1) == duplicate_char .. &amp;quot;]&amp;quot; then			-- if last two chars of str are sepc] external link&lt;br /&gt;
						trim = true;&lt;br /&gt;
					elseif str:sub(-4,-1) == duplicate_char .. &amp;quot;&#039;&#039;]&amp;quot; then		-- normal case when |url=something &amp;amp; |title=Title.&lt;br /&gt;
						trim = true;&lt;br /&gt;
					end&lt;br /&gt;
				elseif end_chr == &amp;quot; &amp;quot; then										-- if last char of output string is a space&lt;br /&gt;
					if str:sub(-2,-1) == duplicate_char .. &amp;quot; &amp;quot; then				-- if last two chars of str are &amp;lt;sepc&amp;gt;&amp;lt;space&amp;gt;&lt;br /&gt;
						str = str:sub(1,-3);									-- remove them both&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
&lt;br /&gt;
				if trim then&lt;br /&gt;
					if value ~= comp then 										-- value does not equal comp when value contains html markup&lt;br /&gt;
						local dup2 = duplicate_char;&lt;br /&gt;
						if dup2:match( &amp;quot;%A&amp;quot; ) then dup2 = &amp;quot;%&amp;quot; .. dup2; end		-- if duplicate_char not a letter then escape it&lt;br /&gt;
						&lt;br /&gt;
						value = value:gsub( &amp;quot;(%b&amp;lt;&amp;gt;)&amp;quot; .. dup2, &amp;quot;%1&amp;quot;, 1 )			-- remove duplicate_char if it follows html markup&lt;br /&gt;
					else&lt;br /&gt;
						value = value:sub( 2, -1 );								-- remove duplicate_char when it is first character&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			str = str .. value;													--add it to the output string&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return str;&lt;br /&gt;
end  &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ S U F F I X &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
returns true is suffix is properly formed Jr, Sr, or ordinal in the range 2–9.  Puncutation not allowed.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_suffix (suffix)&lt;br /&gt;
	if in_array (suffix, {&#039;Jr&#039;, &#039;Sr&#039;, &#039;2nd&#039;, &#039;3rd&#039;}) or suffix:match (&#039;^%dth$&#039;) then&lt;br /&gt;
		return true;&lt;br /&gt;
	end&lt;br /&gt;
	return false;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ G O O D _ V A N C _ N A M E &amp;gt;--------------------------------------------&lt;br /&gt;
&lt;br /&gt;
For Vancouver Style, author/editor names are supposed to be rendered in Latin (read ASCII) characters.  When a name&lt;br /&gt;
uses characters that contain diacritical marks, those characters are to converted to the corresponding Latin character.&lt;br /&gt;
When a name is written using a non-Latin alphabet or logogram, that name is to be transliterated into Latin characters.&lt;br /&gt;
These things are not currently possible in this module so are left to the editor to do.&lt;br /&gt;
&lt;br /&gt;
This test allows |first= and |last= names to contain any of the letters defined in the four Unicode Latin character sets&lt;br /&gt;
	[http://www.unicode.org/charts/PDF/U0000.pdf C0 Controls and Basic Latin] 0041–005A, 0061–007A&lt;br /&gt;
	[http://www.unicode.org/charts/PDF/U0080.pdf C1 Controls and Latin-1 Supplement] 00C0–00D6, 00D8–00F6, 00F8–00FF&lt;br /&gt;
	[http://www.unicode.org/charts/PDF/U0100.pdf Latin Extended-A] 0100–017F&lt;br /&gt;
	[http://www.unicode.org/charts/PDF/U0180.pdf Latin Extended-B] 0180–01BF, 01C4–024F&lt;br /&gt;
&lt;br /&gt;
|lastn= also allowed to contain hyphens, spaces, and apostrophes. (http://www.ncbi.nlm.nih.gov/books/NBK7271/box/A35029/)&lt;br /&gt;
|firstn= also allowed to contain hyphens, spaces, apostrophes, and periods&lt;br /&gt;
&lt;br /&gt;
This original test:&lt;br /&gt;
	if nil == mw.ustring.find (last, &amp;quot;^[A-Za-zÀ-ÖØ-öø-ƿǄ-ɏ%-%s%&#039;]*$&amp;quot;) or nil == mw.ustring.find (first, &amp;quot;^[A-Za-zÀ-ÖØ-öø-ƿǄ-ɏ%-%s%&#039;%.]+[2-6%a]*$&amp;quot;) then&lt;br /&gt;
was written ouside of the code editor and pasted here because the code editor gets confused between character insertion point and cursor position.&lt;br /&gt;
The test has been rewritten to use decimal character escape sequence for the individual bytes of the unicode characters so that it is not necessary&lt;br /&gt;
to use an external editor to maintain this code.&lt;br /&gt;
&lt;br /&gt;
	\195\128-\195\150 – À-Ö (U+00C0–U+00D6 – C0 controls)&lt;br /&gt;
	\195\152-\195\182 – Ø-ö (U+00D8-U+00F6 – C0 controls)&lt;br /&gt;
	\195\184-\198\191 – ø-ƿ (U+00F8-U+01BF – C0 controls, Latin extended A &amp;amp; B)&lt;br /&gt;
	\199\132-\201\143 – Ǆ-ɏ (U+01C4-U+024F – Latin extended B)&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_good_vanc_name (last, first)&lt;br /&gt;
	local first, suffix = first:match (&#039;(.-),?%s*([%dJS][%drndth]+)%.?$&#039;) or first;		-- if first has something that looks like a generational suffix, get it&lt;br /&gt;
&lt;br /&gt;
	if is_set (suffix) then&lt;br /&gt;
		if not is_suffix (suffix) then&lt;br /&gt;
			add_vanc_error (&#039;suffix&#039;);&lt;br /&gt;
			return false;														-- not a name with an appropriate suffix&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if nil == mw.ustring.find (last, &amp;quot;^[A-Za-z\195\128-\195\150\195\152-\195\182\195\184-\198\191\199\132-\201\143%-%s%&#039;]*$&amp;quot;) or&lt;br /&gt;
		nil == mw.ustring.find (first, &amp;quot;^[A-Za-z\195\128-\195\150\195\152-\195\182\195\184-\198\191\199\132-\201\143%-%s%&#039;%.]*$&amp;quot;) then&lt;br /&gt;
			add_vanc_error (&#039;non-Latin character&#039;);&lt;br /&gt;
			return false;														-- not a string of latin characters; Vancouver requires Romanization&lt;br /&gt;
	end;&lt;br /&gt;
	return true;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; R E D U C E _ T O _ I N I T I A L S &amp;gt;------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Attempts to convert names to initials in support of |name-list-format=vanc.  &lt;br /&gt;
&lt;br /&gt;
Names in |firstn= may be separated by spaces or hyphens, or for initials, a period. See http://www.ncbi.nlm.nih.gov/books/NBK7271/box/A35062/.&lt;br /&gt;
&lt;br /&gt;
Vancouver style requires family rank designations (Jr, II, III, etc) to be rendered as Jr, 2nd, 3rd, etc.  See http://www.ncbi.nlm.nih.gov/books/NBK7271/box/A35085/.&lt;br /&gt;
This code only accepts and understands generational suffix in the Vancouver format because Roman numerals look like, and can be mistaken for, initials.&lt;br /&gt;
&lt;br /&gt;
This function uses ustring functions because firstname initials may be any of the unicode Latin characters accepted by is_good_vanc_name ().&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function reduce_to_initials(first)&lt;br /&gt;
	local name, suffix = mw.ustring.match(first, &amp;quot;^(%u+) ([%dJS][%drndth]+)$&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
	if not name then															-- if not initials and a suffix&lt;br /&gt;
		name = mw.ustring.match(first, &amp;quot;^(%u+)$&amp;quot;);								-- is it just intials?&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if name then																-- if first is initials with or without suffix&lt;br /&gt;
		if 3 &amp;gt; mw.ustring.len (name) then										-- if one or two initials&lt;br /&gt;
			if suffix then														-- if there is a suffix&lt;br /&gt;
				if is_suffix (suffix) then										-- is it legitimate?&lt;br /&gt;
					return first;												-- one or two initials and a valid suffix so nothing to do&lt;br /&gt;
				else&lt;br /&gt;
					add_vanc_error (&#039;suffix&#039;);									-- one or two initials with invalid suffix so error message&lt;br /&gt;
					return first;												-- and return first unmolested&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				return first;													-- one or two initials without suffix; nothing to do&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end																			-- if here then name has 3 or more uppercase letters so treat them as a word&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
	local initials, names = {}, {};												-- tables to hold name parts and initials&lt;br /&gt;
	local i = 1;																-- counter for number of initials&lt;br /&gt;
&lt;br /&gt;
	names = mw.text.split (first, &#039;[%s,]+&#039;);									-- split into a table of names and possible suffix&lt;br /&gt;
&lt;br /&gt;
	while names[i] do															-- loop through the table&lt;br /&gt;
		if 1 &amp;lt; i and names[i]:match (&#039;[%dJS][%drndth]+%.?$&#039;) then				-- if not the first name, and looks like a suffix (may have trailing dot)&lt;br /&gt;
			names[i] = names[i]:gsub (&#039;%.&#039;, &#039;&#039;);								-- remove terminal dot if present&lt;br /&gt;
			if is_suffix (names[i]) then										-- if a legitimate suffix&lt;br /&gt;
				table.insert (initials, &#039; &#039; .. names[i]);						-- add a separator space, insert at end of initials table&lt;br /&gt;
				break;															-- and done because suffix must fall at the end of a name&lt;br /&gt;
			end																	-- no error message if not a suffix; possibly because of Romanization&lt;br /&gt;
		end&lt;br /&gt;
		if 3 &amp;gt; i then&lt;br /&gt;
			table.insert (initials, mw.ustring.sub(names[i],1,1));				-- insert the intial at end of initials table&lt;br /&gt;
		end&lt;br /&gt;
		i = i+1;																-- bump the counter&lt;br /&gt;
	end&lt;br /&gt;
			&lt;br /&gt;
	return table.concat(initials)												-- Vancouver format does not include spaces.&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; L I S T  _ P E O P L E &amp;gt;-------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Formats a list of people (e.g. authors / editors) &lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function list_people(control, people, etal)&lt;br /&gt;
	local sep;&lt;br /&gt;
	local namesep;&lt;br /&gt;
	local format = control.format&lt;br /&gt;
	local maximum = control.maximum&lt;br /&gt;
	local lastauthoramp = control.lastauthoramp;&lt;br /&gt;
	local text = {}&lt;br /&gt;
&lt;br /&gt;
	if &#039;vanc&#039; == format then													-- Vancouver-like author/editor name styling?&lt;br /&gt;
		sep = &#039;,&#039;;																-- name-list separator between authors is a comma&lt;br /&gt;
		namesep = &#039; &#039;;															-- last/first separator is a space&lt;br /&gt;
	else&lt;br /&gt;
		sep = &#039;;&#039;																-- name-list separator between authors is a semicolon&lt;br /&gt;
		namesep = &#039;, &#039;															-- last/first separator is &amp;lt;comma&amp;gt;&amp;lt;space&amp;gt;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if sep:sub(-1,-1) ~= &amp;quot; &amp;quot; then sep = sep .. &amp;quot; &amp;quot; end&lt;br /&gt;
	if is_set (maximum) and maximum &amp;lt; 1 then return &amp;quot;&amp;quot;, 0; end					-- returned 0 is for EditorCount; not used for authors&lt;br /&gt;
	&lt;br /&gt;
	for i,person in ipairs(people) do&lt;br /&gt;
		if is_set(person.last) then&lt;br /&gt;
			local mask = person.mask&lt;br /&gt;
			local one&lt;br /&gt;
			local sep_one = sep;&lt;br /&gt;
			if is_set (maximum) and i &amp;gt; maximum then&lt;br /&gt;
				etal = true;&lt;br /&gt;
				break;&lt;br /&gt;
			elseif (mask ~= nil) then&lt;br /&gt;
				local n = tonumber(mask)&lt;br /&gt;
				if (n ~= nil) then&lt;br /&gt;
					one = string.rep(&amp;quot;&amp;amp;mdash;&amp;quot;,n)&lt;br /&gt;
				else&lt;br /&gt;
					one = mask;&lt;br /&gt;
					sep_one = &amp;quot; &amp;quot;;&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				one = person.last&lt;br /&gt;
				local first = person.first&lt;br /&gt;
				if is_set(first) then&lt;br /&gt;
					if ( &amp;quot;vanc&amp;quot; == format ) then								-- if vancouver format&lt;br /&gt;
						one = one:gsub (&#039;%.&#039;, &#039;&#039;);								-- remove periods from surnames (http://www.ncbi.nlm.nih.gov/books/NBK7271/box/A35029/)&lt;br /&gt;
						if not person.corporate and is_good_vanc_name (one, first) then		-- and name is all Latin characters; corporate authors not tested&lt;br /&gt;
							first = reduce_to_initials(first)					-- attempt to convert first name(s) to initials&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
					one = one .. namesep .. first;&lt;br /&gt;
				end&lt;br /&gt;
				if is_set(person.link) and person.link ~= control.page_name then&lt;br /&gt;
					one = make_wikilink (person.link, one);						-- link author/editor if this page is not the author&#039;s/editor&#039;s page&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			table.insert( text, one )&lt;br /&gt;
			table.insert( text, sep_one )&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local count = #text / 2;													-- (number of names + number of separators) divided by 2&lt;br /&gt;
	if count &amp;gt; 0 then &lt;br /&gt;
		if count &amp;gt; 1 and is_set(lastauthoramp) and not etal then&lt;br /&gt;
			text[#text-2] = &amp;quot; &amp;amp; &amp;quot;;												-- replace last separator with ampersand text&lt;br /&gt;
		end&lt;br /&gt;
		text[#text] = nil;														-- erase the last separator&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local result = table.concat(text)											-- construct list&lt;br /&gt;
	if etal and is_set (result) then											-- etal may be set by |display-authors=etal but we might not have a last-first list&lt;br /&gt;
		result = result .. sep .. &#039; &#039; .. cfg.messages[&#039;et al&#039;];					-- we&#039;ve go a last-first list and etal so add et al.&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return result, count&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; A N C H O R _ I D &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Generates a CITEREF anchor ID if we have at least one name or a date.  Otherwise returns an empty string.&lt;br /&gt;
&lt;br /&gt;
namelist is one of the contributor-, author-, or editor-name lists chosen in that order.  year is Year or anchor_year.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
local function anchor_id (namelist, year)&lt;br /&gt;
	local names={};																-- a table for the one to four names and year&lt;br /&gt;
	for i,v in ipairs (namelist) do												-- loop through the list and take up to the first four last names&lt;br /&gt;
		names[i] = v.last &lt;br /&gt;
		if i == 4 then break end												-- if four then done&lt;br /&gt;
	end&lt;br /&gt;
	table.insert (names, year);													-- add the year at the end&lt;br /&gt;
	local id = table.concat(names);												-- concatenate names and year for CITEREF id&lt;br /&gt;
	if is_set (id) then															-- if concatenation is not an empty string&lt;br /&gt;
		return &amp;quot;CITEREF&amp;quot; .. id;													-- add the CITEREF portion&lt;br /&gt;
	else&lt;br /&gt;
		return &#039;&#039;;																-- return an empty string; no reason to include CITEREF id in this citation&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; N A M E _ H A S _ E T A L &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Evaluates the content of author and editor name parameters for variations on the theme of et al.  If found,&lt;br /&gt;
the et al. is removed, a flag is set to true and the function returns the modified name and the flag.&lt;br /&gt;
&lt;br /&gt;
This function never sets the flag to false but returns it&#039;s previous state because it may have been set by&lt;br /&gt;
previous passes through this function or by the parameters |display-authors=etal or |display-editors=etal&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function name_has_etal (name, etal, nocat)&lt;br /&gt;
&lt;br /&gt;
	if is_set (name) then														-- name can be nil in which case just return&lt;br /&gt;
		local etal_pattern = &amp;quot;[;,]? *[\&amp;quot;&#039;]*%f[%a][Ee][Tt] *[Aa][Ll][%.\&amp;quot;&#039;]*$&amp;quot;	-- variations on the &#039;et al&#039; theme&lt;br /&gt;
		local others_pattern = &amp;quot;[;,]? *%f[%a]and [Oo]thers&amp;quot;;					-- and alternate to et al.&lt;br /&gt;
		&lt;br /&gt;
		if name:match (etal_pattern) then										-- variants on et al.&lt;br /&gt;
			name = name:gsub (etal_pattern, &#039;&#039;);								-- if found, remove&lt;br /&gt;
			etal = true;														-- set flag (may have been set previously here or by |display-authors=etal)&lt;br /&gt;
			if not nocat then													-- no categorization for |vauthors=&lt;br /&gt;
				add_maint_cat (&#039;etal&#039;);											-- and add a category if not already added&lt;br /&gt;
			end&lt;br /&gt;
		elseif name:match (others_pattern) then									-- if not &#039;et al.&#039;, then &#039;and others&#039;?&lt;br /&gt;
			name = name:gsub (others_pattern, &#039;&#039;);								-- if found, remove&lt;br /&gt;
			etal = true;														-- set flag (may have been set previously here or by |display-authors=etal)&lt;br /&gt;
			if not nocat then													-- no categorization for |vauthors=&lt;br /&gt;
				add_maint_cat (&#039;etal&#039;);											-- and add a category if not already added&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return name, etal;															-- &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; N A M E _ H A S _ E D _ M A R K U P &amp;gt;------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Evaluates the content of author and editor parameters for extranious editor annotations: ed, ed., eds, (Ed.), etc.&lt;br /&gt;
These annotation do not belong in author parameters and are redundant in editor parameters.  If found, the function&lt;br /&gt;
adds the editor markup maintenance category.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function name_has_ed_markup (name, list_name)&lt;br /&gt;
	local _, pattern;&lt;br /&gt;
	local patterns = {															-- these patterns match annotations at end of name&lt;br /&gt;
		&#039;%f[%(%[][%(%[]%s*[Ee][Dd][Ss]?%.?%s*[%)%]]?$&#039;,							-- (ed) or (eds): leading &#039;(&#039;, case insensitive &#039;ed&#039;, optional &#039;s&#039;, &#039;.&#039; and/or &#039;)&#039;&lt;br /&gt;
		&#039;[,%.%s]%f[e]eds?%.?$&#039;,													-- ed or eds: without &#039;(&#039;or &#039;)&#039;; case sensitive (ED could be initials Ed could be name)&lt;br /&gt;
		&#039;%f[%(%[][%(%[]%s*[Ee][Dd][Ii][Tt][Oo][Rr][Ss]?%.?%s*[%)%]]?$&#039;,			-- (editor) or (editors): leading &#039;(&#039;, case insensitive, optional &#039;.&#039; and/or &#039;)&#039;&lt;br /&gt;
		&#039;[,%.%s]%f[Ee][Ee][Dd][Ii][Tt][Oo][Rr][Ss]?%.?$&#039;,						-- editor or editors: without &#039;(&#039;or &#039;)&#039;; case insensitive&lt;br /&gt;
		&lt;br /&gt;
																				-- these patterns match annotations at beginning of name&lt;br /&gt;
		&#039;^eds?[%.,;]&#039;,															-- ed. or eds.: lower case only, optional &#039;s&#039;, requires &#039;.&#039;&lt;br /&gt;
		&#039;^[%(%[]%s*[Ee][Dd][Ss]?%.?%s*[%)%]]&#039;,									-- (ed) or (eds): also sqare brackets, case insensitive, optional &#039;s&#039;, &#039;.&#039;&lt;br /&gt;
		&#039;^[%(%[]?%s*[Ee][Dd][Ii][Tt][Oo][Rr][Ss]?%A&#039;,							-- (editor or (editors: also sq brackets, case insensitive, optional brackets, &#039;s&#039;&lt;br /&gt;
		&#039;^[%(%[]?%s*[Ee][Dd][Ii][Tt][Ee][Dd]%A&#039;,								-- (edited: also sq brackets, case insensitive, optional brackets&lt;br /&gt;
		}&lt;br /&gt;
&lt;br /&gt;
	if is_set (name) then&lt;br /&gt;
		for _, pattern in ipairs (patterns) do									-- spin through patterns table and&lt;br /&gt;
			if name:match (pattern) then&lt;br /&gt;
				add_maint_cat (&#039;extra_text_names&#039;, cfg.special_case_translation [list_name]);	-- add a maint cat for this template&lt;br /&gt;
				break;&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return name;																-- and done&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; N A M E _ H A S _ M U L T _ N A M E S &amp;gt;----------------------------------------&lt;br /&gt;
&lt;br /&gt;
Evaluates the content of author and editor (surnames only) parameters for multiple names.  Multiple names are&lt;br /&gt;
indicated if there is more than one comma and or semicolon.  If found, the function adds the multiple name&lt;br /&gt;
(author or editor) maintenance category.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function name_has_mult_names (name, list_name)&lt;br /&gt;
local count, _;&lt;br /&gt;
	if is_set (name) then&lt;br /&gt;
		_, count = name:gsub (&#039;[;,]&#039;, &#039;&#039;);										-- count the number of separator-like characters&lt;br /&gt;
		&lt;br /&gt;
		if 1 &amp;lt; count then														-- param could be |author= or |editor= so one separator character is acceptable&lt;br /&gt;
			add_maint_cat (&#039;mult_names&#039;, cfg.special_case_translation [list_name]);	-- more than one separator indicates multiple names so add a maint cat for this template&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return name;																-- and done&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; N A M E _ C H E C K S &amp;gt;--------------------------------------------------------&lt;br /&gt;
This function calls various name checking functions used to validate the content of the various name-holding&lt;br /&gt;
parameters.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function name_checks (last, first, list_name)&lt;br /&gt;
	if is_set (last) then&lt;br /&gt;
		if last:match (&#039;^%(%(.*%)%)$&#039;) then										-- if wrapped in doubled parentheses, accept as written &lt;br /&gt;
			last = last:match (&#039;^%(%((.*)%)%)$&#039;);								-- strip parens&lt;br /&gt;
		else&lt;br /&gt;
			last = name_has_mult_names (last, list_name);						-- check for multiple names in the parameter (last only)&lt;br /&gt;
			last = name_has_ed_markup (last, list_name);						-- check for extraneous &#039;editor&#039; annotation&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if is_set (first) then&lt;br /&gt;
		if first:match (&#039;^%(%(.*%)%)$&#039;) then									-- if wrapped in doubled parentheses, accept as written &lt;br /&gt;
			first = first:match (&#039;^%(%((.*)%)%)$&#039;);								-- strip parens&lt;br /&gt;
		else&lt;br /&gt;
			first = name_has_ed_markup (first, list_name);						-- check for extraneous &#039;editor&#039; annotation&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return last, first;															-- done&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; E X T R A C T _ N A M E S &amp;gt;----------------------------------------------------&lt;br /&gt;
Gets name list from the input arguments&lt;br /&gt;
&lt;br /&gt;
Searches through args in sequential order to find |lastn= and |firstn= parameters (or their aliases), and their matching link and mask parameters.&lt;br /&gt;
Stops searching when both |lastn= and |firstn= are not found in args after two sequential attempts: found |last1=, |last2=, and |last3= but doesn&#039;t&lt;br /&gt;
find |last4= and |last5= then the search is done.&lt;br /&gt;
&lt;br /&gt;
This function emits an error message when there is a |firstn= without a matching |lastn=.  When there are &#039;holes&#039; in the list of last names, |last1= and |last3=&lt;br /&gt;
are present but |last2= is missing, an error message is emitted. |lastn= is not required to have a matching |firstn=.&lt;br /&gt;
&lt;br /&gt;
When an author or editor parameter contains some form of &#039;et al.&#039;, the &#039;et al.&#039; is stripped from the parameter and a flag (etal) returned&lt;br /&gt;
that will cause list_people() to add the static &#039;et al.&#039; text from Module:Citation/CS1/Configuration.  This keeps &#039;et al.&#039; out of the &lt;br /&gt;
template&#039;s metadata.  When this occurs, the page is added to a maintenance category.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function extract_names(args, list_name)&lt;br /&gt;
	local names = {};			-- table of names&lt;br /&gt;
	local last;					-- individual name components&lt;br /&gt;
	local first;&lt;br /&gt;
	local link;&lt;br /&gt;
	local mask;&lt;br /&gt;
	local i = 1;				-- loop counter/indexer&lt;br /&gt;
	local n = 1;				-- output table indexer&lt;br /&gt;
	local count = 0;			-- used to count the number of times we haven&#039;t found a |last= (or alias for authors, |editor-last or alias for editors)&lt;br /&gt;
	local etal=false;			-- return value set to true when we find some form of et al. in an author parameter&lt;br /&gt;
&lt;br /&gt;
	local err_msg_list_name = list_name:match (&amp;quot;(%w+)List&amp;quot;) .. &#039;s list&#039;;		-- modify AuthorList or EditorList for use in error messages if necessary&lt;br /&gt;
	while true do&lt;br /&gt;
		last = select_one( args, cfg.aliases[list_name .. &#039;-Last&#039;], &#039;redundant_parameters&#039;, i );		-- search through args for name components beginning at 1&lt;br /&gt;
		first = select_one( args, cfg.aliases[list_name .. &#039;-First&#039;], &#039;redundant_parameters&#039;, i );&lt;br /&gt;
		link = select_one( args, cfg.aliases[list_name .. &#039;-Link&#039;], &#039;redundant_parameters&#039;, i );&lt;br /&gt;
		mask = select_one( args, cfg.aliases[list_name .. &#039;-Mask&#039;], &#039;redundant_parameters&#039;, i );&lt;br /&gt;
&lt;br /&gt;
		last, etal = name_has_etal (last, etal, false);							-- find and remove variations on et al.&lt;br /&gt;
		first, etal = name_has_etal (first, etal, false);						-- find and remove variations on et al.&lt;br /&gt;
		last, first= name_checks (last, first, list_name);						-- multiple names, extraneous annotation, etc checks&lt;br /&gt;
		&lt;br /&gt;
		if first and not last then												-- if there is a firstn without a matching lastn&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;first_missing_last&#039;, {err_msg_list_name, i}, true ) } );	-- add this error message&lt;br /&gt;
		elseif not first and not last then										-- if both firstn and lastn aren&#039;t found, are we done?&lt;br /&gt;
			count = count + 1;													-- number of times we haven&#039;t found last and first&lt;br /&gt;
			if 2 &amp;lt;= count then													-- two missing names and we give up&lt;br /&gt;
				break;															-- normal exit or there is a two-name hole in the list; can&#039;t tell which&lt;br /&gt;
			end&lt;br /&gt;
		else																	-- we have last with or without a first&lt;br /&gt;
			link_title_ok (link, list_name:match (&amp;quot;(%w+)List&amp;quot;):lower() .. &#039;-link&#039; .. i, last, list_name:match (&amp;quot;(%w+)List&amp;quot;):lower() .. &#039;-last&#039; .. i);	-- check for improper wikimarkup&lt;br /&gt;
&lt;br /&gt;
			names[n] = {last = last, first = first, link = link, mask = mask, corporate=false};	-- add this name to our names list (corporate for |vauthors= only)&lt;br /&gt;
			n = n + 1;															-- point to next location in the names table&lt;br /&gt;
			if 1 == count then													-- if the previous name was missing&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;missing_name&#039;, {err_msg_list_name, i-1}, true ) } );		-- add this error message&lt;br /&gt;
			end&lt;br /&gt;
			count = 0;															-- reset the counter, we&#039;re looking for two consecutive missing names&lt;br /&gt;
		end&lt;br /&gt;
		i = i + 1;																-- point to next args location&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return names, etal;															-- all done, return our list of names&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; G E T _ I S O 6 3 9 _ C O D E &amp;gt;------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Validates language names provided in |language= parameter if not an ISO639-1 or 639-2 code.&lt;br /&gt;
&lt;br /&gt;
Returns the language name and associated two- or three-character code.  Because case of the source may be incorrect&lt;br /&gt;
or different from the case that WikiMedia uses, the name comparisons are done in lower case and when a match is&lt;br /&gt;
found, the Wikimedia version (assumed to be correct) is returned along with the code.  When there is no match, we&lt;br /&gt;
return the original language name string.&lt;br /&gt;
&lt;br /&gt;
mw.language.fetchLanguageNames(&amp;lt;local wiki language&amp;gt;, &#039;all&#039;) returns a list of languages that in some cases may include&lt;br /&gt;
extensions. For example, code &#039;cbk-zam&#039; and its associated name &#039;Chavacano de Zamboanga&#039; (MediaWiki does not support&lt;br /&gt;
code &#039;cbk&#039; or name &#039;Chavacano&#039;.  Most (all?) of these languages are not used a &#039;language&#039; codes per se, rather they&lt;br /&gt;
are used as sub-domain names: cbk-zam.wikipedia.org.  These names can be found (for the time being) at&lt;br /&gt;
https://phabricator.wikimedia.org/diffusion/ECLD/browse/master/LocalNames/LocalNamesEn.php&lt;br /&gt;
&lt;br /&gt;
Names but that are included in the list will be found if that name is provided in the |language= parameter.  For example,&lt;br /&gt;
if |language=Chavacano de Zamboanga, that name will be found with the associated code &#039;cbk-zam&#039;.  When names are found&lt;br /&gt;
and the associated code is not two or three characters, this function returns only the Wikimedia language name.&lt;br /&gt;
&lt;br /&gt;
Adapted from code taken from Module:Check ISO 639-1.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function get_iso639_code (lang, this_wiki_code)&lt;br /&gt;
	local remap = {&lt;br /&gt;
		[&#039;bangla&#039;] = {&#039;Bengali&#039;, &#039;bn&#039;},											-- MediaWiki returns Bangla (the endonym) but we want Bengali (the exonym); here we remap&lt;br /&gt;
		[&#039;bengali&#039;] = {&#039;Bengali&#039;, &#039;bn&#039;},										-- MediaWiki doesn&#039;t use exonym so here we provide correct language name and 639-1 code&lt;br /&gt;
		[&#039;bihari&#039;] = {&#039;Bihari&#039;, &#039;bh&#039;},											-- MediaWiki replace &#039;Bihari&#039; with &#039;Bhojpuri&#039; so &#039;Bihari&#039; cannot be found&lt;br /&gt;
		[&#039;bhojpuri&#039;] = {&#039;Bhojpuri&#039;, &#039;bho&#039;},										-- MediaWiki uses &#039;bh&#039; as a subdomain name for Bhojpuri wWikipedia: bh.wikipedia.org&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	if remap[lang:lower()] then&lt;br /&gt;
		return remap[lang:lower()][1], remap[lang:lower()][2];					-- for this language &#039;name&#039;, return a possibly new name and appropriate code&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local languages = mw.language.fetchLanguageNames(this_wiki_code, &#039;all&#039;)		-- get a list of language names known to Wikimedia&lt;br /&gt;
																				-- (&#039;all&#039; is required for North Ndebele, South Ndebele, and Ojibwa)&lt;br /&gt;
	local langlc = mw.ustring.lower(lang);										-- lower case version for comparisons&lt;br /&gt;
	&lt;br /&gt;
	for code, name in pairs(languages) do										-- scan the list to see if we can find our language&lt;br /&gt;
		if langlc == mw.ustring.lower(name) then&lt;br /&gt;
			if 2 ~= code:len() and 3 ~= code:len() then							-- two- or three-character codes only; extensions not supported&lt;br /&gt;
				return name;													-- so return the name but not the code&lt;br /&gt;
			end&lt;br /&gt;
			return name, code;													-- found it, return name to ensure proper capitalization and the the code&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return lang;																-- not valid language; return language in original case and nil for the code&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; L A N G U A G E _ P A R A M E T E R &amp;gt;------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Gets language name from a provided two- or three-character ISO 639 code.  If a code is recognized by MediaWiki,&lt;br /&gt;
use the returned name; if not, then use the value that was provided with the language parameter.&lt;br /&gt;
&lt;br /&gt;
When |language= contains a recognized language (either code or name), the page is assigned to the category for&lt;br /&gt;
that code: Category:Norwegian-language sources (no).  For valid three-character code languages, the page is assigned&lt;br /&gt;
to the single category for &#039;639-2&#039; codes: Category:CS1 ISO 639-2 language sources.&lt;br /&gt;
&lt;br /&gt;
Languages that are the same as the local wiki are not categorized.  MediaWiki does not recognize three-character&lt;br /&gt;
equivalents of two-character codes: code &#039;ar&#039; is recognized bit code &#039;ara&#039; is not.&lt;br /&gt;
&lt;br /&gt;
This function supports multiple languages in the form |language=nb, French, th where the language names or codes are&lt;br /&gt;
separated from each other by commas.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function language_parameter (lang)&lt;br /&gt;
	local code;																	-- the two- or three-character language code&lt;br /&gt;
	local name;																	-- the language name&lt;br /&gt;
	local language_list = {};													-- table of language names to be rendered&lt;br /&gt;
	local names_table = {};														-- table made from the value assigned to |language=&lt;br /&gt;
&lt;br /&gt;
	local this_wiki = mw.getContentLanguage();									-- get a language object for this wiki&lt;br /&gt;
	local this_wiki_code = this_wiki:getCode()									-- get this wiki&#039;s language code&lt;br /&gt;
	local this_wiki_name = mw.language.fetchLanguageName(this_wiki_code, this_wiki_code);	-- get this wiki&#039;s language name&lt;br /&gt;
&lt;br /&gt;
	local remap = {&lt;br /&gt;
		[&#039;bh&#039;] = &#039;Bihari&#039;,														-- MediaWiki uses &#039;bh&#039; as a subdomain name for Bhojpuri wWikipedia: bh.wikipedia.org&lt;br /&gt;
		[&#039;bn&#039;] = &#039;Bengali&#039;,														-- MediaWiki returns Bangla&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
	names_table = mw.text.split (lang, &#039;%s*,%s*&#039;);								-- names should be a comma separated list&lt;br /&gt;
&lt;br /&gt;
	for _, lang in ipairs (names_table) do										-- reuse lang&lt;br /&gt;
&lt;br /&gt;
		if lang:match (&#039;^%a%a%-&#039;) then											-- strip ietf language tags from code; TODO: is there a need to support 3-char with tag?&lt;br /&gt;
			lang = lang:match (&#039;(%a%a)%-&#039;)										-- keep only 639-1 code portion to lang; TODO: do something with 3166 alpha 2 country code?&lt;br /&gt;
		end&lt;br /&gt;
		if 2 == lang:len() or 3 == lang:len() then								-- if two-or three-character code&lt;br /&gt;
			name = mw.language.fetchLanguageName( lang:lower(), this_wiki_code);	-- get language name if |language= is a proper code&lt;br /&gt;
		end&lt;br /&gt;
	&lt;br /&gt;
		if is_set (name) then													-- if |language= specified a valid code&lt;br /&gt;
			code = lang:lower();												-- save it&lt;br /&gt;
		else&lt;br /&gt;
			name, code = get_iso639_code (lang, this_wiki_code);				-- attempt to get code from name (assign name here so that we are sure of proper capitalization)&lt;br /&gt;
		end&lt;br /&gt;
	&lt;br /&gt;
		if is_set (code) then													-- only 2- or 3-character codes&lt;br /&gt;
			name = remap[code] or name;											-- override wikimedia when they misuse language codes/names&lt;br /&gt;
&lt;br /&gt;
			if this_wiki_code ~= code then										-- when the language is not the same as this wiki&#039;s language&lt;br /&gt;
				if 2 == code:len() then											-- and is a two-character code&lt;br /&gt;
					add_prop_cat (&#039;foreign_lang_source&#039; .. code, {name, code})			-- categorize it&lt;br /&gt;
				else															-- or is a recognized language (but has a three-character code)&lt;br /&gt;
					add_prop_cat (&#039;foreign_lang_source_2&#039; .. code, {code})				-- categorize it differently TODO: support mutliple three-character code categories per cs1|2 template&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			add_maint_cat (&#039;unknown_lang&#039;);										-- add maint category if not already added&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		table.insert (language_list, name);&lt;br /&gt;
		name = &#039;&#039;;																-- so we can reuse it&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	code = #language_list														-- reuse code as number of languages in the list&lt;br /&gt;
	if 2 &amp;gt;= code then&lt;br /&gt;
		name = table.concat (language_list, &#039; and &#039;)							-- insert &#039;&amp;lt;space&amp;gt;and&amp;lt;space&amp;gt;&#039; between two language names&lt;br /&gt;
	elseif 2 &amp;lt; code then&lt;br /&gt;
		language_list[code] = &#039;and &#039; .. language_list[code];					-- prepend last name with &#039;and&amp;lt;space&amp;gt;&#039;&lt;br /&gt;
		name = table.concat (language_list, &#039;, &#039;)								-- and concatenate with &#039;&amp;lt;comma&amp;gt;&amp;lt;space&amp;gt;&#039; separators&lt;br /&gt;
	end&lt;br /&gt;
	if this_wiki_name == name then&lt;br /&gt;
		return &#039;&#039;;																-- if one language and that language is this wiki&#039;s return an empty string (no annotation)&lt;br /&gt;
	end&lt;br /&gt;
	return (&amp;quot; &amp;quot; .. wrap_msg (&#039;language&#039;, name));								-- otherwise wrap with &#039;(in ...)&#039;&lt;br /&gt;
	--[[ TODO: should only return blank or name rather than full list&lt;br /&gt;
	so we can clean up the bunched parenthetical elements Language, Type, Format&lt;br /&gt;
	]]&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E T _ C S 1 _ S T Y L E &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Set style settings for CS1 citation templates. Returns separator and postscript settings&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function set_cs1_style (ps)&lt;br /&gt;
	if not is_set (ps) then														-- unless explicitely set to something&lt;br /&gt;
		ps = &#039;.&#039;;																-- terminate the rendered citation with a period&lt;br /&gt;
	end&lt;br /&gt;
	return &#039;.&#039;, ps;																-- separator is a full stop&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E T _ C S 2 _ S T Y L E &amp;gt;----------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Set style settings for CS2 citation templates. Returns separator, postscript, ref settings&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function set_cs2_style (ps, ref)&lt;br /&gt;
	if not is_set (ps) then														-- if |postscript= has not been set, set cs2 default&lt;br /&gt;
		ps = &#039;&#039;;																-- make sure it isn&#039;t nil&lt;br /&gt;
	end&lt;br /&gt;
	if not is_set (ref) then													-- if |ref= is not set&lt;br /&gt;
		ref = &amp;quot;harv&amp;quot;;															-- set default |ref=harv&lt;br /&gt;
	end&lt;br /&gt;
	return &#039;,&#039;, ps, ref;														-- separator is a comma&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; G E T _ S E T T I N G S _ F R O M _ C I T E _ C L A S S &amp;gt;----------------------&lt;br /&gt;
&lt;br /&gt;
When |mode= is not set or when its value is invalid, use config.CitationClass and parameter values to establish&lt;br /&gt;
rendered style.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function get_settings_from_cite_class (ps, ref, cite_class)&lt;br /&gt;
	local sep;&lt;br /&gt;
	if (cite_class == &amp;quot;citation&amp;quot;) then											-- for citation templates (CS2)&lt;br /&gt;
		sep, ps, ref = set_cs2_style (ps, ref);&lt;br /&gt;
	else																		-- not a citation template so CS1&lt;br /&gt;
		sep, ps = set_cs1_style (ps);&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return sep, ps, ref															-- return them all&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E T _ S T Y L E &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Establish basic style settings to be used when rendering the citation.  Uses |mode= if set and valid or uses&lt;br /&gt;
config.CitationClass from the template&#039;s #invoke: to establish style.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function set_style (mode, ps, ref, cite_class)&lt;br /&gt;
	local sep;&lt;br /&gt;
	if &#039;cs2&#039; == mode then														-- if this template is to be rendered in CS2 (citation) style&lt;br /&gt;
		sep, ps, ref = set_cs2_style (ps, ref);&lt;br /&gt;
	elseif &#039;cs1&#039; == mode then													-- if this template is to be rendered in CS1 (cite xxx) style&lt;br /&gt;
		sep, ps = set_cs1_style (ps);&lt;br /&gt;
	else																		-- anything but cs1 or cs2&lt;br /&gt;
		sep, ps, ref = get_settings_from_cite_class (ps, ref, cite_class);		-- get settings based on the template&#039;s CitationClass&lt;br /&gt;
	end&lt;br /&gt;
	if &#039;none&#039; == ps:lower() then												-- if assigned value is &#039;none&#039; then&lt;br /&gt;
		ps = &#039;&#039;;																-- set to empty string&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return sep, ps, ref&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; I S _ P D F &amp;gt;------------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Determines if a url has the file extension that is one of the pdf file extensions used by [[MediaWiki:Common.css]] when&lt;br /&gt;
applying the pdf icon to external links.&lt;br /&gt;
&lt;br /&gt;
returns true if file extension is one of the recognized extensions, else false&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function is_pdf (url)&lt;br /&gt;
	return url:match (&#039;%.pdf$&#039;) or url:match (&#039;%.PDF$&#039;) or url:match (&#039;%.pdf[%?#]&#039;) or url:match (&#039;%.PDF[%?#]&#039;);&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S T Y L E _ F O R M A T &amp;gt;------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Applies css style to |format=, |chapter-format=, etc.  Also emits an error message if the format parameter does&lt;br /&gt;
not have a matching url parameter.  If the format parameter is not set and the url contains a file extension that&lt;br /&gt;
is recognized as a pdf document by MediaWiki&#039;s commons.css, this code will set the format parameter to (PDF) with&lt;br /&gt;
the appropriate styling.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function style_format (format, url, fmt_param, url_param)&lt;br /&gt;
	if is_set (format) then&lt;br /&gt;
		format = wrap_style (&#039;format&#039;, format);									-- add leading space, parentheses, resize&lt;br /&gt;
		if not is_set (url) then&lt;br /&gt;
			format = format .. set_error( &#039;format_missing_url&#039;, {fmt_param, url_param} );	-- add an error message&lt;br /&gt;
		end&lt;br /&gt;
	elseif is_pdf (url) then													-- format is not set so if url is a pdf file then&lt;br /&gt;
		format = wrap_style (&#039;format&#039;, &#039;PDF&#039;);									-- set format to pdf&lt;br /&gt;
	else&lt;br /&gt;
		format = &#039;&#039;;															-- empty string for concatenation&lt;br /&gt;
	end&lt;br /&gt;
	return format;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; G E T _ D I S P L A Y _ A U T H O R S _ E D I T O R S &amp;gt;------------------------&lt;br /&gt;
&lt;br /&gt;
Returns a number that defines the number of names displayed for author and editor name lists and a boolean flag&lt;br /&gt;
to indicate when et al. should be appended to the name list.&lt;br /&gt;
&lt;br /&gt;
When the value assigned to |display-xxxxors= is a number greater than or equal to zero, return the number and&lt;br /&gt;
the previous state of the &#039;etal&#039; flag (false by default but may have been set to true if the name list contains&lt;br /&gt;
some variant of the text &#039;et al.&#039;).&lt;br /&gt;
&lt;br /&gt;
When the value assigned to |display-xxxxors= is the keyword &#039;etal&#039;, return a number that is one greater than the&lt;br /&gt;
number of authors in the list and set the &#039;etal&#039; flag true.  This will cause the list_people() to display all of&lt;br /&gt;
the names in the name list followed by &#039;et al.&#039;&lt;br /&gt;
&lt;br /&gt;
In all other cases, returns nil and the previous state of the &#039;etal&#039; flag.&lt;br /&gt;
&lt;br /&gt;
inputs:&lt;br /&gt;
	max: A[&#039;DisplayAuthors&#039;] or A[&#039;DisplayEditors&#039;]; a number or some flavor of etal&lt;br /&gt;
	count: #a or #e&lt;br /&gt;
	list_name: &#039;authors&#039; or &#039;editors&#039;&lt;br /&gt;
	etal: author_etal or editor_etal&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function get_display_authors_editors (max, count, list_name, etal)&lt;br /&gt;
	if is_set (max) then&lt;br /&gt;
		if &#039;etal&#039; == max:lower():gsub(&amp;quot;[ &#039;%.]&amp;quot;, &#039;&#039;) then						-- the :gsub() portion makes &#039;etal&#039; from a variety of &#039;et al.&#039; spellings and stylings&lt;br /&gt;
			max = count + 1;													-- number of authors + 1 so display all author name plus et al.&lt;br /&gt;
			etal = true;														-- overrides value set by extract_names()&lt;br /&gt;
		elseif max:match (&#039;^%d+$&#039;) then											-- if is a string of numbers&lt;br /&gt;
			max = tonumber (max);												-- make it a number&lt;br /&gt;
			if max &amp;gt;= count then												-- if |display-xxxxors= value greater than or equal to number of authors/editors&lt;br /&gt;
				add_maint_cat (&#039;disp_auth_ed&#039;, cfg.special_case_translation [list_name]);&lt;br /&gt;
			end&lt;br /&gt;
		else																	-- not a valid keyword or number&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;invalid_param_val&#039;, {&#039;display-&#039; .. list_name, max}, true ) } );		-- add error message&lt;br /&gt;
			max = nil;															-- unset; as if |display-xxxxors= had not been set&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return max, etal;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; E X T R A _ T E X T _ I N _ P A G E _ C H E C K &amp;gt;------------------------------&lt;br /&gt;
&lt;br /&gt;
Adds page to Category:CS1 maint: extra text if |page= or |pages= has what appears to be some form of p. or pp. &lt;br /&gt;
abbreviation in the first characters of the parameter content.&lt;br /&gt;
&lt;br /&gt;
check Page and Pages for extraneous p, p., pp, and pp. at start of parameter value:&lt;br /&gt;
	good pattern: &#039;^P[^%.P%l]&#039; matches when |page(s)= begins PX or P# but not Px where x and X are letters and # is a dgiit&lt;br /&gt;
	bad pattern: &#039;^[Pp][Pp]&#039; matches matches when |page(s)= begins pp or pP or Pp or PP&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function extra_text_in_page_check (page)&lt;br /&gt;
	local good_pattern = &#039;^P[^%.Pp]&#039;;											-- ok to begin with uppercase P: P7 (pg 7 of section P) but not p123 (page 123) TODO: add Gg for PG or Pg?&lt;br /&gt;
	local bad_pattern = &#039;^[Pp]?[Pp]%.?[ %d]&#039;;&lt;br /&gt;
&lt;br /&gt;
	if not page:match (good_pattern) and (page:match (bad_pattern) or  page:match (&#039;^[Pp]ages?&#039;)) then&lt;br /&gt;
		add_maint_cat (&#039;extra_text&#039;);&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; G E T _ V _ N A M E _ T A B L E &amp;gt;----------------------------------------------&lt;br /&gt;
&lt;br /&gt;
split apart a |vauthors= or |veditors= parameter.  This function allows for corporate names, wrapped in doubled&lt;br /&gt;
parentheses to also have commas; in the old version of the code, the doubled parnetheses were included in the&lt;br /&gt;
rendered citation and in the metadata.  Individual author names may be wikilinked&lt;br /&gt;
&lt;br /&gt;
	|vauthors=Jones AB, [[E. B. White|White EB]], ((Black, Brown, and Co.))&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function get_v_name_table (vparam, output_table, output_link_table)&lt;br /&gt;
	local name_table = mw.text.split(vparam, &amp;quot;%s*,%s*&amp;quot;);						-- names are separated by commas&lt;br /&gt;
	local wl_type, label, link;													-- wl_type not used here; just a place holder&lt;br /&gt;
	&lt;br /&gt;
	local i = 1;&lt;br /&gt;
	&lt;br /&gt;
	while name_table[i] do&lt;br /&gt;
		if name_table[i]:match (&#039;^%(%(.*[^%)][^%)]$&#039;) then						-- first segment of corporate with one or more commas; this segment has the opening doubled parens&lt;br /&gt;
			local name = name_table[i];&lt;br /&gt;
			i=i+1;																-- bump indexer to next segment&lt;br /&gt;
			while name_table[i] do&lt;br /&gt;
				name = name .. &#039;, &#039; .. name_table[i];							-- concatenate with previous segments&lt;br /&gt;
				if name_table[i]:match (&#039;^.*%)%)$&#039;) then						-- if this table member has the closing doubled parens&lt;br /&gt;
					break;														-- and done reassembling so&lt;br /&gt;
				end&lt;br /&gt;
				i=i+1;															-- bump indexer&lt;br /&gt;
			end&lt;br /&gt;
			table.insert (output_table, name);									-- and add corporate name to the output table&lt;br /&gt;
			table.insert (output_link_table, &#039;&#039;);								-- no wikilink&lt;br /&gt;
		else&lt;br /&gt;
			wl_type, label, link = is_wikilink (name_table[i]);					-- wl_type is: 0, no wl (text in label variable); 1, [[D]]; 2, [[L|D]]&lt;br /&gt;
			table.insert (output_table, label);									-- add this name&lt;br /&gt;
			if 1 == wl_type then&lt;br /&gt;
				table.insert (output_link_table, label);						-- simple wikilink [[D]]&lt;br /&gt;
			else&lt;br /&gt;
				table.insert (output_link_table, link);							-- no wikilink or [[L|D]]; add this link if there is one, else empty string&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		i = i+1;&lt;br /&gt;
	end	&lt;br /&gt;
	return output_table;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; P A R S E _ V A U T H O R S _ V E D I T O R S &amp;gt;--------------------------------&lt;br /&gt;
&lt;br /&gt;
This function extracts author / editor names from |vauthors= or |veditors= and finds matching |xxxxor-maskn= and&lt;br /&gt;
|xxxxor-linkn= in args.  It then returns a table of assembled names just as extract_names() does.&lt;br /&gt;
&lt;br /&gt;
Author / editor names in |vauthors= or |veditors= must be in Vancouver system style. Corporate or institutional names&lt;br /&gt;
may sometimes be required and because such names will often fail the is_good_vanc_name() and other format compliance&lt;br /&gt;
tests, are wrapped in doubled paranethese ((corporate name)) to suppress the format tests.&lt;br /&gt;
&lt;br /&gt;
Supports generational suffixes Jr, 2nd, 3rd, 4th–6th.&lt;br /&gt;
&lt;br /&gt;
This function sets the vancouver error when a reqired comma is missing and when there is a space between an author&#039;s initials.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function parse_vauthors_veditors (args, vparam, list_name)&lt;br /&gt;
	local names = {};															-- table of names assembled from |vauthors=, |author-maskn=, |author-linkn=&lt;br /&gt;
	local v_name_table = {};&lt;br /&gt;
	local v_link_table = {};													-- when name is wikilinked, targets go in this table&lt;br /&gt;
	local etal = false;															-- return value set to true when we find some form of et al. vauthors parameter&lt;br /&gt;
	local last, first, link, mask, suffix;&lt;br /&gt;
	local corporate = false;&lt;br /&gt;
&lt;br /&gt;
	vparam, etal = name_has_etal (vparam, etal, true);							-- find and remove variations on et al. do not categorize (do it here because et al. might have a period)&lt;br /&gt;
	v_name_table = get_v_name_table (vparam, v_name_table, v_link_table);						-- names are separated by commas&lt;br /&gt;
&lt;br /&gt;
	for i, v_name in ipairs(v_name_table) do&lt;br /&gt;
		if v_name:match (&#039;^%(%(.+%)%)$&#039;) then									-- corporate authors are wrapped in doubled parentheses to supress vanc formatting and error detection&lt;br /&gt;
			first = &#039;&#039;;															-- set to empty string for concatenation and because it may have been set for previous author/editor&lt;br /&gt;
			last = v_name:match (&#039;^%(%((.+)%)%)$&#039;)								-- remove doubled parntheses&lt;br /&gt;
			corporate = true;													-- flag used in list_people()&lt;br /&gt;
		elseif string.find(v_name, &amp;quot;%s&amp;quot;) then&lt;br /&gt;
			if v_name:find(&#039;[;%.]&#039;) then										-- look for commonly occurring punctuation characters; &lt;br /&gt;
				add_vanc_error (&#039;punctuation&#039;);&lt;br /&gt;
			end&lt;br /&gt;
			local lastfirstTable = {}&lt;br /&gt;
			lastfirstTable = mw.text.split(v_name, &amp;quot;%s&amp;quot;)&lt;br /&gt;
			first = table.remove(lastfirstTable);								-- removes and returns value of last element in table which should be author intials&lt;br /&gt;
			if is_suffix (first) then											-- if a valid suffix&lt;br /&gt;
				suffix = first													-- save it as a suffix and&lt;br /&gt;
				first = table.remove(lastfirstTable);							-- get what should be the initials from the table&lt;br /&gt;
			end																	-- no suffix error message here because letter combination may be result of Romanization; check for digits?&lt;br /&gt;
			last = table.concat(lastfirstTable, &amp;quot; &amp;quot;)							-- returns a string that is the concatenation of all other names that are not initials&lt;br /&gt;
			if mw.ustring.match (last, &#039;%a+%s+%u+%s+%a+&#039;) then&lt;br /&gt;
				add_vanc_error (&#039;missing comma&#039;);								-- matches last II last; the case when a comma is missing&lt;br /&gt;
			end&lt;br /&gt;
			if mw.ustring.match (v_name, &#039; %u %u$&#039;) then						-- this test is in the wrong place TODO: move or replace with a more appropriate test&lt;br /&gt;
				add_vanc_error (&#039;name&#039;);										-- matches a space between two intiials&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			first = &#039;&#039;;															-- set to empty string for concatenation and because it may have been set for previous author/editor&lt;br /&gt;
			last = v_name;														-- last name or single corporate name?  Doesn&#039;t support multiword corporate names? do we need this?&lt;br /&gt;
		end&lt;br /&gt;
																&lt;br /&gt;
		if is_set (first) then&lt;br /&gt;
			if not mw.ustring.match (first, &amp;quot;^%u?%u$&amp;quot;) then						-- first shall contain one or two upper-case letters, nothing else&lt;br /&gt;
				add_vanc_error (&#039;initials&#039;);									-- too many initials; mixed case initials (which may be ok Romanization); hyphenated initials&lt;br /&gt;
			end&lt;br /&gt;
			is_good_vanc_name (last, first);									-- check first and last before restoring the suffix which may have a non-Latin digit&lt;br /&gt;
			if is_set (suffix) then&lt;br /&gt;
				first = first .. &#039; &#039; .. suffix;									-- if there was a suffix concatenate with the initials&lt;br /&gt;
				suffix = &#039;&#039;;													-- unset so we don&#039;t add this suffix to all subsequent names&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			if not corporate then&lt;br /&gt;
				is_good_vanc_name (last, &#039;&#039;);&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		link = select_one( args, cfg.aliases[list_name .. &#039;-Link&#039;], &#039;redundant_parameters&#039;, i ) or v_link_table[i];&lt;br /&gt;
		mask = select_one( args, cfg.aliases[list_name .. &#039;-Mask&#039;], &#039;redundant_parameters&#039;, i );&lt;br /&gt;
		names[i] = {last = last, first = first, link = link, mask = mask, corporate=corporate};		-- add this assembled name to our names list&lt;br /&gt;
	end&lt;br /&gt;
	return names, etal;															-- all done, return our list of names&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; S E L E C T _ A U T H O R _ E D I T O R _ S O U R C E &amp;gt;------------------------&lt;br /&gt;
&lt;br /&gt;
Select one of |authors=, |authorn= / |lastn / firstn=, or |vauthors= as the source of the author name list or&lt;br /&gt;
select one of |editors=, |editorn= / editor-lastn= / |editor-firstn= or |veditors= as the source of the editor name list.&lt;br /&gt;
&lt;br /&gt;
Only one of these appropriate three will be used.  The hierarchy is: |authorn= (and aliases) highest and |authors= lowest and&lt;br /&gt;
similarly, |editorn= (and aliases) highest and |editors= lowest&lt;br /&gt;
&lt;br /&gt;
When looking for |authorn= / |editorn= parameters, test |xxxxor1= and |xxxxor2= (and all of their aliases); stops after the second&lt;br /&gt;
test which mimicks the test used in extract_names() when looking for a hole in the author name list.  There may be a better&lt;br /&gt;
way to do this, I just haven&#039;t discovered what that way is.&lt;br /&gt;
&lt;br /&gt;
Emits an error message when more than one xxxxor name source is provided.&lt;br /&gt;
&lt;br /&gt;
In this function, vxxxxors = vauthors or veditors; xxxxors = authors or editors as appropriate.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function select_author_editor_source (vxxxxors, xxxxors, args, list_name)&lt;br /&gt;
local lastfirst = false;&lt;br /&gt;
	if select_one( args, cfg.aliases[list_name .. &#039;-Last&#039;], &#039;none&#039;, 1 ) or		-- do this twice incase we have a |first1= without a |last1=; this ...&lt;br /&gt;
		select_one( args, cfg.aliases[list_name .. &#039;-First&#039;], &#039;none&#039;, 1 ) or	-- ... also catches the case where |first= is used with |vauthors=&lt;br /&gt;
		select_one( args, cfg.aliases[list_name .. &#039;-Last&#039;], &#039;none&#039;, 2 ) or&lt;br /&gt;
		select_one( args, cfg.aliases[list_name .. &#039;-First&#039;], &#039;none&#039;, 2 ) then&lt;br /&gt;
			lastfirst=true;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if (is_set (vxxxxors) and true == lastfirst) or								-- these are the three error conditions&lt;br /&gt;
		(is_set (vxxxxors) and is_set (xxxxors)) or&lt;br /&gt;
		(true == lastfirst and is_set (xxxxors)) then&lt;br /&gt;
			local err_name;&lt;br /&gt;
			if &#039;AuthorList&#039; == list_name then									-- figure out which name should be used in error message&lt;br /&gt;
				err_name = &#039;author&#039;;&lt;br /&gt;
			else&lt;br /&gt;
				err_name = &#039;editor&#039;;&lt;br /&gt;
			end&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;redundant_parameters&#039;,&lt;br /&gt;
				{err_name .. &#039;-name-list parameters&#039;}, true ) } );				-- add error message&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if true == lastfirst then return 1 end;										-- return a number indicating which author name source to use&lt;br /&gt;
	if is_set (vxxxxors) then return 2 end;&lt;br /&gt;
	if is_set (xxxxors) then return 3 end;&lt;br /&gt;
	return 1;																	-- no authors so return 1; this allows missing author name test to run in case there is a first without last &lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; I S _ V A L I D _ P A R A M E T E R _ V A L U E &amp;gt;------------------------------&lt;br /&gt;
&lt;br /&gt;
This function is used to validate a parameter&#039;s assigned value for those parameters that have only a limited number&lt;br /&gt;
of allowable values (yes, y, true, no, etc).  When the parameter value has not been assigned a value (missing or empty&lt;br /&gt;
in the source template) the function returns true.  If the parameter value is one of the list of allowed values returns&lt;br /&gt;
true; else, emits an error message and returns false.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function is_valid_parameter_value (value, name, possible)&lt;br /&gt;
	if not is_set (value) then&lt;br /&gt;
		return true;															-- an empty parameter is ok&lt;br /&gt;
	elseif in_array(value:lower(), possible) then&lt;br /&gt;
		return true;&lt;br /&gt;
	else&lt;br /&gt;
		table.insert( z.message_tail, { set_error( &#039;invalid_param_val&#039;, {name, value}, true ) } );	-- not an allowed value so add error message&lt;br /&gt;
		return false&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; T E R M I N A T E _ N A M E _ L I S T &amp;gt;----------------------------------------&lt;br /&gt;
&lt;br /&gt;
This function terminates a name list (author, contributor, editor) with a separator character (sepc) and a space&lt;br /&gt;
when the last character is not a sepc character or when the last three characters are not sepc followed by two&lt;br /&gt;
closing square brackets (close of a wikilink).  When either of these is true, the name_list is terminated with a&lt;br /&gt;
single space character.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function terminate_name_list (name_list, sepc)&lt;br /&gt;
	if (string.sub (name_list,-3,-1) == sepc .. &#039;. &#039;) then						-- if already properly terminated&lt;br /&gt;
		return name_list;														-- just return the name list&lt;br /&gt;
	elseif (string.sub (name_list,-1,-1) == sepc) or (string.sub (name_list,-3,-1) == sepc .. &#039;]]&#039;) then	-- if last name in list ends with sepc char&lt;br /&gt;
		return name_list .. &amp;quot; &amp;quot;;												-- don&#039;t add another&lt;br /&gt;
	else&lt;br /&gt;
		return name_list .. sepc .. &#039; &#039;;										-- otherwise terninate the name list&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; F O R M A T _ V O L U M E _ I S S U E &amp;gt;----------------------------------------&lt;br /&gt;
&lt;br /&gt;
returns the concatenation of the formatted volume and issue parameters as a single string; or formatted volume&lt;br /&gt;
or formatted issue, or an empty string if neither are set.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
	&lt;br /&gt;
local function format_volume_issue (volume, issue, cite_class, origin, sepc, lower)&lt;br /&gt;
	if not is_set (volume) and not is_set (issue) then&lt;br /&gt;
		return &#039;&#039;;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if &#039;magazine&#039; == cite_class or (in_array (cite_class, {&#039;citation&#039;, &#039;map&#039;}) and &#039;magazine&#039; == origin) then&lt;br /&gt;
		if is_set (volume) and is_set (issue) then&lt;br /&gt;
			return wrap_msg (&#039;vol-no&#039;, {sepc, volume, issue}, lower);&lt;br /&gt;
		elseif is_set (volume) then&lt;br /&gt;
			return wrap_msg (&#039;vol&#039;, {sepc, volume}, lower);&lt;br /&gt;
		else&lt;br /&gt;
			return wrap_msg (&#039;issue&#039;, {sepc, issue}, lower);&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local vol = &#039;&#039;;&lt;br /&gt;
		&lt;br /&gt;
	if is_set (volume) then&lt;br /&gt;
		if (4 &amp;lt; mw.ustring.len(volume)) then&lt;br /&gt;
			vol = substitute (cfg.messages[&#039;j-vol&#039;], {sepc, volume});&lt;br /&gt;
		else&lt;br /&gt;
			vol = substitute (cfg.presentation[&#039;vol-bold&#039;], {sepc, hyphen_to_dash(volume)});&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if is_set (issue) then&lt;br /&gt;
		return vol .. substitute (cfg.messages[&#039;j-issue&#039;], issue);&lt;br /&gt;
	end&lt;br /&gt;
	return vol;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[-------------------------&amp;lt; F O R M A T _ P A G E S _ S H E E T S &amp;gt;-----------------------------------------&lt;br /&gt;
&lt;br /&gt;
adds static text to one of |page(s)= or |sheet(s)= values and returns it with all of the others set to empty strings.&lt;br /&gt;
The return order is:&lt;br /&gt;
	page, pages, sheet, sheets&lt;br /&gt;
&lt;br /&gt;
Singular has priority over plural when both are provided.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function format_pages_sheets (page, pages, sheet, sheets, cite_class, origin, sepc, nopp, lower)&lt;br /&gt;
	if &#039;map&#039; == cite_class then													-- only cite map supports sheet(s) as in-source locators&lt;br /&gt;
		if is_set (sheet) then&lt;br /&gt;
			if &#039;journal&#039; == origin then&lt;br /&gt;
				return &#039;&#039;, &#039;&#039;, wrap_msg (&#039;j-sheet&#039;, sheet, lower), &#039;&#039;;&lt;br /&gt;
			else&lt;br /&gt;
				return &#039;&#039;, &#039;&#039;, wrap_msg (&#039;sheet&#039;, {sepc, sheet}, lower), &#039;&#039;;&lt;br /&gt;
			end&lt;br /&gt;
		elseif is_set (sheets) then&lt;br /&gt;
			if &#039;journal&#039; == origin then&lt;br /&gt;
				return &#039;&#039;, &#039;&#039;, &#039;&#039;, wrap_msg (&#039;j-sheets&#039;, sheets, lower);&lt;br /&gt;
			else&lt;br /&gt;
				return &#039;&#039;, &#039;&#039;, &#039;&#039;, wrap_msg (&#039;sheets&#039;, {sepc, sheets}, lower);&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local is_journal = &#039;journal&#039; == cite_class or (in_array (cite_class, {&#039;citation&#039;, &#039;map&#039;}) and &#039;journal&#039; == origin);&lt;br /&gt;
	&lt;br /&gt;
	if is_set (page) then&lt;br /&gt;
		if is_journal then&lt;br /&gt;
			return substitute (cfg.messages[&#039;j-page(s)&#039;], page), &#039;&#039;, &#039;&#039;, &#039;&#039;;&lt;br /&gt;
		elseif not nopp then&lt;br /&gt;
			return substitute (cfg.messages[&#039;p-prefix&#039;], {sepc, page}), &#039;&#039;, &#039;&#039;, &#039;&#039;;&lt;br /&gt;
		else&lt;br /&gt;
			return substitute (cfg.messages[&#039;nopp&#039;], {sepc, page}), &#039;&#039;, &#039;&#039;, &#039;&#039;;&lt;br /&gt;
		end&lt;br /&gt;
	elseif is_set(pages) then&lt;br /&gt;
		if is_journal then&lt;br /&gt;
			return substitute (cfg.messages[&#039;j-page(s)&#039;], pages), &#039;&#039;, &#039;&#039;, &#039;&#039;;&lt;br /&gt;
		elseif tonumber(pages) ~= nil and not nopp then										-- if pages is only digits, assume a single page number&lt;br /&gt;
			return &#039;&#039;, substitute (cfg.messages[&#039;p-prefix&#039;], {sepc, pages}), &#039;&#039;, &#039;&#039;;&lt;br /&gt;
		elseif not nopp then&lt;br /&gt;
			return &#039;&#039;, substitute (cfg.messages[&#039;pp-prefix&#039;], {sepc, pages}), &#039;&#039;, &#039;&#039;;&lt;br /&gt;
		else&lt;br /&gt;
			return &#039;&#039;, substitute (cfg.messages[&#039;nopp&#039;], {sepc, pages}), &#039;&#039;, &#039;&#039;;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return &#039;&#039;, &#039;&#039;, &#039;&#039;, &#039;&#039;;														-- return empty strings&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[=[-------------------------&amp;lt; A R C H I V E _ U R L _ C H E C K &amp;gt;--------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Check archive.org urls to make sure they at least look like they are pointing at valid archives and not to the &lt;br /&gt;
save snapshot url or to calendar pages.  When the archive url is &#039;https://web.archive.org/save/&#039; (or http://...)&lt;br /&gt;
archive.org saves a snapshot of the target page in the url.  That is something that Wikipedia should not allow&lt;br /&gt;
unwitting readers to do.&lt;br /&gt;
&lt;br /&gt;
When the archive.org url does not have a complete timestamp, archive.org chooses a snapshot according to its own&lt;br /&gt;
algorithm or provides a calendar &#039;search&#039; result.  [[WP:ELNO]] discourages links to search results.&lt;br /&gt;
&lt;br /&gt;
This function looks at the value assigned to |archive-url= and returns empty strings for |archive-url= and&lt;br /&gt;
|archive-date= and an error message when:&lt;br /&gt;
	|archive-url= holds an archive.org save command url&lt;br /&gt;
	|archive-url= is an archive.org url that does not have a complete timestamp (YYYYMMDDhhmmss 14 digits) in the&lt;br /&gt;
		correct place&lt;br /&gt;
otherwise returns |archive-url= and |archive-date=&lt;br /&gt;
&lt;br /&gt;
There are two mostly compatible archive.org urls:&lt;br /&gt;
	//web.archive.org/&amp;lt;timestamp&amp;gt;...		-- the old form&lt;br /&gt;
	//web.archive.org/web/&amp;lt;timestamp&amp;gt;...	-- the new form&lt;br /&gt;
&lt;br /&gt;
The old form does not support or map to the new form when it contains a display flag.  There are four identified flags&lt;br /&gt;
(&#039;id_&#039;, &#039;js_&#039;, &#039;cs_&#039;, &#039;im_&#039;) but since archive.org ignores others following the same form (two letters and an underscore)&lt;br /&gt;
we don&#039;t check for these specific flags but we do check the form.&lt;br /&gt;
&lt;br /&gt;
This function supports a preview mode.  When the article is rendered in preview mode, this funct may return a modified&lt;br /&gt;
archive url:&lt;br /&gt;
	for save command errors, return undated wildcard (/*/)&lt;br /&gt;
	for timestamp errors when the timestamp has a wildcard, return the url unmodified&lt;br /&gt;
	for timestamp errors when the timestamp does not have a wildcard, return with timestamp limited to six digits plus wildcard (/yyyymm*/)&lt;br /&gt;
&lt;br /&gt;
]=]&lt;br /&gt;
&lt;br /&gt;
local function archive_url_check (url, date)&lt;br /&gt;
	local err_msg = &#039;&#039;;															-- start with the error message empty&lt;br /&gt;
	local path, timestamp, flag;												-- portions of the archive.or url&lt;br /&gt;
	&lt;br /&gt;
	if (not url:match(&#039;//web%.archive%.org/&#039;)) and (not url:match(&#039;//liveweb%.archive%.org/&#039;)) then		-- also deprecated liveweb Wayback machine url&lt;br /&gt;
		return url, date;														-- not an archive.org archive, return ArchiveURL and ArchiveDate&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if url:match(&#039;//web%.archive%.org/save/&#039;) then								-- if a save command url, we don&#039;t want to allow saving of the target page &lt;br /&gt;
		err_msg = &#039;save command&#039;;&lt;br /&gt;
		url = url:gsub (&#039;(//web%.archive%.org)/save/&#039;, &#039;%1/*/&#039;, 1);				-- for preview mode: modify ArchiveURL&lt;br /&gt;
	elseif url:match(&#039;//liveweb%.archive%.org/&#039;) then&lt;br /&gt;
		err_msg = &#039;liveweb&#039;;&lt;br /&gt;
	else&lt;br /&gt;
		path, timestamp, flag = url:match(&#039;//web%.archive%.org/([^%d]*)(%d+)([^/]*)/&#039;);		-- split out some of the url parts for evaluation&lt;br /&gt;
		&lt;br /&gt;
		if not is_set(timestamp) or 14 ~= timestamp:len() then					-- path and flag optional, must have 14-digit timestamp here&lt;br /&gt;
			err_msg = &#039;timestamp&#039;;&lt;br /&gt;
			if &#039;*&#039; ~= flag then&lt;br /&gt;
				url=url:gsub (&#039;(//web%.archive%.org/[^%d]*%d?%d?%d?%d?%d?%d?)[^/]*&#039;, &#039;%1*&#039;, 1)	-- for preview, modify ts to be yearmo* max (0-6 digits plus splat)&lt;br /&gt;
			end&lt;br /&gt;
		elseif is_set(path) and &#039;web/&#039; ~= path then								-- older archive urls do not have the extra &#039;web/&#039; path element&lt;br /&gt;
			err_msg = &#039;path&#039;;&lt;br /&gt;
		elseif is_set (flag) and not is_set (path) then							-- flag not allowed with the old form url (without the &#039;web/&#039; path element)&lt;br /&gt;
			err_msg = &#039;flag&#039;;&lt;br /&gt;
		elseif is_set (flag) and not flag:match (&#039;%a%a_&#039;) then					-- flag if present must be two alpha characters and underscore (requires &#039;web/&#039; path element)&lt;br /&gt;
			err_msg = &#039;flag&#039;;&lt;br /&gt;
		else&lt;br /&gt;
			return url, date;													-- return archiveURL and ArchiveDate&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
																				-- if here, something not right so&lt;br /&gt;
	table.insert( z.message_tail, { set_error( &#039;archive_url&#039;, {err_msg}, true ) } );	-- add error message and&lt;br /&gt;
	if is_set (Frame:preprocess(&#039;{{REVISIONID}}&#039;)) then&lt;br /&gt;
		return &#039;&#039;, &#039;&#039;;															-- return empty strings for archiveURL and ArchiveDate&lt;br /&gt;
	else&lt;br /&gt;
		return url, date;														-- preview mode so return archiveURL and ArchiveDate&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; M I S S I N G _ P I P E _ C H E C K &amp;gt;------------------------------------------&lt;br /&gt;
&lt;br /&gt;
Look at the contents of a parameter. If the content has a string of characters and digits followed by an equal&lt;br /&gt;
sign, compare the alphanumeric string to the list of cs1|2 parameters.  If found, then the string is possibly a&lt;br /&gt;
parameter that is missing its pipe:&lt;br /&gt;
	{{cite ... |title=Title access-date=2016-03-17}}&lt;br /&gt;
&lt;br /&gt;
cs1|2 shares some parameter names with xml/html atributes: class=, title=, etc.  To prevent false positives xml/html&lt;br /&gt;
tags are removed before the search.&lt;br /&gt;
&lt;br /&gt;
If a missing pipe is detected, this function adds the missing pipe maintenance category.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function missing_pipe_check (value)&lt;br /&gt;
	local capture;&lt;br /&gt;
	value = value:gsub (&#039;%b&amp;lt;&amp;gt;&#039;, &#039;&#039;);											-- remove xml/html tags because attributes: class=, title=, etc &lt;br /&gt;
&lt;br /&gt;
	capture = value:match (&#039;%s+(%a[%a%d]+)%s*=&#039;) or value:match (&#039;^(%a[%a%d]+)%s*=&#039;);	-- find and categorize parameters with possible missing pipes&lt;br /&gt;
	if capture and validate (capture) then								-- if the capture is a valid parameter name&lt;br /&gt;
		add_maint_cat (&#039;missing_pipe&#039;);&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C I T A T I O N 0 &amp;gt;------------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
This is the main function doing the majority of the citation formatting.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
local function citation0( config, args)&lt;br /&gt;
	--[[ &lt;br /&gt;
	Load Input Parameters&lt;br /&gt;
	The argument_wrapper facilitates the mapping of multiple aliases to single internal variable.&lt;br /&gt;
	]]&lt;br /&gt;
	local A = argument_wrapper( args );&lt;br /&gt;
	local i &lt;br /&gt;
&lt;br /&gt;
	-- Pick out the relevant fields from the arguments.  Different citation templates&lt;br /&gt;
	-- define different field names for the same underlying things.	&lt;br /&gt;
&lt;br /&gt;
-- set default parameter values defined by |mode= parameter.&lt;br /&gt;
	local Mode = A[&#039;Mode&#039;];&lt;br /&gt;
	if not is_valid_parameter_value (Mode, &#039;mode&#039;, cfg.keywords[&#039;mode&#039;]) then&lt;br /&gt;
		Mode = &#039;&#039;;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local author_etal;&lt;br /&gt;
	local a	= {};																-- authors list from |lastn= / |firstn= pairs or |vauthors=&lt;br /&gt;
	local Authors;&lt;br /&gt;
	local NameListFormat = A[&#039;NameListFormat&#039;];&lt;br /&gt;
	local Collaboration = A[&#039;Collaboration&#039;];&lt;br /&gt;
&lt;br /&gt;
	do																			-- to limit scope of selected&lt;br /&gt;
		local selected = select_author_editor_source (A[&#039;Vauthors&#039;], A[&#039;Authors&#039;], args, &#039;AuthorList&#039;);&lt;br /&gt;
		if 1 == selected then&lt;br /&gt;
			a, author_etal = extract_names (args, &#039;AuthorList&#039;);				-- fetch author list from |authorn= / |lastn= / |firstn=, |author-linkn=, and |author-maskn=&lt;br /&gt;
		elseif 2 == selected then&lt;br /&gt;
			NameListFormat = &#039;vanc&#039;;											-- override whatever |name-list-format= might be&lt;br /&gt;
			a, author_etal = parse_vauthors_veditors (args, args.vauthors, &#039;AuthorList&#039;);	-- fetch author list from |vauthors=, |author-linkn=, and |author-maskn=&lt;br /&gt;
		elseif 3 == selected then&lt;br /&gt;
			Authors = A[&#039;Authors&#039;];												-- use content of |authors=&lt;br /&gt;
			if &#039;authors&#039; == A:ORIGIN(&#039;Authors&#039;) then							-- but add a maint cat if the parameter is |authors=&lt;br /&gt;
				add_maint_cat (&#039;authors&#039;);										-- because use of this parameter is discouraged; what to do about the aliases is a TODO:&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		if is_set (Collaboration) then&lt;br /&gt;
			author_etal = true;													-- so that |display-authors=etal not required&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local Others = A[&#039;Others&#039;];&lt;br /&gt;
&lt;br /&gt;
	local editor_etal;&lt;br /&gt;
	local e	= {};																-- editors list from |editor-lastn= / |editor-firstn= pairs or |veditors=&lt;br /&gt;
	local Editors;&lt;br /&gt;
&lt;br /&gt;
	do																			-- to limit scope of selected&lt;br /&gt;
		local selected = select_author_editor_source (A[&#039;Veditors&#039;], A[&#039;Editors&#039;], args, &#039;EditorList&#039;);&lt;br /&gt;
		if 1 == selected then&lt;br /&gt;
			e, editor_etal = extract_names (args, &#039;EditorList&#039;);				-- fetch editor list from |editorn= / |editor-lastn= / |editor-firstn=, |editor-linkn=, and |editor-maskn=&lt;br /&gt;
		elseif 2 == selected then&lt;br /&gt;
			NameListFormat = &#039;vanc&#039;;											-- override whatever |name-list-format= might be&lt;br /&gt;
			e, editor_etal = parse_vauthors_veditors (args, args.veditors, &#039;EditorList&#039;);	-- fetch editor list from |veditors=, |editor-linkn=, and |editor-maskn=&lt;br /&gt;
		elseif 3 == selected then&lt;br /&gt;
			Editors = A[&#039;Editors&#039;];												-- use content of |editors=&lt;br /&gt;
			add_maint_cat (&#039;editors&#039;);											-- but add a maint cat because use of this parameter is discouraged&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local t = {};																-- translators list from |translator-lastn= / translator-firstn= pairs&lt;br /&gt;
	local Translators;															-- assembled translators name list&lt;br /&gt;
	t = extract_names (args, &#039;TranslatorList&#039;);									-- fetch translator list from |translatorn= / |translator-lastn=, -firstn=, -linkn=, -maskn=&lt;br /&gt;
&lt;br /&gt;
	local interviewers_list = {};&lt;br /&gt;
	local Interviewers = A[&#039;Interviewers&#039;]&lt;br /&gt;
	if is_set (Interviewers) then												-- add a maint cat if the |interviewers= is used&lt;br /&gt;
		add_maint_cat (&#039;interviewers&#039;);											-- because use of this parameter is discouraged&lt;br /&gt;
	else&lt;br /&gt;
		interviewers_list = extract_names (args, &#039;InterviewerList&#039;);			-- else, process preferred interviewers parameters&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local c = {};																-- contributors list from |contributor-lastn= / contributor-firstn= pairs&lt;br /&gt;
	local Contributors;															-- assembled contributors name list&lt;br /&gt;
	local Contribution = A[&#039;Contribution&#039;];&lt;br /&gt;
	if in_array(config.CitationClass, {&amp;quot;book&amp;quot;,&amp;quot;citation&amp;quot;}) and not is_set(A[&#039;Periodical&#039;]) then	-- |contributor= and |contribution= only supported in book cites&lt;br /&gt;
		c = extract_names (args, &#039;ContributorList&#039;);							-- fetch contributor list from |contributorn= / |contributor-lastn=, -firstn=, -linkn=, -maskn=&lt;br /&gt;
		&lt;br /&gt;
		if 0 &amp;lt; #c then&lt;br /&gt;
			if not is_set (Contribution) then									-- |contributor= requires |contribution=&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;contributor_missing_required_param&#039;, &#039;contribution&#039;)});	-- add missing contribution error message&lt;br /&gt;
				c = {};															-- blank the contributors&#039; table; it is used as a flag later&lt;br /&gt;
			end&lt;br /&gt;
			if 0 == #a then														-- |contributor= requires |author=&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;contributor_missing_required_param&#039;, &#039;author&#039;)});	-- add missing author error message&lt;br /&gt;
				c = {};															-- blank the contributors&#039; table; it is used as a flag later&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	else																		-- if not a book cite&lt;br /&gt;
		if select_one (args, cfg.aliases[&#039;ContributorList-Last&#039;], &#039;redundant_parameters&#039;, 1 ) then	-- are there contributor name list parameters?&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;contributor_ignored&#039;)});	-- add contributor ignored error message&lt;br /&gt;
		end&lt;br /&gt;
		Contribution = nil;														-- unset&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if not is_valid_parameter_value (NameListFormat, &#039;name-list-format&#039;, cfg.keywords[&#039;name-list-format&#039;]) then			-- only accepted value for this parameter is &#039;vanc&#039;&lt;br /&gt;
		NameListFormat = &#039;&#039;;													-- anything else, set to empty string&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local Year = A[&#039;Year&#039;];&lt;br /&gt;
	local PublicationDate = A[&#039;PublicationDate&#039;];&lt;br /&gt;
	local OrigYear = A[&#039;OrigYear&#039;];&lt;br /&gt;
	local Date = A[&#039;Date&#039;];&lt;br /&gt;
	local LayDate = A[&#039;LayDate&#039;];&lt;br /&gt;
	------------------------------------------------- Get title data&lt;br /&gt;
	local Title = A[&#039;Title&#039;];&lt;br /&gt;
	local ScriptTitle = A[&#039;ScriptTitle&#039;];&lt;br /&gt;
	local BookTitle = A[&#039;BookTitle&#039;];&lt;br /&gt;
	local Conference = A[&#039;Conference&#039;];&lt;br /&gt;
	local TransTitle = A[&#039;TransTitle&#039;];&lt;br /&gt;
	local TitleNote = A[&#039;TitleNote&#039;];&lt;br /&gt;
	local TitleLink = A[&#039;TitleLink&#039;];&lt;br /&gt;
			link_title_ok (TitleLink, A:ORIGIN (&#039;TitleLink&#039;), Title, &#039;title&#039;);	-- check for wikimarkup in |title-link= or wikimarkup in |title= when |title-link= is set&lt;br /&gt;
&lt;br /&gt;
	local Chapter = A[&#039;Chapter&#039;];&lt;br /&gt;
	local ScriptChapter = A[&#039;ScriptChapter&#039;];&lt;br /&gt;
	local ChapterLink	-- = A[&#039;ChapterLink&#039;];									-- deprecated as a parameter but still used internally by cite episode&lt;br /&gt;
	local TransChapter = A[&#039;TransChapter&#039;];&lt;br /&gt;
	local TitleType = A[&#039;TitleType&#039;];&lt;br /&gt;
	local Degree = A[&#039;Degree&#039;];&lt;br /&gt;
	local Docket = A[&#039;Docket&#039;];&lt;br /&gt;
	local ArchiveFormat = A[&#039;ArchiveFormat&#039;];&lt;br /&gt;
&lt;br /&gt;
	local ArchiveDate;&lt;br /&gt;
	local ArchiveURL;&lt;br /&gt;
&lt;br /&gt;
	ArchiveURL, ArchiveDate = archive_url_check (A[&#039;ArchiveURL&#039;], A[&#039;ArchiveDate&#039;])&lt;br /&gt;
	&lt;br /&gt;
	local DeadURL = A[&#039;DeadURL&#039;]&lt;br /&gt;
		if not is_valid_parameter_value (DeadURL, &#039;dead-url&#039;, cfg.keywords [&#039;deadurl&#039;]) then	-- set in config.defaults to &#039;yes&#039;&lt;br /&gt;
			DeadURL = &#039;&#039;;														-- anything else, set to empty string&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	local URL = A[&#039;URL&#039;]&lt;br /&gt;
	local URLorigin = A:ORIGIN(&#039;URL&#039;);											-- get name of parameter that holds URL&lt;br /&gt;
	local ChapterURL = A[&#039;ChapterURL&#039;];&lt;br /&gt;
	local ChapterURLorigin = A:ORIGIN(&#039;ChapterURL&#039;);							-- get name of parameter that holds ChapterURL&lt;br /&gt;
	local ConferenceFormat = A[&#039;ConferenceFormat&#039;];&lt;br /&gt;
	local ConferenceURL = A[&#039;ConferenceURL&#039;];&lt;br /&gt;
	local ConferenceURLorigin = A:ORIGIN(&#039;ConferenceURL&#039;);						-- get name of parameter that holds ConferenceURL&lt;br /&gt;
	local Periodical = A[&#039;Periodical&#039;];&lt;br /&gt;
	local Periodical_origin = A:ORIGIN(&#039;Periodical&#039;);							-- get the name of the periodical parameter&lt;br /&gt;
&lt;br /&gt;
	local Series = A[&#039;Series&#039;];&lt;br /&gt;
	&lt;br /&gt;
	local Volume;&lt;br /&gt;
	local Issue;&lt;br /&gt;
	local Page;&lt;br /&gt;
	local Pages;&lt;br /&gt;
	local At;&lt;br /&gt;
&lt;br /&gt;
	if in_array (config.CitationClass, cfg.templates_using_volume) then&lt;br /&gt;
		Volume = A[&#039;Volume&#039;];&lt;br /&gt;
	end&lt;br /&gt;
																				-- conference &amp;amp; map books do not support issue&lt;br /&gt;
	if in_array (config.CitationClass, cfg.templates_using_issue) and not (in_array (config.CitationClass, {&#039;conference&#039;, &#039;map&#039;}) and not is_set (Periodical))then&lt;br /&gt;
		Issue = A[&#039;Issue&#039;];&lt;br /&gt;
	end&lt;br /&gt;
	local Position = &#039;&#039;;&lt;br /&gt;
	if not in_array (config.CitationClass, cfg.templates_not_using_page) then&lt;br /&gt;
		Page = A[&#039;Page&#039;];&lt;br /&gt;
		Pages = hyphen_to_dash( A[&#039;Pages&#039;] );	&lt;br /&gt;
		At = A[&#039;At&#039;];&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local Edition = A[&#039;Edition&#039;];&lt;br /&gt;
	local PublicationPlace = A[&#039;PublicationPlace&#039;]&lt;br /&gt;
	local Place = A[&#039;Place&#039;];&lt;br /&gt;
	&lt;br /&gt;
	local PublisherName = A[&#039;PublisherName&#039;];&lt;br /&gt;
	local RegistrationRequired = A[&#039;RegistrationRequired&#039;];&lt;br /&gt;
		if not is_valid_parameter_value (RegistrationRequired, &#039;registration&#039;, cfg.keywords [&#039;yes_true_y&#039;]) then&lt;br /&gt;
			RegistrationRequired=nil;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	local SubscriptionRequired = A[&#039;SubscriptionRequired&#039;];&lt;br /&gt;
		if not is_valid_parameter_value (SubscriptionRequired, &#039;subscription&#039;, cfg.keywords [&#039;yes_true_y&#039;]) then&lt;br /&gt;
			SubscriptionRequired=nil;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	local UrlAccess = A[&#039;UrlAccess&#039;];&lt;br /&gt;
		if not is_valid_parameter_value (UrlAccess, &#039;url-access&#039;, cfg.keywords [&#039;url-access&#039;]) then&lt;br /&gt;
			UrlAccess = nil;&lt;br /&gt;
		end&lt;br /&gt;
		if not is_set(URL) and is_set(UrlAccess) then&lt;br /&gt;
			UrlAccess = nil;&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;param_access_requires_param&#039;, {&#039;url&#039;}, true ) } );&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		if is_set (UrlAccess) and is_set (SubscriptionRequired) then			-- while not aliases, these are much the same so if both are set&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;redundant_parameters&#039;, {wrap_style (&#039;parameter&#039;, &#039;url-access&#039;) .. &#039; and &#039; .. wrap_style (&#039;parameter&#039;, &#039;subscription&#039;)}, true ) } );		-- add error message&lt;br /&gt;
			SubscriptionRequired = nil;											-- unset; prefer |access= over |subscription=&lt;br /&gt;
		end&lt;br /&gt;
		if is_set (UrlAccess) and is_set (RegistrationRequired) then			-- these are not the same but contradictory so if both are set&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;redundant_parameters&#039;, {wrap_style (&#039;parameter&#039;, &#039;url-access&#039;) .. &#039; and &#039; .. wrap_style (&#039;parameter&#039;, &#039;registration&#039;)}, true ) } );		-- add error message&lt;br /&gt;
			RegistrationRequired = nil;											-- unset; prefer |access= over |registration=&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	local ChapterUrlAccess = A[&#039;ChapterUrlAccess&#039;];&lt;br /&gt;
		if not is_valid_parameter_value (ChapterUrlAccess, &#039;chapter-url-access&#039;, cfg.keywords [&#039;url-access&#039;]) then	-- same as url-access&lt;br /&gt;
			ChapterUrlAccess = nil;&lt;br /&gt;
		end&lt;br /&gt;
		if not is_set(ChapterURL) and is_set(ChapterUrlAccess) then&lt;br /&gt;
			ChapterUrlAccess = nil;&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;param_access_requires_param&#039;, {&#039;chapter-url&#039;}, true ) } );&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	local Via = A[&#039;Via&#039;];&lt;br /&gt;
	local AccessDate = A[&#039;AccessDate&#039;];&lt;br /&gt;
	local Agency = A[&#039;Agency&#039;];&lt;br /&gt;
&lt;br /&gt;
	local Language = A[&#039;Language&#039;];&lt;br /&gt;
	local Format = A[&#039;Format&#039;];&lt;br /&gt;
	local ChapterFormat = A[&#039;ChapterFormat&#039;];&lt;br /&gt;
	local DoiBroken = A[&#039;DoiBroken&#039;];&lt;br /&gt;
	local ID = A[&#039;ID&#039;];&lt;br /&gt;
	local ASINTLD = A[&#039;ASINTLD&#039;];&lt;br /&gt;
	local IgnoreISBN = A[&#039;IgnoreISBN&#039;];&lt;br /&gt;
		if not is_valid_parameter_value (IgnoreISBN, &#039;ignore-isbn-error&#039;, cfg.keywords [&#039;yes_true_y&#039;]) then&lt;br /&gt;
			IgnoreISBN = nil;													-- anything else, set to empty string&lt;br /&gt;
		end&lt;br /&gt;
	local Embargo = A[&#039;Embargo&#039;];&lt;br /&gt;
	local Class = A[&#039;Class&#039;];													-- arxiv class identifier&lt;br /&gt;
&lt;br /&gt;
	local ID_list = extract_ids( args );&lt;br /&gt;
	local ID_access_levels = extract_id_access_levels( args, ID_list );&lt;br /&gt;
&lt;br /&gt;
	local Quote = A[&#039;Quote&#039;];&lt;br /&gt;
&lt;br /&gt;
	local LayFormat = A[&#039;LayFormat&#039;];&lt;br /&gt;
	local LayURL = A[&#039;LayURL&#039;];&lt;br /&gt;
	local LaySource = A[&#039;LaySource&#039;];&lt;br /&gt;
	local Transcript = A[&#039;Transcript&#039;];&lt;br /&gt;
	local TranscriptFormat = A[&#039;TranscriptFormat&#039;];&lt;br /&gt;
	local TranscriptURL = A[&#039;TranscriptURL&#039;] &lt;br /&gt;
	local TranscriptURLorigin = A:ORIGIN(&#039;TranscriptURL&#039;);						-- get name of parameter that holds TranscriptURL&lt;br /&gt;
&lt;br /&gt;
	local LastAuthorAmp = A[&#039;LastAuthorAmp&#039;];&lt;br /&gt;
		if not is_valid_parameter_value (LastAuthorAmp, &#039;last-author-amp&#039;, cfg.keywords [&#039;yes_true_y&#039;]) then&lt;br /&gt;
			LastAuthorAmp = nil;												-- set to empty string&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	local no_tracking_cats = A[&#039;NoTracking&#039;];&lt;br /&gt;
		if not is_valid_parameter_value (no_tracking_cats, &#039;no-tracking&#039;, cfg.keywords [&#039;yes_true_y&#039;]) then&lt;br /&gt;
			no_tracking_cats = nil;												-- set to empty string&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	--local variables that are not cs1 parameters&lt;br /&gt;
	local use_lowercase;														-- controls capitalization of certain static text&lt;br /&gt;
	local this_page = mw.title.getCurrentTitle();								-- also used for COinS and for language&lt;br /&gt;
	local anchor_year;															-- used in the CITEREF identifier&lt;br /&gt;
	local COinS_date = {};														-- holds date info extracted from |date= for the COinS metadata by Module:Date verification&lt;br /&gt;
&lt;br /&gt;
	local DF = A[&#039;DF&#039;];															-- date format set in cs1|2 template&lt;br /&gt;
	if not is_valid_parameter_value (DF, &#039;df&#039;, cfg.keywords[&#039;date-format&#039;]) then	-- validate reformatting keyword&lt;br /&gt;
		DF = &#039;&#039;;																-- not valid, set to empty string&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local sepc;											-- separator between citation elements for CS1 a period, for CS2, a comma&lt;br /&gt;
	local PostScript;&lt;br /&gt;
	local Ref;&lt;br /&gt;
	sepc, PostScript, Ref = set_style (Mode:lower(), A[&#039;PostScript&#039;], A[&#039;Ref&#039;], config.CitationClass);&lt;br /&gt;
	use_lowercase = ( sepc == &#039;,&#039; );					-- used to control capitalization for certain static text&lt;br /&gt;
&lt;br /&gt;
	--check this page to see if it is in one of the namespaces that cs1 is not supposed to add to the error categories&lt;br /&gt;
	if not is_set (no_tracking_cats) then										-- ignore if we are already not going to categorize this page&lt;br /&gt;
		if in_array (this_page.nsText, cfg.uncategorized_namespaces) then&lt;br /&gt;
			no_tracking_cats = &amp;quot;true&amp;quot;;											-- set no_tracking_cats&lt;br /&gt;
		end&lt;br /&gt;
		for _,v in ipairs (cfg.uncategorized_subpages) do						-- cycle through page name patterns&lt;br /&gt;
			if this_page.text:match (v) then									-- test page name against each pattern&lt;br /&gt;
				no_tracking_cats = &amp;quot;true&amp;quot;;										-- set no_tracking_cats&lt;br /&gt;
				break;															-- bail out if one is found&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- check for extra |page=, |pages= or |at= parameters. (also sheet and sheets while we&#039;re at it)&lt;br /&gt;
	select_one( args, {&#039;page&#039;, &#039;p&#039;, &#039;pp&#039;, &#039;pages&#039;, &#039;at&#039;, &#039;sheet&#039;, &#039;sheets&#039;}, &#039;redundant_parameters&#039; );		-- this is a dummy call simply to get the error message and category&lt;br /&gt;
&lt;br /&gt;
	local NoPP = A[&#039;NoPP&#039;] &lt;br /&gt;
	if is_set (NoPP) and is_valid_parameter_value (NoPP, &#039;nopp&#039;, cfg.keywords [&#039;yes_true_y&#039;]) then&lt;br /&gt;
		NoPP = true;&lt;br /&gt;
	else&lt;br /&gt;
		NoPP = nil;																-- unset, used as a flag later&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set(Page) then&lt;br /&gt;
		if is_set(Pages) or is_set(At) then&lt;br /&gt;
			Pages = &#039;&#039;;															-- unset the others&lt;br /&gt;
			At = &#039;&#039;;&lt;br /&gt;
		end&lt;br /&gt;
		extra_text_in_page_check (Page);										-- add this page to maint cat if |page= value begins with what looks like p. or pp.&lt;br /&gt;
	elseif is_set(Pages) then&lt;br /&gt;
		if is_set(At) then&lt;br /&gt;
			At = &#039;&#039;;															-- unset&lt;br /&gt;
		end&lt;br /&gt;
		extra_text_in_page_check (Pages);										-- add this page to maint cat if |pages= value begins with what looks like p. or pp.&lt;br /&gt;
	end	&lt;br /&gt;
&lt;br /&gt;
	-- both |publication-place= and |place= (|location=) allowed if different&lt;br /&gt;
	if not is_set(PublicationPlace) and is_set(Place) then&lt;br /&gt;
		PublicationPlace = Place;							-- promote |place= (|location=) to |publication-place&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if PublicationPlace == Place then Place = &#039;&#039;; end		-- don&#039;t need both if they are the same&lt;br /&gt;
	&lt;br /&gt;
	--[[&lt;br /&gt;
	Parameter remapping for cite encyclopedia:&lt;br /&gt;
	When the citation has these parameters:&lt;br /&gt;
		|encyclopedia and |title then map |title to |article and |encyclopedia to |title&lt;br /&gt;
		|encyclopedia and |article then map |encyclopedia to |title&lt;br /&gt;
		|encyclopedia then map |encyclopedia to |title&lt;br /&gt;
	&lt;br /&gt;
		|trans-title maps to |trans-chapter when |title is re-mapped&lt;br /&gt;
		|url maps to |chapterurl when |title is remapped&lt;br /&gt;
	&lt;br /&gt;
	All other combinations of |encyclopedia, |title, and |article are not modified&lt;br /&gt;
	&lt;br /&gt;
	]]&lt;br /&gt;
&lt;br /&gt;
local Encyclopedia = A[&#039;Encyclopedia&#039;];&lt;br /&gt;
&lt;br /&gt;
	if ( config.CitationClass == &amp;quot;encyclopaedia&amp;quot; ) or ( config.CitationClass == &amp;quot;citation&amp;quot; and is_set (Encyclopedia)) then	-- test code for citation&lt;br /&gt;
		if is_set(Periodical) then												-- Periodical is set when |encyclopedia is set&lt;br /&gt;
			if is_set(Title) or is_set (ScriptTitle) then&lt;br /&gt;
				if not is_set(Chapter) then&lt;br /&gt;
					Chapter = Title;											-- |encyclopedia and |title are set so map |title to |article and |encyclopedia to |title&lt;br /&gt;
					ScriptChapter = ScriptTitle;&lt;br /&gt;
					TransChapter = TransTitle;&lt;br /&gt;
					ChapterURL = URL;&lt;br /&gt;
					ChapterUrlAccess = UrlAccess;&lt;br /&gt;
&lt;br /&gt;
					if not is_set (ChapterURL) and is_set (TitleLink) then&lt;br /&gt;
						Chapter = make_wikilink (TitleLink, Chapter);&lt;br /&gt;
					end&lt;br /&gt;
					Title = Periodical;&lt;br /&gt;
					ChapterFormat = Format;&lt;br /&gt;
					Periodical = &#039;&#039;;											-- redundant so unset&lt;br /&gt;
					TransTitle = &#039;&#039;;&lt;br /&gt;
					URL = &#039;&#039;;&lt;br /&gt;
					Format = &#039;&#039;;&lt;br /&gt;
					TitleLink = &#039;&#039;;&lt;br /&gt;
					ScriptTitle = &#039;&#039;;&lt;br /&gt;
				end&lt;br /&gt;
			else																-- |title not set&lt;br /&gt;
				Title = Periodical;												-- |encyclopedia set and |article set or not set so map |encyclopedia to |title&lt;br /&gt;
				Periodical = &#039;&#039;;												-- redundant so unset&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Special case for cite techreport.&lt;br /&gt;
	if (config.CitationClass == &amp;quot;techreport&amp;quot;) then								-- special case for cite techreport&lt;br /&gt;
		if is_set(A[&#039;Number&#039;]) then												-- cite techreport uses &#039;number&#039;, which other citations alias to &#039;issue&#039;&lt;br /&gt;
			if not is_set(ID) then												-- can we use ID for the &amp;quot;number&amp;quot;?&lt;br /&gt;
				ID = A[&#039;Number&#039;];												-- yes, use it&lt;br /&gt;
			else																-- ID has a value so emit error message&lt;br /&gt;
				table.insert( z.message_tail, { set_error(&#039;redundant_parameters&#039;, {wrap_style (&#039;parameter&#039;, &#039;id&#039;) .. &#039; and &#039; .. wrap_style (&#039;parameter&#039;, &#039;number&#039;)}, true )});&lt;br /&gt;
			end&lt;br /&gt;
		end	&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- special case for cite mailing list&lt;br /&gt;
	if (config.CitationClass == &amp;quot;mailinglist&amp;quot;) then&lt;br /&gt;
		Periodical = A [&#039;MailingList&#039;];&lt;br /&gt;
	elseif &#039;mailinglist&#039; == A:ORIGIN(&#039;Periodical&#039;) then&lt;br /&gt;
		Periodical = &#039;&#039;;														-- unset because mailing list is only used for cite mailing list&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Account for the oddity that is {{cite conference}}, before generation of COinS data.&lt;br /&gt;
	if &#039;conference&#039; == config.CitationClass then&lt;br /&gt;
		if is_set(BookTitle) then&lt;br /&gt;
			Chapter = Title;&lt;br /&gt;
--			ChapterLink = TitleLink;											-- |chapterlink= is deprecated&lt;br /&gt;
			ChapterURL = URL;&lt;br /&gt;
			ChapterUrlAccess = UrlAccess;&lt;br /&gt;
			ChapterURLorigin = URLorigin;&lt;br /&gt;
			URLorigin = &#039;&#039;;&lt;br /&gt;
			ChapterFormat = Format;&lt;br /&gt;
			TransChapter = TransTitle;&lt;br /&gt;
			Title = BookTitle;&lt;br /&gt;
			Format = &#039;&#039;;&lt;br /&gt;
--			TitleLink = &#039;&#039;;&lt;br /&gt;
			TransTitle = &#039;&#039;;&lt;br /&gt;
			URL = &#039;&#039;;&lt;br /&gt;
		end&lt;br /&gt;
	elseif &#039;speech&#039; ~= config.CitationClass then&lt;br /&gt;
		Conference = &#039;&#039;;														-- not cite conference or cite speech so make sure this is empty string&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- cite map oddities&lt;br /&gt;
	local Cartography = &amp;quot;&amp;quot;;&lt;br /&gt;
	local Scale = &amp;quot;&amp;quot;;&lt;br /&gt;
	local Sheet = A[&#039;Sheet&#039;] or &#039;&#039;;&lt;br /&gt;
	local Sheets = A[&#039;Sheets&#039;] or &#039;&#039;;&lt;br /&gt;
	if config.CitationClass == &amp;quot;map&amp;quot; then&lt;br /&gt;
		Chapter = A[&#039;Map&#039;];&lt;br /&gt;
		ChapterURL = A[&#039;MapURL&#039;];&lt;br /&gt;
		ChapterUrlAccess = UrlAccess;&lt;br /&gt;
		TransChapter = A[&#039;TransMap&#039;];&lt;br /&gt;
		ChapterURLorigin = A:ORIGIN(&#039;MapURL&#039;);&lt;br /&gt;
		ChapterFormat = A[&#039;MapFormat&#039;];&lt;br /&gt;
		&lt;br /&gt;
		Cartography = A[&#039;Cartography&#039;];&lt;br /&gt;
		if is_set( Cartography ) then&lt;br /&gt;
			Cartography = sepc .. &amp;quot; &amp;quot; .. wrap_msg (&#039;cartography&#039;, Cartography, use_lowercase);&lt;br /&gt;
		end		&lt;br /&gt;
		Scale = A[&#039;Scale&#039;];&lt;br /&gt;
		if is_set( Scale ) then&lt;br /&gt;
			Scale = sepc .. &amp;quot; &amp;quot; .. Scale;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Account for the oddities that are {{cite episode}} and {{cite serial}}, before generation of COinS data.&lt;br /&gt;
	if &#039;episode&#039; == config.CitationClass or &#039;serial&#039; == config.CitationClass then&lt;br /&gt;
		local AirDate = A[&#039;AirDate&#039;];&lt;br /&gt;
		local SeriesLink = A[&#039;SeriesLink&#039;];&lt;br /&gt;
&lt;br /&gt;
		link_title_ok (SeriesLink, A:ORIGIN (&#039;SeriesLink&#039;), Series, &#039;series&#039;);	-- check for wikimarkup in |series-link= or wikimarkup in |series= when |series-link= is set&lt;br /&gt;
&lt;br /&gt;
		local Network = A[&#039;Network&#039;];&lt;br /&gt;
		local Station = A[&#039;Station&#039;];&lt;br /&gt;
		local s, n = {}, {};&lt;br /&gt;
																				-- do common parameters first&lt;br /&gt;
		if is_set(Network) then table.insert(n, Network); end&lt;br /&gt;
		if is_set(Station) then table.insert(n, Station); end&lt;br /&gt;
		ID = table.concat(n, sepc .. &#039; &#039;);&lt;br /&gt;
		&lt;br /&gt;
		if not is_set (Date) and is_set (AirDate) then							-- promote airdate to date&lt;br /&gt;
			Date = AirDate;&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		if &#039;episode&#039; == config.CitationClass then								-- handle the oddities that are strictly {{cite episode}}&lt;br /&gt;
			local Season = A[&#039;Season&#039;];&lt;br /&gt;
			local SeriesNumber = A[&#039;SeriesNumber&#039;];&lt;br /&gt;
&lt;br /&gt;
			if is_set (Season) and is_set (SeriesNumber) then					-- these are mutually exclusive so if both are set&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;redundant_parameters&#039;, {wrap_style (&#039;parameter&#039;, &#039;season&#039;) .. &#039; and &#039; .. wrap_style (&#039;parameter&#039;, &#039;seriesno&#039;)}, true ) } );		-- add error message&lt;br /&gt;
				SeriesNumber = &#039;&#039;;												-- unset; prefer |season= over |seriesno=&lt;br /&gt;
			end&lt;br /&gt;
																				-- assemble a table of parts concatenated later into Series&lt;br /&gt;
			if is_set(Season) then table.insert(s, wrap_msg (&#039;season&#039;, Season, use_lowercase)); end&lt;br /&gt;
			if is_set(SeriesNumber) then table.insert(s, wrap_msg (&#039;series&#039;, SeriesNumber, use_lowercase)); end&lt;br /&gt;
			if is_set(Issue) then table.insert(s, wrap_msg (&#039;episode&#039;, Issue, use_lowercase)); end&lt;br /&gt;
			Issue = &#039;&#039;;															-- unset because this is not a unique parameter&lt;br /&gt;
	&lt;br /&gt;
			Chapter = Title;													-- promote title parameters to chapter&lt;br /&gt;
			ScriptChapter = ScriptTitle;&lt;br /&gt;
			ChapterLink = TitleLink;											-- alias episodelink&lt;br /&gt;
			TransChapter = TransTitle;&lt;br /&gt;
			ChapterURL = URL;&lt;br /&gt;
			ChapterUrlAccess = UrlAccess;&lt;br /&gt;
			ChapterURLorigin = A:ORIGIN(&#039;URL&#039;);&lt;br /&gt;
			&lt;br /&gt;
			Title = Series;														-- promote series to title&lt;br /&gt;
			TitleLink = SeriesLink;&lt;br /&gt;
			Series = table.concat(s, sepc .. &#039; &#039;);								-- this is concatenation of season, seriesno, episode number&lt;br /&gt;
&lt;br /&gt;
			if is_set (ChapterLink) and not is_set (ChapterURL) then			-- link but not URL&lt;br /&gt;
				Chapter = make_wikilink (ChapterLink, Chapter);&lt;br /&gt;
			elseif is_set (ChapterLink) and is_set (ChapterURL) then			-- if both are set, URL links episode;&lt;br /&gt;
				Series = make_wikilink (ChapterLink, Series);&lt;br /&gt;
			end&lt;br /&gt;
			URL = &#039;&#039;;															-- unset&lt;br /&gt;
			TransTitle = &#039;&#039;;&lt;br /&gt;
			ScriptTitle = &#039;&#039;;&lt;br /&gt;
			&lt;br /&gt;
		else																	-- now oddities that are cite serial&lt;br /&gt;
			Issue = &#039;&#039;;															-- unset because this parameter no longer supported by the citation/core version of cite serial&lt;br /&gt;
			Chapter = A[&#039;Episode&#039;];												-- TODO: make |episode= available to cite episode someday?&lt;br /&gt;
			if is_set (Series) and is_set (SeriesLink) then&lt;br /&gt;
				Series = make_wikilink (SeriesLink, Series);&lt;br /&gt;
			end&lt;br /&gt;
			Series = wrap_style (&#039;italic-title&#039;, Series);						-- series is italicized&lt;br /&gt;
		end	&lt;br /&gt;
	end&lt;br /&gt;
	-- end of {{cite episode}} stuff&lt;br /&gt;
&lt;br /&gt;
	-- Account for the oddities that are {{cite arxiv}}, {{cite biorxiv}}, {{cite citeseerx}}, before generation of COinS data.&lt;br /&gt;
	do&lt;br /&gt;
		if in_array (config.CitationClass, {&#039;arxiv&#039;, &#039;biorxiv&#039;, &#039;citeseerx&#039;}) then&lt;br /&gt;
			if not is_set (ID_list[config.CitationClass:upper()]) then			-- |arxiv= or |eprint= required for cite arxiv; |biorxiv= &amp;amp; |citeseerx= required for their templates&lt;br /&gt;
				table.insert( z.message_tail, { set_error( config.CitationClass .. &#039;_missing&#039;, {}, true ) } );		-- add error message&lt;br /&gt;
			end&lt;br /&gt;
			&lt;br /&gt;
			if &#039;arxiv&#039; == config.CitationClass then&lt;br /&gt;
				Periodical = &#039;arXiv&#039;;											-- set to arXiv for COinS; after that, must be set to empty string&lt;br /&gt;
			end&lt;br /&gt;
&lt;br /&gt;
			if &#039;biorxiv&#039; == config.CitationClass then&lt;br /&gt;
				Periodical = &#039;bioRxiv&#039;;											-- set to bioRxiv for COinS; after that, must be set to empty string&lt;br /&gt;
			end&lt;br /&gt;
&lt;br /&gt;
			if &#039;citeseerx&#039; == config.CitationClass then&lt;br /&gt;
				Periodical = &#039;CiteSeerX&#039;;										-- set to CiteSeerX for COinS; after that, must be set to empty string&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- handle type parameter for those CS1 citations that have default values&lt;br /&gt;
	if in_array(config.CitationClass, {&amp;quot;AV-media-notes&amp;quot;, &amp;quot;interview&amp;quot;, &amp;quot;mailinglist&amp;quot;, &amp;quot;map&amp;quot;, &amp;quot;podcast&amp;quot;, &amp;quot;pressrelease&amp;quot;, &amp;quot;report&amp;quot;, &amp;quot;techreport&amp;quot;, &amp;quot;thesis&amp;quot;}) then&lt;br /&gt;
		TitleType = set_titletype (config.CitationClass, TitleType);&lt;br /&gt;
		if is_set(Degree) and &amp;quot;Thesis&amp;quot; == TitleType then						-- special case for cite thesis&lt;br /&gt;
			TitleType = Degree .. &#039; &#039; .. cfg.title_types [&#039;thesis&#039;]:lower();&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set(TitleType) then													-- if type parameter is specified&lt;br /&gt;
		TitleType = substitute( cfg.messages[&#039;type&#039;], TitleType);				-- display it in parentheses&lt;br /&gt;
	-- TODO: Hack on TitleType to fix bunched parentheses problem&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- legacy: promote PublicationDate to Date if neither Date nor Year are set.&lt;br /&gt;
	if not is_set (Date) then&lt;br /&gt;
		Date = Year;															-- promote Year to Date&lt;br /&gt;
		Year = nil;																-- make nil so Year as empty string isn&#039;t used for CITEREF&lt;br /&gt;
		if not is_set (Date) and is_set(PublicationDate) then					-- use PublicationDate when |date= and |year= are not set&lt;br /&gt;
			Date = PublicationDate;												-- promote PublicationDate to Date&lt;br /&gt;
			PublicationDate = &#039;&#039;;												-- unset, no longer needed&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if PublicationDate == Date then PublicationDate = &#039;&#039;; end					-- if PublicationDate is same as Date, don&#039;t display in rendered citation&lt;br /&gt;
&lt;br /&gt;
	--[[&lt;br /&gt;
	Go test all of the date-holding parameters for valid MOS:DATE format and make sure that dates are real dates. This must be done before we do COinS because here is where&lt;br /&gt;
	we get the date used in the metadata.&lt;br /&gt;
	&lt;br /&gt;
	Date validation supporting code is in Module:Citation/CS1/Date_validation&lt;br /&gt;
	]]&lt;br /&gt;
	do	-- create defined block to contain local variables error_message, date_parameters_list, mismatch&lt;br /&gt;
		local error_message = &#039;&#039;;&lt;br /&gt;
																				-- AirDate has been promoted to Date so not necessary to check it&lt;br /&gt;
		local date_parameters_list = {[&#039;access-date&#039;]=AccessDate, [&#039;archive-date&#039;]=ArchiveDate, [&#039;date&#039;]=Date, [&#039;doi-broken-date&#039;]=DoiBroken,&lt;br /&gt;
				[&#039;embargo&#039;]=Embargo, [&#039;lay-date&#039;]=LayDate, [&#039;publication-date&#039;]=PublicationDate, [&#039;year&#039;]=Year};&lt;br /&gt;
&lt;br /&gt;
		anchor_year, Embargo, error_message = dates(date_parameters_list, COinS_date);&lt;br /&gt;
-- start temporary Julian / Gregorian calendar uncertainty categorization&lt;br /&gt;
		if COinS_date.inter_cal_cat then&lt;br /&gt;
			add_prop_cat (&#039;jul_greg_uncertainty&#039;);&lt;br /&gt;
		end&lt;br /&gt;
-- end temporary Julian / Gregorian calendar uncertainty categorization&lt;br /&gt;
&lt;br /&gt;
		if is_set (Year) and is_set (Date) then									-- both |date= and |year= not normally needed; &lt;br /&gt;
			local mismatch = year_date_check (Year, Date)&lt;br /&gt;
			if 0 == mismatch then												-- |year= does not match a year-value in |date=&lt;br /&gt;
				if is_set (error_message) then									-- if there is already an error message&lt;br /&gt;
					error_message = error_message .. &#039;, &#039;;						-- tack on this additional message&lt;br /&gt;
				end&lt;br /&gt;
				error_message = error_message .. &#039;&amp;amp;#124;year= / &amp;amp;#124;date= mismatch&#039;;&lt;br /&gt;
			elseif 1 == mismatch then											-- |year= matches year-value in |date=&lt;br /&gt;
				add_maint_cat (&#039;date_year&#039;);&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		if not is_set(error_message) then										-- error free dates only&lt;br /&gt;
			local modified = false;												-- flag&lt;br /&gt;
			&lt;br /&gt;
			if is_set (DF) then													-- if we need to reformat dates&lt;br /&gt;
				modified = reformat_dates (date_parameters_list, DF, false);	-- reformat to DF format, use long month names if appropriate&lt;br /&gt;
			end&lt;br /&gt;
&lt;br /&gt;
			if true == date_hyphen_to_dash (date_parameters_list) then			-- convert hyphens to dashes where appropriate&lt;br /&gt;
				modified = true;&lt;br /&gt;
				add_maint_cat (&#039;date_format&#039;);									-- hyphens were converted so add maint category&lt;br /&gt;
			end&lt;br /&gt;
			&lt;br /&gt;
	-- for those wikis that can and want to have English date names translated to the local language,&lt;br /&gt;
	-- uncomment these three lines.  Not supported by en.wiki (for obvious reasons)&lt;br /&gt;
--			if date_name_xlate (date_parameters_list) then&lt;br /&gt;
--				modified = true;&lt;br /&gt;
--			end&lt;br /&gt;
&lt;br /&gt;
			if modified then													-- if the date_parameters_list values were modified&lt;br /&gt;
				AccessDate = date_parameters_list[&#039;access-date&#039;];				-- overwrite date holding parameters with modified values&lt;br /&gt;
				ArchiveDate = date_parameters_list[&#039;archive-date&#039;];&lt;br /&gt;
				Date = date_parameters_list[&#039;date&#039;];&lt;br /&gt;
				DoiBroken = date_parameters_list[&#039;doi-broken-date&#039;];&lt;br /&gt;
				LayDate = date_parameters_list[&#039;lay-date&#039;];&lt;br /&gt;
				PublicationDate = date_parameters_list[&#039;publication-date&#039;];&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;bad_date&#039;, {error_message}, true ) } );	-- add this error message&lt;br /&gt;
		end&lt;br /&gt;
	end	-- end of do&lt;br /&gt;
&lt;br /&gt;
	-- Account for the oddity that is {{cite journal}} with |pmc= set and |url= not set.  Do this after date check but before COInS.&lt;br /&gt;
	-- Here we unset Embargo if PMC not embargoed (|embargo= not set in the citation) or if the embargo time has expired. Otherwise, holds embargo date&lt;br /&gt;
	Embargo = is_embargoed (Embargo);&lt;br /&gt;
&lt;br /&gt;
	if config.CitationClass == &amp;quot;journal&amp;quot; and not is_set(URL) and is_set(ID_list[&#039;PMC&#039;]) then&lt;br /&gt;
		if not is_set (Embargo) then											-- if not embargoed or embargo has expired&lt;br /&gt;
			URL=cfg.id_handlers[&#039;PMC&#039;].prefix .. ID_list[&#039;PMC&#039;];				-- set url to be the same as the PMC external link if not embargoed&lt;br /&gt;
			URLorigin = cfg.id_handlers[&#039;PMC&#039;].parameters[1];					-- set URLorigin to parameter name for use in error message if citation is missing a |title=&lt;br /&gt;
			if is_set(AccessDate) then											-- access date requires |url=; pmc created url is not |url=&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;accessdate_missing_url&#039;, {}, true ) } );&lt;br /&gt;
				AccessDate = &#039;&#039;;												-- unset&lt;br /&gt;
			end&lt;br /&gt;
&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- At this point fields may be nil if they weren&#039;t specified in the template use.  We can use that fact.&lt;br /&gt;
	-- Test if citation has no title&lt;br /&gt;
	if	not is_set(Title) and&lt;br /&gt;
		not is_set(TransTitle) and&lt;br /&gt;
		not is_set(ScriptTitle) then&lt;br /&gt;
			if &#039;episode&#039; == config.CitationClass then							-- special case for cite episode; TODO: is there a better way to do this?&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;citation_missing_title&#039;, {&#039;series&#039;}, true ) } );&lt;br /&gt;
			else&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;citation_missing_title&#039;, {&#039;title&#039;}, true ) } );&lt;br /&gt;
			end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if &#039;none&#039; == Title and in_array (config.CitationClass, {&#039;journal&#039;, &#039;citation&#039;}) and is_set (Periodical) and &#039;journal&#039; == A:ORIGIN(&#039;Periodical&#039;) then	-- special case for journal cites&lt;br /&gt;
		Title = &#039;&#039;;																-- set title to empty string&lt;br /&gt;
		add_maint_cat (&#039;untitled&#039;);&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	check_for_url ({															-- add error message when any of these parameters contains a URL&lt;br /&gt;
		[&#039;title&#039;]=Title,&lt;br /&gt;
		[A:ORIGIN(&#039;Chapter&#039;)]=Chapter,&lt;br /&gt;
		[A:ORIGIN(&#039;Periodical&#039;)]=Periodical,&lt;br /&gt;
		[A:ORIGIN(&#039;PublisherName&#039;)] = PublisherName&lt;br /&gt;
		});&lt;br /&gt;
&lt;br /&gt;
	-- COinS metadata (see &amp;lt;http://ocoins.info/&amp;gt;) for automated parsing of citation information.&lt;br /&gt;
	-- handle the oddity that is cite encyclopedia and {{citation |encyclopedia=something}}. Here we presume that&lt;br /&gt;
	-- when Periodical, Title, and Chapter are all set, then Periodical is the book (encyclopedia) title, Title&lt;br /&gt;
	-- is the article title, and Chapter is a section within the article.  So, we remap &lt;br /&gt;
	&lt;br /&gt;
	local coins_chapter = Chapter;												-- default assuming that remapping not required&lt;br /&gt;
	local coins_title = Title;													-- et tu&lt;br /&gt;
	if &#039;encyclopaedia&#039; == config.CitationClass or (&#039;citation&#039; == config.CitationClass and is_set (Encyclopedia)) then&lt;br /&gt;
		if is_set (Chapter) and is_set (Title) and is_set (Periodical) then		-- if all are used then&lt;br /&gt;
			coins_chapter = Title;												-- remap&lt;br /&gt;
			coins_title = Periodical;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local coins_author = a;														-- default for coins rft.au &lt;br /&gt;
	if 0 &amp;lt; #c then																-- but if contributor list&lt;br /&gt;
		coins_author = c;														-- use that instead&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- this is the function call to COinS()&lt;br /&gt;
	local OCinSoutput = COinS({&lt;br /&gt;
		[&#039;Periodical&#039;] = Periodical,&lt;br /&gt;
		[&#039;Encyclopedia&#039;] = Encyclopedia,&lt;br /&gt;
		[&#039;Chapter&#039;] = make_coins_title (coins_chapter, ScriptChapter),			-- Chapter and ScriptChapter stripped of bold / italic wikimarkup&lt;br /&gt;
		[&#039;Degree&#039;] = Degree;													-- cite thesis only&lt;br /&gt;
		[&#039;Title&#039;] = make_coins_title (coins_title, ScriptTitle),				-- Title and ScriptTitle stripped of bold / italic wikimarkup&lt;br /&gt;
		[&#039;PublicationPlace&#039;] = PublicationPlace,&lt;br /&gt;
		[&#039;Date&#039;] = COinS_date.rftdate,											-- COinS_date has correctly formatted date if Date is valid;&lt;br /&gt;
		[&#039;Season&#039;] = COinS_date.rftssn,&lt;br /&gt;
		[&#039;Chron&#039;] =  COinS_date.rftchron or (not COinS_date.rftdate and Date) or &#039;&#039;,	-- chron but if not set and invalid date format use Date; keep this last bit?&lt;br /&gt;
		[&#039;Series&#039;] = Series,&lt;br /&gt;
		[&#039;Volume&#039;] = Volume,&lt;br /&gt;
		[&#039;Issue&#039;] = Issue,&lt;br /&gt;
		[&#039;Pages&#039;] = get_coins_pages (first_set ({Sheet, Sheets, Page, Pages, At}, 5)),				-- pages stripped of external links&lt;br /&gt;
		[&#039;Edition&#039;] = Edition,&lt;br /&gt;
		[&#039;PublisherName&#039;] = PublisherName,&lt;br /&gt;
		[&#039;URL&#039;] = first_set ({ChapterURL, URL}, 2),&lt;br /&gt;
		[&#039;Authors&#039;] = coins_author,&lt;br /&gt;
		[&#039;ID_list&#039;] = ID_list,&lt;br /&gt;
		[&#039;RawPage&#039;] = this_page.prefixedText,&lt;br /&gt;
	}, config.CitationClass);&lt;br /&gt;
&lt;br /&gt;
	-- Account for the oddities that are {{cite arxiv}}, {{cite biorxiv}}, and {{cite citeseerx}} AFTER generation of COinS data.&lt;br /&gt;
	if in_array (config.CitationClass, {&#039;arxiv&#039;, &#039;biorxiv&#039;, &#039;citeseerx&#039;}) then	-- we have set rft.jtitle in COinS to arXiv, bioRxiv, or CiteSeerX now unset so it isn&#039;t displayed&lt;br /&gt;
		Periodical = &#039;&#039;;														-- periodical not allowed in these templates; if article has been published, use cite journal&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- special case for cite newsgroup.  Do this after COinS because we are modifying Publishername to include some static text&lt;br /&gt;
	if &#039;newsgroup&#039; == config.CitationClass then&lt;br /&gt;
		if is_set (PublisherName) then&lt;br /&gt;
			PublisherName = substitute (cfg.messages[&#039;newsgroup&#039;], external_link( &#039;news:&#039; .. PublisherName, PublisherName, A:ORIGIN(&#039;PublisherName&#039;), nil ));&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
	-- Now perform various field substitutions.&lt;br /&gt;
	-- We also add leading spaces and surrounding markup and punctuation to the&lt;br /&gt;
	-- various parts of the citation, but only when they are non-nil.&lt;br /&gt;
	local EditorCount;															-- used only for choosing {ed.) or (eds.) annotation at end of editor name-list&lt;br /&gt;
	do&lt;br /&gt;
		local last_first_list;&lt;br /&gt;
		local control = { &lt;br /&gt;
			format = NameListFormat,											-- empty string or &#039;vanc&#039;&lt;br /&gt;
			maximum = nil,														-- as if display-authors or display-editors not set&lt;br /&gt;
			lastauthoramp = LastAuthorAmp,&lt;br /&gt;
			page_name = this_page.text,											-- get current page name so that we don&#039;t wikilink to it via editorlinkn&lt;br /&gt;
			mode = Mode&lt;br /&gt;
		};&lt;br /&gt;
&lt;br /&gt;
		do																		-- do editor name list first because the now unsupported coauthors used to modify control table&lt;br /&gt;
			control.maximum , editor_etal = get_display_authors_editors (A[&#039;DisplayEditors&#039;], #e, &#039;editors&#039;, editor_etal);&lt;br /&gt;
			last_first_list, EditorCount = list_people(control, e, editor_etal);&lt;br /&gt;
&lt;br /&gt;
			if is_set (Editors) then&lt;br /&gt;
				if editor_etal then&lt;br /&gt;
					Editors = Editors .. &#039; &#039; .. cfg.messages[&#039;et al&#039;];			-- add et al. to editors parameter beause |display-editors=etal&lt;br /&gt;
					EditorCount = 2;											-- with et al., |editors= is multiple names; spoof to display (eds.) annotation&lt;br /&gt;
				else&lt;br /&gt;
					EditorCount = 2;											-- we don&#039;t know but assume |editors= is multiple names; spoof to display (eds.) annotation&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				Editors = last_first_list;										-- either an author name list or an empty string&lt;br /&gt;
			end&lt;br /&gt;
&lt;br /&gt;
			if 1 == EditorCount and (true == editor_etal or 1 &amp;lt; #e) then		-- only one editor displayed but includes etal then &lt;br /&gt;
				EditorCount = 2;												-- spoof to display (eds.) annotation&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		do																		-- now do interviewers&lt;br /&gt;
			control.maximum = #interviewers_list;							-- number of interviewerss&lt;br /&gt;
			Interviewers = list_people(control, interviewers_list, false);	-- et al not currently supported&lt;br /&gt;
		end&lt;br /&gt;
		do																		-- now do translators&lt;br /&gt;
			control.maximum = #t;												-- number of translators&lt;br /&gt;
			Translators = list_people(control, t, false);						-- et al not currently supported&lt;br /&gt;
		end&lt;br /&gt;
		do																		-- now do contributors&lt;br /&gt;
			control.maximum = #c;												-- number of contributors&lt;br /&gt;
			Contributors = list_people(control, c, false);						-- et al not currently supported&lt;br /&gt;
		end&lt;br /&gt;
		do																		-- now do authors&lt;br /&gt;
			control.maximum , author_etal = get_display_authors_editors (A[&#039;DisplayAuthors&#039;], #a, &#039;authors&#039;, author_etal);&lt;br /&gt;
&lt;br /&gt;
			last_first_list = list_people(control, a, author_etal);&lt;br /&gt;
&lt;br /&gt;
			if is_set (Authors) then&lt;br /&gt;
				Authors, author_etal = name_has_etal (Authors, author_etal, false);	-- find and remove variations on et al.&lt;br /&gt;
				if author_etal then&lt;br /&gt;
					Authors = Authors .. &#039; &#039; .. cfg.messages[&#039;et al&#039;];			-- add et al. to authors parameter&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				Authors = last_first_list;										-- either an author name list or an empty string&lt;br /&gt;
			end&lt;br /&gt;
		end																		-- end of do&lt;br /&gt;
	&lt;br /&gt;
		if is_set (Authors) and is_set (Collaboration) then&lt;br /&gt;
			Authors = Authors .. &#039; (&#039; .. Collaboration .. &#039;)&#039;;					-- add collaboration after et al.&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- apply |[xx-]format= styling; at the end, these parameters hold correctly styled format annotation,&lt;br /&gt;
	-- an error message if the associated url is not set, or an empty string for concatenation&lt;br /&gt;
	ArchiveFormat = style_format (ArchiveFormat, ArchiveURL, &#039;archive-format&#039;, &#039;archive-url&#039;);&lt;br /&gt;
	ConferenceFormat = style_format (ConferenceFormat, ConferenceURL, &#039;conference-format&#039;, &#039;conference-url&#039;);&lt;br /&gt;
	Format = style_format (Format, URL, &#039;format&#039;, &#039;url&#039;);&lt;br /&gt;
	LayFormat = style_format (LayFormat, LayURL, &#039;lay-format&#039;, &#039;lay-url&#039;);&lt;br /&gt;
	TranscriptFormat = style_format (TranscriptFormat, TranscriptURL, &#039;transcript-format&#039;, &#039;transcripturl&#039;);&lt;br /&gt;
&lt;br /&gt;
	-- special case for chapter format so no error message or cat when chapter not supported&lt;br /&gt;
	if not (in_array(config.CitationClass, {&#039;web&#039;, &#039;news&#039;, &#039;journal&#039;, &#039;magazine&#039;, &#039;pressrelease&#039;, &#039;podcast&#039;, &#039;newsgroup&#039;, &#039;arxiv&#039;, &#039;biorxiv&#039;, &#039;citeseerx&#039;}) or&lt;br /&gt;
		(&#039;citation&#039; == config.CitationClass and is_set (Periodical) and not is_set (Encyclopedia))) then&lt;br /&gt;
			ChapterFormat = style_format (ChapterFormat, ChapterURL, &#039;chapter-format&#039;, &#039;chapter-url&#039;);&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if not is_set(URL) then&lt;br /&gt;
		if in_array(config.CitationClass, {&amp;quot;web&amp;quot;,&amp;quot;podcast&amp;quot;, &amp;quot;mailinglist&amp;quot;}) then	-- |url= required for cite web, cite podcast, and cite mailinglist&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;cite_web_url&#039;, {}, true ) } );&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		-- do we have |accessdate= without either |url= or |chapter-url=?&lt;br /&gt;
		if is_set(AccessDate) and not is_set(ChapterURL)then					-- ChapterURL may be set when URL is not set;&lt;br /&gt;
			table.insert( z.message_tail, { set_error( &#039;accessdate_missing_url&#039;, {}, true ) } );&lt;br /&gt;
			AccessDate = &#039;&#039;;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local OriginalURL, OriginalURLorigin, OriginalFormat, OriginalAccess;&lt;br /&gt;
	DeadURL = DeadURL:lower();													-- used later when assembling archived text&lt;br /&gt;
	if is_set( ArchiveURL ) then&lt;br /&gt;
		if is_set (ChapterURL) then 											-- URL not set so if chapter-url is set apply archive url to it&lt;br /&gt;
			OriginalURL = ChapterURL;											-- save copy of source chapter&#039;s url for archive text&lt;br /&gt;
			OriginalURLorigin = ChapterURLorigin;								-- name of chapter-url parameter for error messages&lt;br /&gt;
			OriginalFormat = ChapterFormat;										-- and original |format=&lt;br /&gt;
			if &#039;no&#039; ~= DeadURL then&lt;br /&gt;
				ChapterURL = ArchiveURL											-- swap-in the archive&#039;s url&lt;br /&gt;
				ChapterURLorigin = A:ORIGIN(&#039;ArchiveURL&#039;)						-- name of archive-url parameter for error messages&lt;br /&gt;
				ChapterFormat = ArchiveFormat or &#039;&#039;;							-- swap in archive&#039;s format&lt;br /&gt;
			end&lt;br /&gt;
		elseif is_set (URL) then&lt;br /&gt;
			OriginalURL = URL;													-- save copy of original source URL&lt;br /&gt;
			OriginalURLorigin = URLorigin;										-- name of url parameter for error messages&lt;br /&gt;
			OriginalFormat = Format; 											-- and original |format=&lt;br /&gt;
			OriginalAccess = UrlAccess;&lt;br /&gt;
			if &#039;no&#039; ~= DeadURL then												-- if URL set then archive-url applies to it&lt;br /&gt;
				URL = ArchiveURL												-- swap-in the archive&#039;s url&lt;br /&gt;
				URLorigin = A:ORIGIN(&#039;ArchiveURL&#039;)								-- name of archive url parameter for error messages&lt;br /&gt;
				Format = ArchiveFormat or &#039;&#039;;									-- swap in archive&#039;s format&lt;br /&gt;
				UrlAccess = nil;												-- restricted access levels do not make sense for archived urls&lt;br /&gt;
			end&lt;br /&gt;
 		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if in_array(config.CitationClass, {&#039;web&#039;,&#039;news&#039;,&#039;journal&#039;, &#039;magazine&#039;, &#039;pressrelease&#039;, &#039;podcast&#039;, &#039;newsgroup&#039;, &#039;arxiv&#039;, &#039;biorxiv&#039;, &#039;citeseerx&#039;}) or	-- if any of the &#039;periodical&#039; cites except encyclopedia&lt;br /&gt;
		(&#039;citation&#039; == config.CitationClass and is_set (Periodical) and not is_set (Encyclopedia)) then&lt;br /&gt;
			local chap_param;&lt;br /&gt;
			if is_set (Chapter) then											-- get a parameter name from one of these chapter related meta-parameters&lt;br /&gt;
				chap_param = A:ORIGIN (&#039;Chapter&#039;)&lt;br /&gt;
			elseif is_set (TransChapter) then&lt;br /&gt;
				chap_param = A:ORIGIN (&#039;TransChapter&#039;)&lt;br /&gt;
			elseif is_set (ChapterURL) then&lt;br /&gt;
				chap_param = A:ORIGIN (&#039;ChapterURL&#039;)&lt;br /&gt;
			elseif is_set (ScriptChapter) then&lt;br /&gt;
				chap_param = A:ORIGIN (&#039;ScriptChapter&#039;)&lt;br /&gt;
			else is_set (ChapterFormat)&lt;br /&gt;
				chap_param = A:ORIGIN (&#039;ChapterFormat&#039;)&lt;br /&gt;
			end&lt;br /&gt;
&lt;br /&gt;
			if is_set (chap_param) then											-- if we found one&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;chapter_ignored&#039;, {chap_param}, true ) } );		-- add error message&lt;br /&gt;
				Chapter = &#039;&#039;;													-- and set them to empty string to be safe with concatenation&lt;br /&gt;
				TransChapter = &#039;&#039;;&lt;br /&gt;
				ChapterURL = &#039;&#039;;&lt;br /&gt;
				ScriptChapter = &#039;&#039;;&lt;br /&gt;
				ChapterFormat = &#039;&#039;;&lt;br /&gt;
			end&lt;br /&gt;
	else																		-- otherwise, format chapter / article title&lt;br /&gt;
		local no_quotes = false;												-- default assume that we will be quoting the chapter parameter value&lt;br /&gt;
		if is_set (Contribution) and 0 &amp;lt; #c then								-- if this is a contribution with contributor(s)&lt;br /&gt;
			if in_array (Contribution:lower(), cfg.keywords.contribution) then	-- and a generic contribution title&lt;br /&gt;
				no_quotes = true;												-- then render it unquoted&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
		Chapter = format_chapter_title (ScriptChapter, Chapter, TransChapter, ChapterURL, ChapterURLorigin, no_quotes, ChapterUrlAccess);		-- Contribution is also in Chapter&lt;br /&gt;
		if is_set (Chapter) then&lt;br /&gt;
			Chapter = Chapter .. ChapterFormat ;&lt;br /&gt;
			if &#039;map&#039; == config.CitationClass and is_set (TitleType) then&lt;br /&gt;
				Chapter = Chapter .. &#039; &#039; .. TitleType;							-- map annotation here; not after title&lt;br /&gt;
			end&lt;br /&gt;
			Chapter = Chapter.. sepc .. &#039; &#039;;&lt;br /&gt;
		elseif is_set (ChapterFormat) then										-- |chapter= not set but |chapter-format= is so ...&lt;br /&gt;
			Chapter = ChapterFormat .. sepc .. &#039; &#039;;								-- ... ChapterFormat has error message, we want to see it&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Format main title.&lt;br /&gt;
	if &#039;...&#039; == Title:sub (-3) then												-- if elipsis is the last three characters of |title=&lt;br /&gt;
		Title = mw.ustring.gsub (Title, &#039;(%.%.%.)%.+$&#039;, &#039;%1&#039;);					-- limit the number of dots to three&lt;br /&gt;
	elseif not mw.ustring.find (Title, &#039;%.%s*%a%.&#039;) then						-- end of title is not a &#039;dot-(optional space-)letter-dot&#039; initialism&lt;br /&gt;
		Title = mw.ustring.gsub(Title, &#039;%&#039;..sepc..&#039;$&#039;, &#039;&#039;);						-- remove any trailing separator character&lt;br /&gt;
	end&lt;br /&gt;
	if is_set(TitleLink) and is_set(Title) then&lt;br /&gt;
		Title = make_wikilink (TitleLink, Title);&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if in_array(config.CitationClass, {&#039;web&#039;, &#039;news&#039;, &#039;journal&#039;, &#039;magazine&#039;, &#039;pressrelease&#039;, &#039;podcast&#039;, &#039;newsgroup&#039;, &#039;mailinglist&#039;, &#039;interview&#039;, &#039;arxiv&#039;, &#039;biorxiv&#039;, &#039;citeseerx&#039;}) or&lt;br /&gt;
		(&#039;citation&#039; == config.CitationClass and is_set (Periodical) and not is_set (Encyclopedia)) or&lt;br /&gt;
		(&#039;map&#039; == config.CitationClass and is_set (Periodical)) then			-- special case for cite map when the map is in a periodical treat as an article&lt;br /&gt;
			Title = kern_quotes (Title);										-- if necessary, separate title&#039;s leading and trailing quote marks from Module provided quote marks&lt;br /&gt;
			Title = wrap_style (&#039;quoted-title&#039;, Title);&lt;br /&gt;
			Title = script_concatenate (Title, ScriptTitle);					-- &amp;lt;bdi&amp;gt; tags, lang atribute, categorization, etc; must be done after title is wrapped&lt;br /&gt;
			TransTitle= wrap_style (&#039;trans-quoted-title&#039;, TransTitle );&lt;br /&gt;
	elseif &#039;report&#039; == config.CitationClass then								-- no styling for cite report&lt;br /&gt;
		Title = script_concatenate (Title, ScriptTitle);						-- &amp;lt;bdi&amp;gt; tags, lang atribute, categorization, etc; must be done after title is wrapped&lt;br /&gt;
		TransTitle= wrap_style (&#039;trans-quoted-title&#039;, TransTitle );				-- for cite report, use this form for trans-title&lt;br /&gt;
	else&lt;br /&gt;
		Title = wrap_style (&#039;italic-title&#039;, Title);&lt;br /&gt;
		Title = script_concatenate (Title, ScriptTitle);						-- &amp;lt;bdi&amp;gt; tags, lang atribute, categorization, etc; must be done after title is wrapped&lt;br /&gt;
		TransTitle = wrap_style (&#039;trans-italic-title&#039;, TransTitle);&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local TransError = &amp;quot;&amp;quot;;&lt;br /&gt;
	if is_set(TransTitle) then&lt;br /&gt;
		if is_set(Title) then&lt;br /&gt;
			TransTitle = &amp;quot; &amp;quot; .. TransTitle;&lt;br /&gt;
		else&lt;br /&gt;
			TransError = &amp;quot; &amp;quot; .. set_error( &#039;trans_missing_title&#039;, {&#039;title&#039;} );&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if is_set(Title) then&lt;br /&gt;
		if not is_set(TitleLink) and is_set(URL) then&lt;br /&gt;
			&lt;br /&gt;
			Title = external_link( URL, Title, URLorigin, UrlAccess ) .. TransTitle .. TransError .. Format;&lt;br /&gt;
			URL = &#039;&#039;;															-- unset these because no longer needed&lt;br /&gt;
			Format = &amp;quot;&amp;quot;;&lt;br /&gt;
		else&lt;br /&gt;
			Title = Title .. TransTitle .. TransError;&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		Title = TransTitle .. TransError;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set(Place) then&lt;br /&gt;
		Place = &amp;quot; &amp;quot; .. wrap_msg (&#039;written&#039;, Place, use_lowercase) .. sepc .. &amp;quot; &amp;quot;;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set (Conference) then&lt;br /&gt;
		if is_set (ConferenceURL) then&lt;br /&gt;
			Conference = external_link( ConferenceURL, Conference, ConferenceURLorigin, nil );&lt;br /&gt;
		end&lt;br /&gt;
		Conference = sepc .. &amp;quot; &amp;quot; .. Conference .. ConferenceFormat;&lt;br /&gt;
	elseif is_set(ConferenceURL) then&lt;br /&gt;
		Conference = sepc .. &amp;quot; &amp;quot; .. external_link( ConferenceURL, nil, ConferenceURLorigin, nil );&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if not is_set(Position) then&lt;br /&gt;
		local Minutes = A[&#039;Minutes&#039;];&lt;br /&gt;
		local Time = A[&#039;Time&#039;];&lt;br /&gt;
&lt;br /&gt;
		if is_set(Minutes) then&lt;br /&gt;
			if is_set (Time) then&lt;br /&gt;
				table.insert( z.message_tail, { set_error( &#039;redundant_parameters&#039;, {wrap_style (&#039;parameter&#039;, &#039;minutes&#039;) .. &#039; and &#039; .. wrap_style (&#039;parameter&#039;, &#039;time&#039;)}, true ) } );&lt;br /&gt;
			end&lt;br /&gt;
			Position = &amp;quot; &amp;quot; .. Minutes .. &amp;quot; &amp;quot; .. cfg.messages[&#039;minutes&#039;];&lt;br /&gt;
		else&lt;br /&gt;
			if is_set(Time) then&lt;br /&gt;
				local TimeCaption = A[&#039;TimeCaption&#039;]&lt;br /&gt;
				if not is_set(TimeCaption) then&lt;br /&gt;
					TimeCaption = cfg.messages[&#039;event&#039;];&lt;br /&gt;
					if sepc ~= &#039;.&#039; then&lt;br /&gt;
						TimeCaption = TimeCaption:lower();&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
				Position = &amp;quot; &amp;quot; .. TimeCaption .. &amp;quot; &amp;quot; .. Time;&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	else&lt;br /&gt;
		Position = &amp;quot; &amp;quot; .. Position;&lt;br /&gt;
		At = &#039;&#039;;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	Page, Pages, Sheet, Sheets = format_pages_sheets (Page, Pages, Sheet, Sheets, config.CitationClass, Periodical_origin, sepc, NoPP, use_lowercase);&lt;br /&gt;
&lt;br /&gt;
	At = is_set(At) and (sepc .. &amp;quot; &amp;quot; .. At) or &amp;quot;&amp;quot;;&lt;br /&gt;
	Position = is_set(Position) and (sepc .. &amp;quot; &amp;quot; .. Position) or &amp;quot;&amp;quot;;&lt;br /&gt;
	if config.CitationClass == &#039;map&#039; then&lt;br /&gt;
		local Section = A[&#039;Section&#039;];&lt;br /&gt;
		local Sections = A[&#039;Sections&#039;];&lt;br /&gt;
		local Inset = A[&#039;Inset&#039;];&lt;br /&gt;
		&lt;br /&gt;
		if is_set( Inset ) then&lt;br /&gt;
			Inset = sepc .. &amp;quot; &amp;quot; .. wrap_msg (&#039;inset&#039;, Inset, use_lowercase);&lt;br /&gt;
		end			&lt;br /&gt;
&lt;br /&gt;
		if is_set( Sections ) then&lt;br /&gt;
			Section = sepc .. &amp;quot; &amp;quot; .. wrap_msg (&#039;sections&#039;, Sections, use_lowercase);&lt;br /&gt;
		elseif is_set( Section ) then&lt;br /&gt;
			Section = sepc .. &amp;quot; &amp;quot; .. wrap_msg (&#039;section&#039;, Section, use_lowercase);&lt;br /&gt;
		end&lt;br /&gt;
		At = At .. Inset .. Section;		&lt;br /&gt;
	end	&lt;br /&gt;
&lt;br /&gt;
	if is_set (Language) then&lt;br /&gt;
		Language = language_parameter (Language);								-- format, categories, name from ISO639-1, etc&lt;br /&gt;
	else&lt;br /&gt;
		Language=&amp;quot;&amp;quot;;															-- language not specified so make sure this is an empty string;&lt;br /&gt;
	--[[ TODO: need to extract the wrap_msg from language_parameter&lt;br /&gt;
	so that we can solve parentheses bunching problem with Format/Language/TitleType&lt;br /&gt;
	]]&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	Others = is_set(Others) and (sepc .. &amp;quot; &amp;quot; .. Others) or &amp;quot;&amp;quot;;&lt;br /&gt;
	&lt;br /&gt;
	if is_set (Translators) then&lt;br /&gt;
		Others = sepc .. &#039; &#039; .. wrap_msg (&#039;translated&#039;, Translators, use_lowercase) .. Others;&lt;br /&gt;
	end&lt;br /&gt;
	if is_set (Interviewers) then&lt;br /&gt;
		Others = sepc .. &#039; &#039; .. wrap_msg (&#039;interview&#039;, Interviewers, use_lowercase) .. Others;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	TitleNote = is_set(TitleNote) and (sepc .. &amp;quot; &amp;quot; .. TitleNote) or &amp;quot;&amp;quot;;&lt;br /&gt;
	if is_set (Edition) then&lt;br /&gt;
		if Edition:match (&#039;%f[%a][Ee]d%.?$&#039;) or Edition:match (&#039;%f[%a][Ee]dition$&#039;) then&lt;br /&gt;
			add_maint_cat (&#039;extra_text&#039;, &#039;edition&#039;);&lt;br /&gt;
		end&lt;br /&gt;
		Edition = &amp;quot; &amp;quot; .. wrap_msg (&#039;edition&#039;, Edition);&lt;br /&gt;
	else&lt;br /&gt;
		Edition = &#039;&#039;;&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	Series = is_set(Series) and (sepc .. &amp;quot; &amp;quot; .. Series) or &amp;quot;&amp;quot;;&lt;br /&gt;
		OrigYear = is_set(OrigYear) and (&amp;quot; [&amp;quot; .. OrigYear .. &amp;quot;]&amp;quot;) or &amp;quot;&amp;quot;;		-- TODO: presentation&lt;br /&gt;
&lt;br /&gt;
	Agency = is_set(Agency) and (sepc .. &amp;quot; &amp;quot; .. Agency) or &amp;quot;&amp;quot;;&lt;br /&gt;
&lt;br /&gt;
	Volume = format_volume_issue (Volume, Issue, config.CitationClass, Periodical_origin, sepc, use_lowercase);&lt;br /&gt;
&lt;br /&gt;
	------------------------------------ totally unrelated data&lt;br /&gt;
	if is_set(Via) then&lt;br /&gt;
		Via = &amp;quot; &amp;quot; .. wrap_msg (&#039;via&#039;, Via);&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	--[[&lt;br /&gt;
	Subscription implies paywall; Registration does not.  If both are used in a citation, the subscription required link&lt;br /&gt;
	note is displayed. There are no error messages for this condition.&lt;br /&gt;
	&lt;br /&gt;
	]]&lt;br /&gt;
	if is_set (SubscriptionRequired) then&lt;br /&gt;
		SubscriptionRequired = sepc .. &amp;quot; &amp;quot; .. cfg.messages[&#039;subscription&#039;];		-- subscription required message&lt;br /&gt;
	elseif is_set (RegistrationRequired) then&lt;br /&gt;
		SubscriptionRequired = sepc .. &amp;quot; &amp;quot; .. cfg.messages[&#039;registration&#039;];		-- registration required message&lt;br /&gt;
	else&lt;br /&gt;
		SubscriptionRequired = &#039;&#039;;												-- either or both might be set to something other than yes true y&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set(AccessDate) then&lt;br /&gt;
		local retrv_text = &amp;quot; &amp;quot; .. cfg.messages[&#039;retrieved&#039;]&lt;br /&gt;
&lt;br /&gt;
		AccessDate = nowrap_date (AccessDate);									-- wrap in nowrap span if date in appropriate format&lt;br /&gt;
		if (sepc ~= &amp;quot;.&amp;quot;) then retrv_text = retrv_text:lower() end				-- if mode is cs2, lower case&lt;br /&gt;
		AccessDate = substitute (retrv_text, AccessDate);						-- add retrieved text&lt;br /&gt;
&lt;br /&gt;
		AccessDate = substitute (cfg.presentation[&#039;accessdate&#039;], {sepc, AccessDate});	-- allow editors to hide accessdates&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if is_set(ID) then ID = sepc ..&amp;quot; &amp;quot;.. ID; end&lt;br /&gt;
   	if &amp;quot;thesis&amp;quot; == config.CitationClass and is_set(Docket) then&lt;br /&gt;
		ID = sepc ..&amp;quot; Docket &amp;quot;.. Docket .. ID;&lt;br /&gt;
	end&lt;br /&gt;
   	if &amp;quot;report&amp;quot; == config.CitationClass and is_set(Docket) then					-- for cite report when |docket= is set&lt;br /&gt;
		ID = sepc .. &#039; &#039; .. Docket;												-- overwrite ID even if |id= is set&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	ID_list = build_id_list( ID_list, {IdAccessLevels=ID_access_levels, DoiBroken = DoiBroken, ASINTLD = ASINTLD, IgnoreISBN = IgnoreISBN, Embargo=Embargo, Class = Class} );&lt;br /&gt;
&lt;br /&gt;
	if is_set(URL) then&lt;br /&gt;
		URL = &amp;quot; &amp;quot; .. external_link( URL, nil, URLorigin, UrlAccess );&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set(Quote) then&lt;br /&gt;
		if Quote:sub(1,1) == &#039;&amp;quot;&#039; and Quote:sub(-1,-1) == &#039;&amp;quot;&#039; then				-- if first and last characters of quote are quote marks&lt;br /&gt;
			Quote = Quote:sub(2,-2);											-- strip them off&lt;br /&gt;
		end&lt;br /&gt;
		Quote = sepc ..&amp;quot; &amp;quot; .. wrap_style (&#039;quoted-text&#039;, Quote ); 				-- wrap in &amp;lt;q&amp;gt;...&amp;lt;/q&amp;gt; tags&lt;br /&gt;
		PostScript = &amp;quot;&amp;quot;;														-- cs1|2 does not supply terminal punctuation when |quote= is set&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local Archived&lt;br /&gt;
	if is_set(ArchiveURL) then&lt;br /&gt;
		if not is_set(ArchiveDate) then&lt;br /&gt;
			ArchiveDate = set_error(&#039;archive_missing_date&#039;);&lt;br /&gt;
		end&lt;br /&gt;
		if &amp;quot;no&amp;quot; == DeadURL then&lt;br /&gt;
			local arch_text = cfg.messages[&#039;archived&#039;];&lt;br /&gt;
			if sepc ~= &amp;quot;.&amp;quot; then arch_text = arch_text:lower() end&lt;br /&gt;
			Archived = sepc .. &amp;quot; &amp;quot; .. substitute( cfg.messages[&#039;archived-not-dead&#039;],&lt;br /&gt;
				{ external_link( ArchiveURL, arch_text, A:ORIGIN(&#039;ArchiveURL&#039;), nil ) .. ArchiveFormat, ArchiveDate } );&lt;br /&gt;
			if not is_set(OriginalURL) then&lt;br /&gt;
				Archived = Archived .. &amp;quot; &amp;quot; .. set_error(&#039;archive_missing_url&#039;);							   &lt;br /&gt;
			end&lt;br /&gt;
		elseif is_set(OriginalURL) then											-- DeadURL is empty, &#039;yes&#039;, &#039;true&#039;, &#039;y&#039;, &#039;unfit&#039;, &#039;usurped&#039;&lt;br /&gt;
			local arch_text = cfg.messages[&#039;archived-dead&#039;];&lt;br /&gt;
			if sepc ~= &amp;quot;.&amp;quot; then arch_text = arch_text:lower() end&lt;br /&gt;
			if in_array (DeadURL, {&#039;unfit&#039;, &#039;usurped&#039;, &#039;bot: unknown&#039;}) then&lt;br /&gt;
				Archived = sepc .. &amp;quot; &amp;quot; .. &#039;Archived from the original on &#039; .. ArchiveDate;	-- format already styled&lt;br /&gt;
				if &#039;bot: unknown&#039; == DeadURL then&lt;br /&gt;
					add_maint_cat (&#039;bot:_unknown&#039;);								-- and add a category if not already added&lt;br /&gt;
				else&lt;br /&gt;
					add_maint_cat (&#039;unfit&#039;);									-- and add a category if not already added&lt;br /&gt;
				end&lt;br /&gt;
			else																-- DeadURL is empty, &#039;yes&#039;, &#039;true&#039;, or &#039;y&#039;&lt;br /&gt;
				Archived = sepc .. &amp;quot; &amp;quot; .. substitute( arch_text,&lt;br /&gt;
					{ external_link( OriginalURL, cfg.messages[&#039;original&#039;], OriginalURLorigin, OriginalAccess ) .. OriginalFormat, ArchiveDate } );	-- format already styled&lt;br /&gt;
			end	&lt;br /&gt;
		else&lt;br /&gt;
			local arch_text = cfg.messages[&#039;archived-missing&#039;];&lt;br /&gt;
			if sepc ~= &amp;quot;.&amp;quot; then arch_text = arch_text:lower() end&lt;br /&gt;
			Archived = sepc .. &amp;quot; &amp;quot; .. substitute( arch_text, &lt;br /&gt;
				{ set_error(&#039;archive_missing_url&#039;), ArchiveDate } );&lt;br /&gt;
		end&lt;br /&gt;
	elseif is_set (ArchiveFormat) then&lt;br /&gt;
		Archived = ArchiveFormat;												-- if set and ArchiveURL not set ArchiveFormat has error message&lt;br /&gt;
	else&lt;br /&gt;
		Archived = &amp;quot;&amp;quot;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local Lay = &#039;&#039;;&lt;br /&gt;
	if is_set(LayURL) then&lt;br /&gt;
		if is_set(LayDate) then LayDate = &amp;quot; (&amp;quot; .. LayDate .. &amp;quot;)&amp;quot; end&lt;br /&gt;
		if is_set(LaySource) then &lt;br /&gt;
			LaySource = &amp;quot; &amp;amp;ndash; &#039;&#039;&amp;quot; .. safe_for_italics(LaySource) .. &amp;quot;&#039;&#039;&amp;quot;;&lt;br /&gt;
		else&lt;br /&gt;
			LaySource = &amp;quot;&amp;quot;;&lt;br /&gt;
		end&lt;br /&gt;
		if sepc == &#039;.&#039; then&lt;br /&gt;
			Lay = sepc .. &amp;quot; &amp;quot; .. external_link( LayURL, cfg.messages[&#039;lay summary&#039;], A:ORIGIN(&#039;LayURL&#039;), nil ) .. LayFormat .. LaySource .. LayDate&lt;br /&gt;
		else&lt;br /&gt;
			Lay = sepc .. &amp;quot; &amp;quot; .. external_link( LayURL, cfg.messages[&#039;lay summary&#039;]:lower(), A:ORIGIN(&#039;LayURL&#039;), nil ) .. LayFormat .. LaySource .. LayDate&lt;br /&gt;
		end			&lt;br /&gt;
	elseif is_set (LayFormat) then												-- Test if |lay-format= is given without giving a |lay-url=&lt;br /&gt;
		Lay = sepc .. LayFormat;												-- if set and LayURL not set, then LayFormat has error message&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if is_set(Transcript) then&lt;br /&gt;
		if is_set(TranscriptURL) then&lt;br /&gt;
			Transcript = external_link( TranscriptURL, Transcript, TranscriptURLorigin, nil );&lt;br /&gt;
		end&lt;br /&gt;
		Transcript = sepc .. &#039; &#039; .. Transcript .. TranscriptFormat;&lt;br /&gt;
	elseif is_set(TranscriptURL) then&lt;br /&gt;
		Transcript = external_link( TranscriptURL, nil, TranscriptURLorigin, nil );&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	local Publisher;&lt;br /&gt;
	if is_set(PublicationDate) then&lt;br /&gt;
		PublicationDate = wrap_msg (&#039;published&#039;, PublicationDate);&lt;br /&gt;
	end&lt;br /&gt;
	if is_set(PublisherName) then&lt;br /&gt;
		if is_set(PublicationPlace) then&lt;br /&gt;
			Publisher = sepc .. &amp;quot; &amp;quot; .. PublicationPlace .. &amp;quot;: &amp;quot; .. PublisherName .. PublicationDate;&lt;br /&gt;
		else&lt;br /&gt;
			Publisher = sepc .. &amp;quot; &amp;quot; .. PublisherName .. PublicationDate;  &lt;br /&gt;
		end			&lt;br /&gt;
	elseif is_set(PublicationPlace) then &lt;br /&gt;
		Publisher= sepc .. &amp;quot; &amp;quot; .. PublicationPlace .. PublicationDate;&lt;br /&gt;
	else &lt;br /&gt;
		Publisher = PublicationDate;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Several of the above rely upon detecting this as nil, so do it last.&lt;br /&gt;
	if is_set(Periodical) then&lt;br /&gt;
		if is_set(Title) or is_set(TitleNote) then &lt;br /&gt;
			Periodical = sepc .. &amp;quot; &amp;quot; .. wrap_style (&#039;italic-title&#039;, Periodical) &lt;br /&gt;
		else &lt;br /&gt;
			Periodical = wrap_style (&#039;italic-title&#039;, Periodical)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	--[[&lt;br /&gt;
	Handle the oddity that is cite speech.  This code overrides whatever may be the value assigned to TitleNote (through |department=) and forces it to be &amp;quot; (Speech)&amp;quot; so that&lt;br /&gt;
	the annotation directly follows the |title= parameter value in the citation rather than the |event= parameter value (if provided).&lt;br /&gt;
	]]&lt;br /&gt;
	if &amp;quot;speech&amp;quot; == config.CitationClass then				-- cite speech only&lt;br /&gt;
		TitleNote = &amp;quot; (Speech)&amp;quot;;							-- annotate the citation&lt;br /&gt;
		if is_set (Periodical) then							-- if Periodical, perhaps because of an included |website= or |journal= parameter &lt;br /&gt;
			if is_set (Conference) then						-- and if |event= is set&lt;br /&gt;
				Conference = Conference .. sepc .. &amp;quot; &amp;quot;;		-- then add appropriate punctuation to the end of the Conference variable before rendering&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Piece all bits together at last.  Here, all should be non-nil.&lt;br /&gt;
	-- We build things this way because it is more efficient in LUA&lt;br /&gt;
	-- not to keep reassigning to the same string variable over and over.&lt;br /&gt;
&lt;br /&gt;
	local tcommon;&lt;br /&gt;
	local tcommon2;																-- used for book cite when |contributor= is set&lt;br /&gt;
	&lt;br /&gt;
	if in_array(config.CitationClass, {&amp;quot;journal&amp;quot;,&amp;quot;citation&amp;quot;}) and is_set(Periodical) then&lt;br /&gt;
		if is_set(Others) then Others = Others .. sepc .. &amp;quot; &amp;quot; end&lt;br /&gt;
		tcommon = safe_join( {Others, Title, TitleNote, Conference, Periodical, Format, TitleType, Series, Language, Edition, Publisher, Agency, Volume}, sepc );&lt;br /&gt;
	elseif in_array(config.CitationClass, {&amp;quot;book&amp;quot;,&amp;quot;citation&amp;quot;}) and not is_set(Periodical) then		-- special cases for book cites&lt;br /&gt;
		if is_set (Contributors) then											-- when we are citing foreword, preface, introduction, etc&lt;br /&gt;
			tcommon = safe_join( {Title, TitleNote}, sepc );					-- author and other stuff will come after this and before tcommon2&lt;br /&gt;
			tcommon2 = safe_join( {Conference, Periodical, Format, TitleType, Series, Language, Volume, Others, Edition, Publisher, Agency}, sepc );&lt;br /&gt;
		else&lt;br /&gt;
			tcommon = safe_join( {Title, TitleNote, Conference, Periodical, Format, TitleType, Series, Language, Volume, Others, Edition, Publisher, Agency}, sepc );&lt;br /&gt;
		end&lt;br /&gt;
&lt;br /&gt;
	elseif &#039;map&#039; == config.CitationClass then									-- special cases for cite map&lt;br /&gt;
		if is_set (Chapter) then												-- map in a book; TitleType is part of Chapter&lt;br /&gt;
			tcommon = safe_join( {Title, Format, Edition, Scale, Series, Language, Cartography, Others, Publisher, Volume}, sepc );&lt;br /&gt;
		elseif is_set (Periodical) then											-- map in a periodical&lt;br /&gt;
			tcommon = safe_join( {Title, TitleType, Format, Periodical, Scale, Series, Language, Cartography, Others, Publisher, Volume}, sepc );&lt;br /&gt;
		else																	-- a sheet or stand-alone map&lt;br /&gt;
			tcommon = safe_join( {Title, TitleType, Format, Edition, Scale, Series, Language, Cartography, Others, Publisher}, sepc );&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
	elseif &#039;episode&#039; == config.CitationClass then								-- special case for cite episode&lt;br /&gt;
		tcommon = safe_join( {Title, TitleNote, TitleType, Series, Transcript, Language, Edition, Publisher}, sepc );&lt;br /&gt;
&lt;br /&gt;
	else																		-- all other CS1 templates&lt;br /&gt;
		tcommon = safe_join( {Title, TitleNote, Conference, Periodical, Format, TitleType, Series, Language, &lt;br /&gt;
			Volume, Others, Edition, Publisher, Agency}, sepc );&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if #ID_list &amp;gt; 0 then&lt;br /&gt;
		ID_list = safe_join( { sepc .. &amp;quot; &amp;quot;,  table.concat( ID_list, sepc .. &amp;quot; &amp;quot; ), ID }, sepc );&lt;br /&gt;
	else&lt;br /&gt;
		ID_list = ID;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local idcommon = safe_join( { ID_list, URL, Archived, AccessDate, Via, SubscriptionRequired, Lay, Quote }, sepc );&lt;br /&gt;
	local text;&lt;br /&gt;
	local pgtext = Position .. Sheet .. Sheets .. Page .. Pages .. At;&lt;br /&gt;
&lt;br /&gt;
	if is_set(Date) then&lt;br /&gt;
		if is_set (Authors) or is_set (Editors) then							-- date follows authors or editors when authors not set&lt;br /&gt;
			Date = &amp;quot; (&amp;quot; .. Date ..&amp;quot;)&amp;quot; .. OrigYear .. sepc .. &amp;quot; &amp;quot;;				-- in paranetheses&lt;br /&gt;
		else																	-- neither of authors and editors set&lt;br /&gt;
			if (string.sub(tcommon,-1,-1) == sepc) then							-- if the last character of tcommon is sepc&lt;br /&gt;
				Date = &amp;quot; &amp;quot; .. Date .. OrigYear;									-- Date does not begin with sepc&lt;br /&gt;
			else&lt;br /&gt;
				Date = sepc .. &amp;quot; &amp;quot; .. Date .. OrigYear;							-- Date begins with sepc&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end	&lt;br /&gt;
	if is_set(Authors) then&lt;br /&gt;
		if (not is_set (Date)) then												-- when date is set it&#039;s in parentheses; no Authors termination&lt;br /&gt;
			Authors = terminate_name_list (Authors, sepc);						-- when no date, terminate with 0 or 1 sepc and a space&lt;br /&gt;
		end&lt;br /&gt;
		if is_set(Editors) then&lt;br /&gt;
			local in_text = &amp;quot; &amp;quot;;&lt;br /&gt;
			local post_text = &amp;quot;&amp;quot;;&lt;br /&gt;
			if is_set(Chapter) and 0 == #c then&lt;br /&gt;
				in_text = in_text .. cfg.messages[&#039;in&#039;] .. &amp;quot; &amp;quot;&lt;br /&gt;
				if (sepc ~= &#039;.&#039;) then&lt;br /&gt;
					in_text = in_text:lower()									-- lowercase for cs2&lt;br /&gt;
				 end&lt;br /&gt;
			else&lt;br /&gt;
				if EditorCount &amp;lt;= 1 then&lt;br /&gt;
					post_text = &amp;quot;, &amp;quot; .. cfg.messages[&#039;editor&#039;];&lt;br /&gt;
				else&lt;br /&gt;
					post_text = &amp;quot;, &amp;quot; .. cfg.messages[&#039;editors&#039;];&lt;br /&gt;
				end&lt;br /&gt;
			end &lt;br /&gt;
			Editors = terminate_name_list (in_text .. Editors .. post_text, sepc);	-- terminate with 0 or 1 sepc and a space&lt;br /&gt;
		end&lt;br /&gt;
		if is_set (Contributors) then											-- book cite and we&#039;re citing the intro, preface, etc&lt;br /&gt;
			local by_text = sepc .. &#039; &#039; .. cfg.messages[&#039;by&#039;] .. &#039; &#039;;&lt;br /&gt;
			if (sepc ~= &#039;.&#039;) then by_text = by_text:lower() end					-- lowercase for cs2&lt;br /&gt;
			Authors = by_text .. Authors;										-- author follows title so tweak it here&lt;br /&gt;
			if is_set (Editors) and is_set (Date) then							-- when Editors make sure that Authors gets terminated&lt;br /&gt;
				Authors = terminate_name_list (Authors, sepc);					-- terminate with 0 or 1 sepc and a space&lt;br /&gt;
			end&lt;br /&gt;
			if (not is_set (Date)) then											-- when date is set it&#039;s in parentheses; no Contributors termination&lt;br /&gt;
				Contributors = terminate_name_list (Contributors, sepc);		-- terminate with 0 or 1 sepc and a space&lt;br /&gt;
			end&lt;br /&gt;
			text = safe_join( {Contributors, Date, Chapter, tcommon, Authors, Place, Editors, tcommon2, pgtext, idcommon }, sepc );&lt;br /&gt;
		else&lt;br /&gt;
			text = safe_join( {Authors, Date, Chapter, Place, Editors, tcommon, pgtext, idcommon }, sepc );&lt;br /&gt;
		end&lt;br /&gt;
	elseif is_set(Editors) then&lt;br /&gt;
		if is_set(Date) then&lt;br /&gt;
			if EditorCount &amp;lt;= 1 then&lt;br /&gt;
				Editors = Editors .. &amp;quot;, &amp;quot; .. cfg.messages[&#039;editor&#039;];&lt;br /&gt;
			else&lt;br /&gt;
				Editors = Editors .. &amp;quot;, &amp;quot; .. cfg.messages[&#039;editors&#039;];&lt;br /&gt;
			end&lt;br /&gt;
		else&lt;br /&gt;
			if EditorCount &amp;lt;= 1 then&lt;br /&gt;
				Editors = Editors .. &amp;quot; (&amp;quot; .. cfg.messages[&#039;editor&#039;] .. &amp;quot;)&amp;quot; .. sepc .. &amp;quot; &amp;quot;&lt;br /&gt;
			else&lt;br /&gt;
				Editors = Editors .. &amp;quot; (&amp;quot; .. cfg.messages[&#039;editors&#039;] .. &amp;quot;)&amp;quot; .. sepc .. &amp;quot; &amp;quot;&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		text = safe_join( {Editors, Date, Chapter, Place, tcommon, pgtext, idcommon}, sepc );&lt;br /&gt;
	else&lt;br /&gt;
		if in_array(config.CitationClass, {&amp;quot;journal&amp;quot;,&amp;quot;citation&amp;quot;}) and is_set(Periodical) then&lt;br /&gt;
			text = safe_join( {Chapter, Place, tcommon, pgtext, Date, idcommon}, sepc );&lt;br /&gt;
		else&lt;br /&gt;
			text = safe_join( {Chapter, Place, tcommon, Date, pgtext, idcommon}, sepc );&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if is_set(PostScript) and PostScript ~= sepc then&lt;br /&gt;
		text = safe_join( {text, sepc}, sepc );  --Deals with italics, spaces, etc.&lt;br /&gt;
		text = text:sub(1,-sepc:len()-1);&lt;br /&gt;
	end	&lt;br /&gt;
	&lt;br /&gt;
	text = safe_join( {text, PostScript}, sepc );&lt;br /&gt;
&lt;br /&gt;
	-- Now enclose the whole thing in a &amp;lt;cite/&amp;gt; element&lt;br /&gt;
	local options = {};&lt;br /&gt;
	&lt;br /&gt;
	if is_set(config.CitationClass) and config.CitationClass ~= &amp;quot;citation&amp;quot; then&lt;br /&gt;
		options.class = config.CitationClass;&lt;br /&gt;
		options.class = &amp;quot;citation &amp;quot; .. config.CitationClass;					-- class=citation required for blue highlight when used with |ref=&lt;br /&gt;
	else&lt;br /&gt;
		options.class = &amp;quot;citation&amp;quot;;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if is_set(Ref) and Ref:lower() ~= &amp;quot;none&amp;quot; then								-- set reference anchor if appropriate&lt;br /&gt;
		local id = Ref&lt;br /&gt;
		if (&#039;harv&#039; == Ref ) then&lt;br /&gt;
			local namelist = {};												-- holds selected contributor, author, editor name list&lt;br /&gt;
			local year = first_set ({Year, anchor_year}, 2);					-- Year first for legacy citations and for YMD dates that require disambiguation&lt;br /&gt;
&lt;br /&gt;
			if #c &amp;gt; 0 then														-- if there is a contributor list&lt;br /&gt;
				namelist = c;													-- select it&lt;br /&gt;
			elseif #a &amp;gt; 0 then													-- or an author list&lt;br /&gt;
				namelist = a;&lt;br /&gt;
			elseif #e &amp;gt; 0 then													-- or an editor list&lt;br /&gt;
				namelist = e;&lt;br /&gt;
			end&lt;br /&gt;
			if #namelist &amp;gt; 0 then												-- if there are names in namelist&lt;br /&gt;
				id = anchor_id (namelist, year);								-- go make the CITEREF anchor&lt;br /&gt;
			else&lt;br /&gt;
				id = &#039;&#039;;														-- unset&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		options.id = id;&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if string.len(text:gsub(&amp;quot;&amp;lt;span[^&amp;gt;/]*&amp;gt;(.-)&amp;lt;/span&amp;gt;&amp;quot;, &amp;quot;%1&amp;quot;):gsub(&amp;quot;%b&amp;lt;&amp;gt;&amp;quot;,&amp;quot;&amp;quot;)) &amp;lt;= 2 then	-- remove &amp;lt;span&amp;gt; tags and other html-like markup; then get length of what remains&lt;br /&gt;
		z.error_categories = {};&lt;br /&gt;
		text = set_error(&#039;empty_citation&#039;);&lt;br /&gt;
		z.message_tail = {};&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local render = {};															-- here we collect the final bits for concatenation into the rendered citation&lt;br /&gt;
&lt;br /&gt;
	if is_set(options.id) then													-- here we wrap the rendered citation in &amp;lt;cite ...&amp;gt;...&amp;lt;/cite&amp;gt; tags&lt;br /&gt;
		table.insert (render, substitute (cfg.presentation[&#039;cite-id&#039;], {mw.uri.anchorEncode(options.id), mw.text.nowiki(options.class), text}));	-- when |ref= is set&lt;br /&gt;
	else&lt;br /&gt;
		table.insert (render, substitute (cfg.presentation[&#039;cite&#039;], {mw.text.nowiki(options.class), text}));	-- all other cases&lt;br /&gt;
	end		&lt;br /&gt;
&lt;br /&gt;
	table.insert (render, substitute (cfg.presentation[&#039;ocins&#039;], {OCinSoutput}));		-- append metadata to the citation&lt;br /&gt;
&lt;br /&gt;
	if #z.message_tail ~= 0 then&lt;br /&gt;
		table.insert (render, &#039; &#039;);&lt;br /&gt;
		for i,v in ipairs( z.message_tail ) do&lt;br /&gt;
			if is_set(v[1]) then&lt;br /&gt;
				if i == #z.message_tail then&lt;br /&gt;
					table.insert (render, error_comment( v[1], v[2] ));&lt;br /&gt;
				else&lt;br /&gt;
					table.insert (render, error_comment( v[1] .. &amp;quot;; &amp;quot;, v[2] ));&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	if #z.maintenance_cats ~= 0 then&lt;br /&gt;
		table.insert (render, &#039;&amp;lt;span class=&amp;quot;citation-comment&amp;quot; style=&amp;quot;display:none; color:#33aa33; margin-left:0.3em&amp;quot;&amp;gt;&#039;);&lt;br /&gt;
		for _, v in ipairs( z.maintenance_cats ) do								-- append maintenance categories&lt;br /&gt;
			table.insert (render, v);&lt;br /&gt;
			table.insert (render, &#039; (&#039;);&lt;br /&gt;
			table.insert (render, make_wikilink (&#039;:Category:&#039; .. v, &#039;link&#039;));&lt;br /&gt;
			table.insert (render, &#039;) &#039;);&lt;br /&gt;
		end&lt;br /&gt;
		table.insert (render, &#039;&amp;lt;/span&amp;gt;&#039;);&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	no_tracking_cats = no_tracking_cats:lower();&lt;br /&gt;
	if in_array(no_tracking_cats, {&amp;quot;&amp;quot;, &amp;quot;no&amp;quot;, &amp;quot;false&amp;quot;, &amp;quot;n&amp;quot;}) then&lt;br /&gt;
		for _, v in ipairs( z.error_categories ) do&lt;br /&gt;
			table.insert (render, make_wikilink (&#039;Category:&#039; .. v));&lt;br /&gt;
		end&lt;br /&gt;
		for _, v in ipairs( z.maintenance_cats ) do								-- append maintenance categories&lt;br /&gt;
			table.insert (render, make_wikilink (&#039;Category:&#039; .. v));&lt;br /&gt;
		end&lt;br /&gt;
		for _, v in ipairs( z.properties_cats ) do								-- append properties categories&lt;br /&gt;
			table.insert (render, make_wikilink (&#039;Category:&#039; .. v));&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return table.concat (render);	&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
--[[--------------------------&amp;lt; C S 1 . C I T A T I O N &amp;gt;------------------------------------------------------&lt;br /&gt;
&lt;br /&gt;
This is used by templates such as {{cite book}} to create the actual citation text.&lt;br /&gt;
&lt;br /&gt;
]]&lt;br /&gt;
&lt;br /&gt;
function cs1.citation(frame)&lt;br /&gt;
	Frame = frame;																-- save a copy incase we need to display an error message in preview mode&lt;br /&gt;
	local pframe = frame:getParent()&lt;br /&gt;
	local validation, utilities, identifiers, metadata;&lt;br /&gt;
	&lt;br /&gt;
	if nil ~= string.find (frame:getTitle(), &#039;sandbox&#039;, 1, true) then			-- did the {{#invoke:}} use sandbox version?&lt;br /&gt;
		cfg = mw.loadData (&#039;Module:Citation/CS1/Configuration/sandbox&#039;);		-- load sandbox versions of support modules&lt;br /&gt;
		whitelist = mw.loadData (&#039;Module:Citation/CS1/Whitelist/sandbox&#039;);&lt;br /&gt;
		utilities = require (&#039;Module:Citation/CS1/Utilities/sandbox&#039;);&lt;br /&gt;
		validation = require (&#039;Module:Citation/CS1/Date_validation/sandbox&#039;);&lt;br /&gt;
		identifiers = require (&#039;Module:Citation/CS1/Identifiers/sandbox&#039;);&lt;br /&gt;
		metadata = require (&#039;Module:Citation/CS1/COinS/sandbox&#039;);&lt;br /&gt;
		&lt;br /&gt;
	else																		-- otherwise&lt;br /&gt;
		cfg = mw.loadData (&#039;Module:Citation/CS1/Configuration&#039;);				-- load live versions of support modules&lt;br /&gt;
		whitelist = mw.loadData (&#039;Module:Citation/CS1/Whitelist&#039;);&lt;br /&gt;
		utilities = require (&#039;Module:Citation/CS1/Utilities&#039;);&lt;br /&gt;
		validation = require (&#039;Module:Citation/CS1/Date_validation&#039;);&lt;br /&gt;
		identifiers = require (&#039;Module:Citation/CS1/Identifiers&#039;);&lt;br /&gt;
		metadata = require (&#039;Module:Citation/CS1/COinS&#039;);&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	utilities.set_selected_modules (cfg);										-- so that functions in Utilities can see the cfg tables&lt;br /&gt;
	identifiers.set_selected_modules (cfg, utilities);							-- so that functions in Identifiers can see the selected cfg tables and selected Utilities module&lt;br /&gt;
	validation.set_selected_modules (cfg, utilities);							-- so that functions in Date validataion can see selected cfg tables and the selected Utilities module&lt;br /&gt;
	metadata.set_selected_modules (cfg, utilities);								-- so that functions in COinS can see the selected cfg tables and selected Utilities module&lt;br /&gt;
&lt;br /&gt;
	dates = validation.dates;													-- imported functions from Module:Citation/CS1/Date validation&lt;br /&gt;
	year_date_check = validation.year_date_check;&lt;br /&gt;
	reformat_dates = validation.reformat_dates;&lt;br /&gt;
	date_hyphen_to_dash = validation.date_hyphen_to_dash;&lt;br /&gt;
	date_name_xlate = validation.date_name_xlate;&lt;br /&gt;
&lt;br /&gt;
	is_set = utilities.is_set;													-- imported functions from Module:Citation/CS1/Utilities&lt;br /&gt;
	in_array = utilities.in_array;&lt;br /&gt;
	substitute = utilities.substitute;&lt;br /&gt;
	error_comment = utilities.error_comment;&lt;br /&gt;
	set_error = utilities.set_error;&lt;br /&gt;
	select_one = utilities.select_one;&lt;br /&gt;
	add_maint_cat = utilities.add_maint_cat;&lt;br /&gt;
	wrap_style = utilities.wrap_style;&lt;br /&gt;
	safe_for_italics = utilities.safe_for_italics;&lt;br /&gt;
	is_wikilink = utilities.is_wikilink;&lt;br /&gt;
	make_wikilink = utilities.make_wikilink;&lt;br /&gt;
&lt;br /&gt;
	z = utilities.z;															-- table of error and category tables in Module:Citation/CS1/Utilities&lt;br /&gt;
&lt;br /&gt;
	extract_ids = identifiers.extract_ids;										-- imported functions from Module:Citation/CS1/Identifiers&lt;br /&gt;
	build_id_list = identifiers.build_id_list;&lt;br /&gt;
	is_embargoed = identifiers.is_embargoed;&lt;br /&gt;
	extract_id_access_levels = identifiers.extract_id_access_levels;&lt;br /&gt;
	&lt;br /&gt;
	make_coins_title = metadata.make_coins_title;								-- imported functions from Module:Citation/CS1/COinS&lt;br /&gt;
	get_coins_pages = metadata.get_coins_pages;&lt;br /&gt;
	COinS = metadata.COinS;&lt;br /&gt;
&lt;br /&gt;
	local args = {};															-- table where we store all of the template&#039;s arguments&lt;br /&gt;
	local suggestions = {};														-- table where we store suggestions if we need to loadData them&lt;br /&gt;
	local error_text, error_state;&lt;br /&gt;
&lt;br /&gt;
	local config = {};															-- table to store parameters from the module {{#invoke:}}&lt;br /&gt;
	for k, v in pairs( frame.args ) do&lt;br /&gt;
		config[k] = v;&lt;br /&gt;
--		args[k] = v;															-- debug tool that allows us to render a citation from module {{#invoke:}}&lt;br /&gt;
	end	&lt;br /&gt;
&lt;br /&gt;
	local capture;																-- the single supported capture when matching unknown parameters using patterns&lt;br /&gt;
	for k, v in pairs( pframe.args ) do&lt;br /&gt;
		if v ~= &#039;&#039; then&lt;br /&gt;
			if not validate( k, config.CitationClass ) then			&lt;br /&gt;
				error_text = &amp;quot;&amp;quot;;&lt;br /&gt;
				if type( k ) ~= &#039;string&#039; then&lt;br /&gt;
					-- Exclude empty numbered parameters&lt;br /&gt;
					if v:match(&amp;quot;%S+&amp;quot;) ~= nil then&lt;br /&gt;
						error_text, error_state = set_error( &#039;text_ignored&#039;, {v}, true );&lt;br /&gt;
					end&lt;br /&gt;
				elseif validate( k:lower(), config.CitationClass ) then &lt;br /&gt;
					error_text, error_state = set_error( &#039;parameter_ignored_suggest&#039;, {k, k:lower()}, true );&lt;br /&gt;
				else&lt;br /&gt;
					if nil == suggestions.suggestions then						-- if this table is nil then we need to load it&lt;br /&gt;
						if nil ~= string.find (frame:getTitle(), &#039;sandbox&#039;, 1, true) then			-- did the {{#invoke:}} use sandbox version?&lt;br /&gt;
							suggestions = mw.loadData( &#039;Module:Citation/CS1/Suggestions/sandbox&#039; );	-- use the sandbox version&lt;br /&gt;
						else&lt;br /&gt;
							suggestions = mw.loadData( &#039;Module:Citation/CS1/Suggestions&#039; );			-- use the live version&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
					for pattern, param in pairs (suggestions.patterns) do		-- loop through the patterns to see if we can suggest a proper parameter&lt;br /&gt;
						capture = k:match (pattern);							-- the whole match if no caputre in pattern else the capture if a match&lt;br /&gt;
						if capture then											-- if the pattern matches &lt;br /&gt;
							param = substitute( param, capture );				-- add the capture to the suggested parameter (typically the enumerator)&lt;br /&gt;
							error_text, error_state = set_error( &#039;parameter_ignored_suggest&#039;, {k, param}, true );	-- set the error message&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
					if not is_set (error_text) then								-- couldn&#039;t match with a pattern, is there an expicit suggestion?&lt;br /&gt;
						if suggestions.suggestions[ k:lower() ] ~= nil then&lt;br /&gt;
							error_text, error_state = set_error( &#039;parameter_ignored_suggest&#039;, {k, suggestions.suggestions[ k:lower() ]}, true );&lt;br /&gt;
						else&lt;br /&gt;
							error_text, error_state = set_error( &#039;parameter_ignored&#039;, {k}, true );&lt;br /&gt;
							v = &#039;&#039;;												-- unset value assigned to unrecognized parameters (this for the limited parameter lists)&lt;br /&gt;
						end&lt;br /&gt;
					end&lt;br /&gt;
				end				  &lt;br /&gt;
				if error_text ~= &#039;&#039; then&lt;br /&gt;
					table.insert( z.message_tail, {error_text, error_state} );&lt;br /&gt;
				end				&lt;br /&gt;
			end&lt;br /&gt;
			missing_pipe_check (v);												-- do we think that there is a parameter that is missing a pipe?&lt;br /&gt;
			&lt;br /&gt;
			args[k] = v;&lt;br /&gt;
		elseif args[k] ~= nil or (k == &#039;postscript&#039;) then&lt;br /&gt;
			args[k] = v;&lt;br /&gt;
		end		&lt;br /&gt;
	end	&lt;br /&gt;
&lt;br /&gt;
	for k, v in pairs( args ) do&lt;br /&gt;
		if &#039;string&#039; == type (k) then											-- don&#039;t evaluate positional parameters&lt;br /&gt;
			has_invisible_chars (k, v);&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return citation0( config, args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return cs1;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Check_for_unknown_parameters&amp;diff=1181</id>
		<title>Module:Check for unknown parameters</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Check_for_unknown_parameters&amp;diff=1181"/>
		<updated>2018-04-07T11:49:50Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module may be used to compare the arguments passed to the parent&lt;br /&gt;
-- with a list of arguments, returning a specified result if an argument is&lt;br /&gt;
-- not on the list&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function trim(s)&lt;br /&gt;
	return s:match(&#039;^%s*(.-)%s*$&#039;)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function isnotempty(s)&lt;br /&gt;
	return s and trim(s) ~= &#039;&#039;&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.check (frame)&lt;br /&gt;
	local args = frame.args&lt;br /&gt;
	local pargs = frame:getParent().args&lt;br /&gt;
	local ignoreblank = isnotempty(frame.args[&#039;ignoreblank&#039;])&lt;br /&gt;
	local showblankpos = isnotempty(frame.args[&#039;showblankpositional&#039;])&lt;br /&gt;
	local knownargs = {}&lt;br /&gt;
	local unknown = frame.args[&#039;unknown&#039;] or &#039;Found _VALUE_, &#039;&lt;br /&gt;
	local preview = frame.args[&#039;preview&#039;]&lt;br /&gt;
&lt;br /&gt;
	local values = {}&lt;br /&gt;
	local res = {}&lt;br /&gt;
	local regexps = {}&lt;br /&gt;
&lt;br /&gt;
	-- create the list of known args, regular expressions, and the return string&lt;br /&gt;
	for k, v in pairs(args) do&lt;br /&gt;
		if type(k) == &#039;number&#039; then&lt;br /&gt;
			v = trim(v)&lt;br /&gt;
			knownargs[v] = 1&lt;br /&gt;
		elseif k:find(&#039;^regexp[1-9][0-9]*$&#039;) then&lt;br /&gt;
			table.insert(regexps, &#039;^&#039; .. v .. &#039;$&#039;)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	if isnotempty(preview) then &lt;br /&gt;
		preview = &#039;&amp;lt;div class=&amp;quot;hatnote&amp;quot; style=&amp;quot;color:red&amp;quot;&amp;gt;&amp;lt;strong&amp;gt;Warning:&amp;lt;/strong&amp;gt; &#039; .. preview .. &#039; (this message is shown only in preview).&amp;lt;/div&amp;gt;&#039;&lt;br /&gt;
	elseif preview == nil then&lt;br /&gt;
		preview = unknown&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- loop over the parent args, and make sure they are on the list&lt;br /&gt;
	for k, v in pairs(pargs) do&lt;br /&gt;
		if type(k) == &#039;string&#039; and knownargs[k] == nil then&lt;br /&gt;
			local knownflag = false&lt;br /&gt;
			for i, regexp in ipairs(regexps) do&lt;br /&gt;
				if mw.ustring.match(k, regexp) then&lt;br /&gt;
					knownflag = true&lt;br /&gt;
					break&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			if not knownflag and ( not ignoreblank or isnotempty(v) )  then&lt;br /&gt;
				k = mw.ustring.gsub(k, &#039;[^%w\-_ ]&#039;, &#039;?&#039;)&lt;br /&gt;
				table.insert(values, k)&lt;br /&gt;
			end&lt;br /&gt;
		elseif type(k) == &#039;number&#039; and &lt;br /&gt;
			knownargs[tostring(k)] == nil and&lt;br /&gt;
			( showblankpos or isnotempty(v) )&lt;br /&gt;
		then&lt;br /&gt;
			local vlen = mw.ustring.len(v)&lt;br /&gt;
			v = mw.ustring.sub(v, 1, (vlen &amp;lt; 25) and vlen or 25) &lt;br /&gt;
			v = mw.ustring.gsub(v, &#039;[^%w\-_ ]&#039;, &#039;?&#039;)&lt;br /&gt;
			table.insert(values, k .. &#039; = &#039; .. v .. ((vlen &amp;gt;= 25) and &#039; ...&#039; or &#039;&#039;))&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- add resuls to the output tables&lt;br /&gt;
	if #values &amp;gt; 0 then&lt;br /&gt;
		if frame:preprocess( &amp;quot;{{REVISIONID}}&amp;quot; ) == &amp;quot;&amp;quot; then&lt;br /&gt;
			unknown = preview&lt;br /&gt;
		end&lt;br /&gt;
		for k, v in pairs(values) do&lt;br /&gt;
			if v == &#039;&#039; then&lt;br /&gt;
			-- Fix odd bug for | = which gets stripped to the empty string and&lt;br /&gt;
			-- breaks category links&lt;br /&gt;
			v = &#039; &#039;&lt;br /&gt;
			end&lt;br /&gt;
			local r =  unknown:gsub(&#039;_VALUE_&#039;, v)&lt;br /&gt;
			table.insert(res, r)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	return table.concat(res)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Module:Anchor&amp;diff=1179</id>
		<title>Module:Anchor</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Module:Anchor&amp;diff=1179"/>
		<updated>2018-04-07T11:49:49Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;-- This module implements {{anchor}}.&lt;br /&gt;
&lt;br /&gt;
local getArgs = require(&#039;Module:Arguments&#039;).getArgs&lt;br /&gt;
local tableTools = require(&#039;Module:TableTools&#039;)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	-- Get the positional arguments from #invoke, remove any nil values,&lt;br /&gt;
	-- and pass them to p._main.&lt;br /&gt;
	local args = getArgs(frame)&lt;br /&gt;
	local argArray = tableTools.compressSparseArray(args)&lt;br /&gt;
	return p._main(unpack(argArray))&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p._main(...)&lt;br /&gt;
	-- Generate the list of anchors.&lt;br /&gt;
	local anchors = {...}&lt;br /&gt;
	local ret = {}&lt;br /&gt;
	for _, anchor in ipairs(anchors) do&lt;br /&gt;
		ret[#ret + 1] = &#039;&amp;lt;span id=&amp;quot;&#039; .. anchor .. &#039;&amp;quot;&amp;gt;&amp;lt;/span&amp;gt;&#039;&lt;br /&gt;
	end&lt;br /&gt;
	return table.concat(ret)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Yes&amp;diff=1177</id>
		<title>Template:Yes</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Yes&amp;diff=1177"/>
		<updated>2018-04-07T11:49:49Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;noinclude&amp;gt;{{Tfm/dated|page=Yes|otherpage=Available|link=Wikipedia:Templates for discussion/Log/2018 April 5#Template:Yes|bigbox={{#invoke:Noinclude|noinclude|text=yes}}}}&amp;lt;/noinclude&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
|&amp;lt;/noinclude&amp;gt;style=&amp;quot;background:#9F9;vertical-align:middle;text-align:{{{align|center}}};{{{style|}}}&amp;quot; class=&amp;quot;table-yes&amp;quot;|{{{1|Yes}}}&amp;lt;noinclude&amp;gt;&lt;br /&gt;
|}&lt;br /&gt;
{{documentation}}&lt;br /&gt;
&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Unbulleted_list&amp;diff=1175</id>
		<title>Template:Unbulleted list</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Unbulleted_list&amp;diff=1175"/>
		<updated>2018-04-07T11:49:49Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{&amp;lt;includeonly&amp;gt;safesubst:&amp;lt;/includeonly&amp;gt;#invoke:list|unbulleted}}&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>Max</name></author>
	</entry>
	<entry>
		<id>https://oddworldlibrary.net/oddenc/index.php?title=Template:Tnull&amp;diff=1173</id>
		<title>Template:Tnull</title>
		<link rel="alternate" type="text/html" href="https://oddworldlibrary.net/oddenc/index.php?title=Template:Tnull&amp;diff=1173"/>
		<updated>2018-04-07T11:49:48Z</updated>

		<summary type="html">&lt;p&gt;Max: 1 revision imported&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;code&amp;gt;&amp;amp;#123;&amp;amp;#123;{{#if:{{{1|}}}|{{{1}}}| tnull&amp;amp;#124;...}}{{#if:{{{2|}}}|&amp;amp;#124;{{{2}}}|}}{{#if:{{{3|}}}|&amp;amp;#124;{{{3}}}|}}{{#if:{{{4|}}}|&amp;amp;#124;{{{4}}}|}}{{#if:{{{5|}}}|&amp;amp;#124;{{{5}}}|}}{{#if:{{{6|}}}|&amp;amp;#124;{{{6}}}|}}{{#if:{{{7|}}}|&amp;amp;#124;{{{7}}}|}}{{#if:{{{8|}}}|&amp;amp;#124;{{{8}}}|}}{{#if:{{{9|}}}|&amp;amp;#124;{{{9}}}|}}{{#if:{{{10|}}}|&amp;amp;#124;{{{10}}}|}}{{#if:{{{11|}}}|&amp;amp;#124;{{{11}}}|}}&amp;amp;#125;&amp;amp;#125;&amp;lt;/code&amp;gt;&amp;lt;noinclude&amp;gt;&lt;br /&gt;
{{documentation}}&amp;lt;/noinclude&amp;gt;&lt;/div&gt;</summary>
		<author><name>Max</name></author>
	</entry>
</feed>