<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
		<id>https://wiki.agency/index.php?action=history&amp;feed=atom&amp;title=Module%3ARoad_data%2Fparser</id>
		<title>Module:Road data/parser - Revision history</title>
		<link rel="self" type="application/atom+xml" href="https://wiki.agency/index.php?action=history&amp;feed=atom&amp;title=Module%3ARoad_data%2Fparser"/>
		<link rel="alternate" type="text/html" href="https://wiki.agency/index.php?title=Module:Road_data/parser&amp;action=history"/>
		<updated>2026-05-01T18:42:52Z</updated>
		<subtitle>Revision history for this page on the wiki</subtitle>
		<generator>MediaWiki 1.30.1</generator>

	<entry>
		<id>https://wiki.agency/index.php?title=Module:Road_data/parser&amp;diff=3163&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="https://wiki.agency/index.php?title=Module:Road_data/parser&amp;diff=3163&amp;oldid=prev"/>
				<updated>2018-11-02T14:48:56Z</updated>
		
		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Revision as of 14:48, 2 November 2018&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>https://wiki.agency/index.php?title=Module:Road_data/parser&amp;diff=3162&amp;oldid=prev</id>
		<title>Imzadi1979: Reverted to revision 719942056 by Happy5214 (talk): Rolling back update in attempt to fix a large number of breakages. (TW)</title>
		<link rel="alternate" type="text/html" href="https://wiki.agency/index.php?title=Module:Road_data/parser&amp;diff=3162&amp;oldid=prev"/>
				<updated>2016-05-19T10:18:31Z</updated>
		
		<summary type="html">&lt;p&gt;Reverted to revision 719942056 by &lt;a href=&quot;/Special:Contributions/Happy5214&quot; title=&quot;Special:Contributions/Happy5214&quot;&gt;Happy5214&lt;/a&gt; (&lt;a href=&quot;/index.php?title=User_talk:Happy5214&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;User talk:Happy5214 (page does not exist)&quot;&gt;talk&lt;/a&gt;): Rolling back update in attempt to fix a large number of breakages. (&lt;a href=&quot;/index.php?title=WP:TW&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;WP:TW (page does not exist)&quot;&gt;TW&lt;/a&gt;)&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;-- Export package&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-- Local library aliases&lt;br /&gt;
local format = string.format&lt;br /&gt;
local gsub = mw.ustring.gsub&lt;br /&gt;
local trim = mw.text.trim&lt;br /&gt;
local upper = mw.ustring.upper&lt;br /&gt;
&lt;br /&gt;
-- Regex substitution patterns&lt;br /&gt;
local prepattern = &amp;quot;%[(%w+)%|(.*)%|(.*)%|(.*)%]&amp;quot; -- [arg|equal to (blank for existence)|if true|if false]&lt;br /&gt;
local pattern = &amp;quot;%%(%w+)%%&amp;quot; -- %arg%&lt;br /&gt;
&lt;br /&gt;
local function parser(formatStr, args, form)&lt;br /&gt;
	local function ifexists(name)&lt;br /&gt;
		-- Check whether a page or file named name exists&lt;br /&gt;
		if name == &amp;#039;&amp;#039; then return false end -- Page doesn&amp;#039;t exist if name is blank&lt;br /&gt;
		local title -- mw.title object&lt;br /&gt;
		if form == &amp;#039;shield&amp;#039; then&lt;br /&gt;
			title = mw.title.new(name, &amp;#039;Media&amp;#039;) -- Shields are in the Media namespace&lt;br /&gt;
		else&lt;br /&gt;
			title = mw.title.new(name, 0) -- Links are in the mainspace&lt;br /&gt;
		end&lt;br /&gt;
		return title.exists -- A boolean for whether the page exists&lt;br /&gt;
	end&lt;br /&gt;
	local function testArgs(test, equals, ifexists, ifnot)&lt;br /&gt;
		-- Implement the if test&lt;br /&gt;
		if equals ~= &amp;#039;&amp;#039; then -- Argument equals something&lt;br /&gt;
			if args[test] == equals then return ifexists else return ifnot end&lt;br /&gt;
		else -- Existence of argument&lt;br /&gt;
			if args[test] and args[test] ~= &amp;#039;&amp;#039; then return ifexists else return ifnot end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local formatTable = {} -- Table with definitions&lt;br /&gt;
	-- Recursively dig into tables that could be parser hooks or argument tables.&lt;br /&gt;
	local function formatStrInTable(formatStr)&lt;br /&gt;
		if type(formatStr) ~= &amp;quot;table&amp;quot; then return formatStr end -- formatStr is a scalar&lt;br /&gt;
		formatTable = formatStr&lt;br /&gt;
		local hook = formatStr.hook -- Possible hook&lt;br /&gt;
		local both = formatStr[2] -- Second shield&lt;br /&gt;
		if both then&lt;br /&gt;
			local first = formatStrInTable(formatStr[1])&lt;br /&gt;
			local second = formatStrInTable(both)&lt;br /&gt;
			return {first, second} -- First and second shield&lt;br /&gt;
		elseif hook then&lt;br /&gt;
			local hooksModule = require &amp;quot;Module:Road data/parser/hooks&amp;quot;&lt;br /&gt;
			local hookFunction = hooksModule[hook] or error(&amp;quot;Hook &amp;#039;&amp;quot; .. hook .. &amp;quot;&amp;#039; does not exist&amp;quot;, 0)&lt;br /&gt;
			return formatStrInTable(hookFunction(formatStr, args)) -- Call hook&lt;br /&gt;
		else -- Switch on an argument&lt;br /&gt;
			local arg = args[formatStr.arg or &amp;quot;route&amp;quot;]&lt;br /&gt;
			return formatStrInTable(formatStr[arg] or formatStr.default)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	local function parse(formatStr)&lt;br /&gt;
		local preprocessed = gsub(formatStr, prepattern, testArgs) -- If statements&lt;br /&gt;
		local parsedStr = gsub(preprocessed, pattern, args) -- Variable interpolation&lt;br /&gt;
		local final = trim(parsedStr) -- Trim extra spaces&lt;br /&gt;
		if formatTable.ifexists then -- Existence test&lt;br /&gt;
			local exists = ifexists(final)&lt;br /&gt;
			if exists then&lt;br /&gt;
				return final&lt;br /&gt;
			else&lt;br /&gt;
				return parser(formatTable.otherwise, args, form)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		return final&lt;br /&gt;
	end&lt;br /&gt;
	formatStr = formatStrInTable(formatStr) -- Get formatStr&lt;br /&gt;
	if not formatStr or formatStr == &amp;#039;&amp;#039; then return &amp;#039;&amp;#039; end -- Return empty string for empty formatStr&lt;br /&gt;
	if type(formatStr) == &amp;#039;table&amp;#039; then -- Dual shields&lt;br /&gt;
		local first = parse(formatStr[1])&lt;br /&gt;
		local second = parse(formatStr[2])&lt;br /&gt;
		return first, second&lt;br /&gt;
	else&lt;br /&gt;
		return parse(formatStr)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function formatString(args, form)&lt;br /&gt;
	-- Get format string/table from module based on jurisdiction and type&lt;br /&gt;
	local function getTypeData(module, type)&lt;br /&gt;
		-- Get data from module for particular type&lt;br /&gt;
		local success, moduleData = pcall(mw.loadData, module)&lt;br /&gt;
		if not success then return &amp;#039;&amp;#039; end -- Empty string if module cannot be loaded&lt;br /&gt;
		local typeTable = moduleData[type] or moduleData[&amp;#039;&amp;#039;] -- Type table or empty string default table&lt;br /&gt;
		local defaultTable = moduleData[&amp;#039;&amp;#039;] or {} -- Default table&lt;br /&gt;
		if typeTable then&lt;br /&gt;
			local alias = typeTable.alias&lt;br /&gt;
			if alias then -- Type is an alias to another module&lt;br /&gt;
				local aliasedModule = &amp;quot;Module:Road data/strings/&amp;quot; .. alias.module&lt;br /&gt;
				local aliasedType = alias.type&lt;br /&gt;
				return getTypeData(aliasedModule, aliasedType)&lt;br /&gt;
			end&lt;br /&gt;
			return typeTable[form] or defaultTable[form] or &amp;#039;&amp;#039;&lt;br /&gt;
		else&lt;br /&gt;
			return &amp;#039;&amp;#039;&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	local stateCountries = {USA = true, CAN = true} -- These countries have state/province modules&lt;br /&gt;
	local state = upper(args.state or &amp;#039;&amp;#039;)&lt;br /&gt;
	local country&lt;br /&gt;
	if args.country then&lt;br /&gt;
		country = upper(args.country)&lt;br /&gt;
	else -- Find country via a mask&lt;br /&gt;
		local countryModule = mw.loadData(&amp;quot;Module:Road data/countrymask&amp;quot;)&lt;br /&gt;
		country = countryModule[state] or &amp;#039;UNK&amp;#039;&lt;br /&gt;
	end&lt;br /&gt;
	local typeArg = args.type&lt;br /&gt;
	local module&lt;br /&gt;
	if stateCountries[country] and state ~= &amp;#039;&amp;#039; then&lt;br /&gt;
		module = format(&amp;quot;Module:Road data/strings/%s/%s&amp;quot;, country, state)&lt;br /&gt;
	else&lt;br /&gt;
		module = format(&amp;quot;Module:Road data/strings/%s&amp;quot;, country)&lt;br /&gt;
	end&lt;br /&gt;
	return getTypeData(module, typeArg)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.parser(passedArgs, form)&lt;br /&gt;
	local args = {state = passedArgs.state, type = passedArgs.type, route = passedArgs.route, &lt;br /&gt;
	              denom = passedArgs.denom, county = passedArgs.county, dab = passedArgs.dab,&lt;br /&gt;
	              country = passedArgs.country, township = passedArgs.township}&lt;br /&gt;
	local formatStr = formatString(args, form)&lt;br /&gt;
	if not formatStr or formatStr == &amp;#039;&amp;#039; then return nil end&lt;br /&gt;
	return parser(formatStr, args, form)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Imzadi1979</name></author>	</entry>

	</feed>