<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://mywikibiz.com/index.php?action=history&amp;feed=atom&amp;title=Module%3ASports_results</id>
	<title>Module:Sports results - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://mywikibiz.com/index.php?action=history&amp;feed=atom&amp;title=Module%3ASports_results"/>
	<link rel="alternate" type="text/html" href="https://mywikibiz.com/index.php?title=Module:Sports_results&amp;action=history"/>
	<updated>2026-06-15T12:52:35Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.35.3</generator>
	<entry>
		<id>https://mywikibiz.com/index.php?title=Module:Sports_results&amp;diff=479560&amp;oldid=prev</id>
		<title>Zoran: Pywikibot 6.4.0</title>
		<link rel="alternate" type="text/html" href="https://mywikibiz.com/index.php?title=Module:Sports_results&amp;diff=479560&amp;oldid=prev"/>
		<updated>2021-07-16T06:41:11Z</updated>

		<summary type="html">&lt;p&gt;Pywikibot 6.4.0&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;-- Module to build results cross-tables for standings in Sports&lt;br /&gt;
-- See documentation for details&lt;br /&gt;
&lt;br /&gt;
require('Module:No globals')&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
-- Main function&lt;br /&gt;
function p.main(frame)&lt;br /&gt;
	-- Get the args, stripping out blank values&lt;br /&gt;
	local getArgs = require('Module:Arguments').getArgs&lt;br /&gt;
	local Args = getArgs(frame, {parentFirst = true})&lt;br /&gt;
&lt;br /&gt;
	-- Exit early if we are using section transclusion for a different section&lt;br /&gt;
	if (Args['transcludesection'] and Args['section'])&lt;br /&gt;
		and Args['transcludesection'] ~= Args['section'] then&lt;br /&gt;
		return ''&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Declare locals&lt;br /&gt;
	local t = {}&lt;br /&gt;
	local t_footer = {}&lt;br /&gt;
	local t_return = {}&lt;br /&gt;
	local team_list = {}&lt;br /&gt;
	local notes_exist = false&lt;br /&gt;
	local ii, ii_fw, bg_col, team_name, team_code_ii, ii_start, ii_end&lt;br /&gt;
	-- Optional custom team header&lt;br /&gt;
	local team_header = Args['team_header'] or 'Home \\ Away'&lt;br /&gt;
	-- Number of legs&lt;br /&gt;
	local legs = tonumber(Args['legs']) or 1&lt;br /&gt;
	local multirowlegs = (Args['multirowlegs'] or 'no') ~= 'no'&lt;br /&gt;
	&lt;br /&gt;
	-- Edit links if requested&lt;br /&gt;
	local baselink = frame:getParent():getTitle()&lt;br /&gt;
	if mw.title.getCurrentTitle().text == baselink then	baselink = '' end&lt;br /&gt;
	local template_name = Args['template_name']&lt;br /&gt;
		or (baselink ~= '' and (':' .. baselink))&lt;br /&gt;
		or ''&lt;br /&gt;
	local edit_links = template_name == '' and ''&lt;br /&gt;
		or require('Module:Navbar')._navbar({&lt;br /&gt;
			template_name,&lt;br /&gt;
			mini=1,&lt;br /&gt;
			style='float:right'&lt;br /&gt;
		})&lt;br /&gt;
		&lt;br /&gt;
	-- Get the custom start point for the table (most will start by default at 1)&lt;br /&gt;
	local top_pos = tonumber(Args['highest_pos']) or 1&lt;br /&gt;
	-- Get the custom end point for the table (unrestricted if bottom_pos is &amp;lt; top_pos)&lt;br /&gt;
	local bottom_pos = tonumber(Args['lowest_pos']) or 0&lt;br /&gt;
	local N_teams = top_pos - 1 -- Default to 0 at start, but higher number needed to skip certain entries&lt;br /&gt;
&lt;br /&gt;
	-- Load some other modules&lt;br /&gt;
	local p_sub = require('Module:Sports table/sub')&lt;br /&gt;
	&lt;br /&gt;
	-- Alternative syntax for team list&lt;br /&gt;
	if Args['team_order'] and Args['team_order'] ~= '' then&lt;br /&gt;
		local tlist = mw.text.split(Args['team_order'], '%s*[;,]%s*')&lt;br /&gt;
		for k, tname in ipairs(tlist) do&lt;br /&gt;
			if tname ~= '' then&lt;br /&gt;
				Args['team' .. k] = tname&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	if Args['team_header_note'] then&lt;br /&gt;
		notes_exist=true&lt;br /&gt;
		local note_string = frame:expandTemplate{ title = 'efn',&lt;br /&gt;
								args = { group='lower-alpha', Args['team_header_note']} }&lt;br /&gt;
		team_header = team_header .. note_string&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Read in number of consecutive teams (ignore entries after skipping a spot)&lt;br /&gt;
	ii_start = N_teams&lt;br /&gt;
	while Args['team'..N_teams+1] ~= nil and (bottom_pos &amp;lt; top_pos or N_teams &amp;lt; bottom_pos) do&lt;br /&gt;
		N_teams = N_teams+1&lt;br /&gt;
		-- Sneakily add it twice to the team_list parameter, once for the actual&lt;br /&gt;
		-- ranking, the second for position lookup in sub-tables&lt;br /&gt;
		-- This is possible because Lua allows both numbers and strings as indices.&lt;br /&gt;
		team_list[N_teams] = Args['team'..N_teams] -- i^th entry is team X&lt;br /&gt;
		team_list[Args['team'..N_teams]] = N_teams -- team X entry is position i&lt;br /&gt;
	end&lt;br /&gt;
	ii_end = N_teams&lt;br /&gt;
	-- Get team to show&lt;br /&gt;
	local ii_show = team_list[Args['showteam']] -- nil if non-existant&lt;br /&gt;
&lt;br /&gt;
	-- Set the font size&lt;br /&gt;
	local font_size=Args['font_size'] or '100%'&lt;br /&gt;
&lt;br /&gt;
	-- Create header&lt;br /&gt;
	-- Open table&lt;br /&gt;
	table.insert(t,'{|class=&amp;quot;wikitable plainrowheaders&amp;quot; style=&amp;quot;text-align:center;font-size:'..font_size..';&amp;quot;\n')&lt;br /&gt;
	-- Table title&lt;br /&gt;
	if Args['title'] then&lt;br /&gt;
		table.insert(t,'|+ ' .. Args['title'] .. '\n')&lt;br /&gt;
	end&lt;br /&gt;
	-- First column&lt;br /&gt;
	t_return.count = 0 			-- Dummy parameter, using subfunction call seems best at this point because both module are intertwined&lt;br /&gt;
	t_return.tab_text = t		-- Actual text&lt;br /&gt;
	t_return = p_sub.colhead(t_return,'auto', edit_links .. ' ' .. team_header)&lt;br /&gt;
	-- Other columns passed to subfunction&lt;br /&gt;
	t_return = p.header(t_return,Args,p_sub,N_teams,team_list,legs,multirowlegs)&lt;br /&gt;
	t = t_return.tab_text&lt;br /&gt;
&lt;br /&gt;
	-- Random value used for uniqueness&lt;br /&gt;
	math.randomseed( os.clock() * 10^8 )&lt;br /&gt;
	local rand_val = math.random()&lt;br /&gt;
&lt;br /&gt;
	local note_string, note_id&lt;br /&gt;
	local note_id_list = {}&lt;br /&gt;
&lt;br /&gt;
	-- Now create individual rows&lt;br /&gt;
	ii_start = tonumber(Args['highest_row']) and (tonumber(Args['highest_row']) &amp;gt; top_pos) and tonumber(Args['highest_row']) or top_pos&lt;br /&gt;
	ii_end = tonumber(Args['lowest_row']) and (tonumber(Args['lowest_row']) &amp;lt; N_teams) and tonumber(Args['lowest_row']) or N_teams&lt;br /&gt;
	for ii=ii_start,ii_end do&lt;br /&gt;
		-- Get team info&lt;br /&gt;
		team_code_ii = team_list[ii]&lt;br /&gt;
		team_name = Args['name_'..team_code_ii] or team_code_ii&lt;br /&gt;
		local ii_style = 'text-align:' .. (Args['team_align'] or 'right') .. ';'&lt;br /&gt;
			.. (ii and ii == ii_show and 'font-weight:bold;' or '')&lt;br /&gt;
			.. (Args['team_nowrap'] and 'white-space:nowrap;' or '')&lt;br /&gt;
		local team_note = Args['note_'..team_code_ii]&lt;br /&gt;
		if team_note then&lt;br /&gt;
			notes_exist = true&lt;br /&gt;
			-- Only when it exist&lt;br /&gt;
			-- First check for existence of reference for note&lt;br /&gt;
			if not Args['note_'..team_note] then&lt;br /&gt;
				-- It's the entry&lt;br /&gt;
				-- Add random end for unique ID if more tables are present on article (which might otherwise share an ID)&lt;br /&gt;
				note_id = '&amp;quot;table_note_'..team_code_ii..rand_val..'&amp;quot;'&lt;br /&gt;
				note_id_list[team_code_ii] = note_id&lt;br /&gt;
				note_string = frame:expandTemplate{ title = 'efn',&lt;br /&gt;
					args = { group='lower-alpha', name=note_id,  team_note} }&lt;br /&gt;
			else&lt;br /&gt;
				-- Check for existence elsewhere&lt;br /&gt;
				local note_local_num = team_list[team_note] or ii_end + 1&lt;br /&gt;
				if note_id_list[team_note] or ((note_local_num &amp;gt;= ii_start) and (note_local_num &amp;lt;= ii_end)) then&lt;br /&gt;
					-- It exists&lt;br /&gt;
					note_id = '&amp;quot;table_note_'..team_note..rand_val..'&amp;quot;' -- Identifier&lt;br /&gt;
					note_string = frame:extensionTag{ name = 'ref',&lt;br /&gt;
						args = { group = 'lower-alpha', name = note_id} }&lt;br /&gt;
				else&lt;br /&gt;
					-- Now define the identifier for this&lt;br /&gt;
					-- Add random end for unique ID&lt;br /&gt;
					note_id = '&amp;quot;table_note_'..team_note..rand_val..'&amp;quot;'&lt;br /&gt;
					note_id_list[team_note] = note_id&lt;br /&gt;
					-- Call refn template&lt;br /&gt;
					note_string = frame:expandTemplate{ title = 'efn',&lt;br /&gt;
						args = { group='lower-alpha', name=note_id, Args['note_'..team_note]} }&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
			-- Now append this to the team_name string&lt;br /&gt;
			team_name = team_name..note_string&lt;br /&gt;
		end&lt;br /&gt;
		-- Team names&lt;br /&gt;
		table.insert(t,'|- \n')  -- New row&lt;br /&gt;
		table.insert(t,'! scope=&amp;quot;row&amp;quot;'.. (multirowlegs and ' rowspan=' .. legs or '') &lt;br /&gt;
			.. 'style=&amp;quot;'.. ii_style ..'&amp;quot;| '..team_name..'\n')  -- Position number&lt;br /&gt;
&lt;br /&gt;
		-- Now include note to match results if needed&lt;br /&gt;
		for jj=top_pos,N_teams do&lt;br /&gt;
			local team_code_jj = team_list[jj]&lt;br /&gt;
			if ii == jj then&lt;br /&gt;
				-- Nothing&lt;br /&gt;
			else&lt;br /&gt;
				for l=1,legs do&lt;br /&gt;
					local m = (legs == 1) and 'match_' or 'match' .. l .. '_'&lt;br /&gt;
					local match_note = Args[m ..team_code_ii..'_'..team_code_jj..'_note']&lt;br /&gt;
					if match_note then&lt;br /&gt;
						notes_exist = true&lt;br /&gt;
						-- Only when it exist&lt;br /&gt;
						-- First check for existence of reference for note&lt;br /&gt;
						if not (Args['note_'..match_note] or Args[m ..match_note..'_note']) then&lt;br /&gt;
							-- It's the entry&lt;br /&gt;
							-- Add random end for unique ID if more tables are present on article (which might otherwise share an ID)&lt;br /&gt;
							note_id = '&amp;quot;table_note_'..team_code_ii..'_'..team_code_jj..rand_val..'&amp;quot;'&lt;br /&gt;
							note_id_list[team_code_ii..'_'..team_code_jj] = note_id&lt;br /&gt;
							note_string = frame:expandTemplate{ title = 'efn',&lt;br /&gt;
								args = { group='lower-alpha', name=note_id,  match_note} }&lt;br /&gt;
						else&lt;br /&gt;
							-- Check for existence elsewhere&lt;br /&gt;
							local note_local_num = team_list[match_note] or ii_end + 1&lt;br /&gt;
							if note_id_list[match_note] or ((note_local_num &amp;gt;= ii_start) and (note_local_num &amp;lt;= ii_end)) then&lt;br /&gt;
								-- It exists&lt;br /&gt;
								note_id = '&amp;quot;table_note_'..match_note..rand_val..'&amp;quot;' -- Identifier&lt;br /&gt;
								note_string = frame:extensionTag{ name = 'ref',&lt;br /&gt;
									args = { group = 'lower-alpha', name = note_id} }&lt;br /&gt;
							else&lt;br /&gt;
								-- Now define the identifier for this&lt;br /&gt;
								-- Add random end for unique ID&lt;br /&gt;
								note_id = '&amp;quot;table_note_'..match_note..rand_val..'&amp;quot;'&lt;br /&gt;
								note_id_list[match_note] = note_id&lt;br /&gt;
								-- Call refn template&lt;br /&gt;
								note_string = frame:expandTemplate{ title = 'efn',&lt;br /&gt;
									args = { group='lower-alpha', name=note_id, Args['note_'..match_note]} }&lt;br /&gt;
							end&lt;br /&gt;
						end&lt;br /&gt;
						-- Now append this to the match result string&lt;br /&gt;
						Args[m..team_code_ii..'_'..team_code_jj] = (Args[m..team_code_ii..'_'..team_code_jj] or '–')..note_string&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		-- Then individual results&lt;br /&gt;
		t = p.row(t,Args,N_teams,team_list,ii,ii_show,legs,multirowlegs)&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Close table&lt;br /&gt;
	table.insert(t, '|}\n')&lt;br /&gt;
&lt;br /&gt;
	-- Get info for footer&lt;br /&gt;
	local update = Args['update']&lt;br /&gt;
		or 'unknown'&lt;br /&gt;
	local start_date = Args['start_date']&lt;br /&gt;
		or 'unknown'&lt;br /&gt;
	local source = Args['source']&lt;br /&gt;
		or frame:expandTemplate{ title = 'citation needed',&lt;br /&gt;
			args = { reason='No source parameter defined', date=os.date('%B %Y') } }&lt;br /&gt;
&lt;br /&gt;
	-- Create footer text&lt;br /&gt;
	-- Date updating&lt;br /&gt;
	if string.lower(update)=='complete' then&lt;br /&gt;
		-- Do nothing&lt;br /&gt;
	elseif update=='' then&lt;br /&gt;
		-- Empty parameter&lt;br /&gt;
		table.insert(t_footer,'Updated to match(es) played on unknown. ')&lt;br /&gt;
	elseif string.lower(update)=='future' then&lt;br /&gt;
		-- Future start date&lt;br /&gt;
		table.insert(t_footer,'First match(es) will be played on '..start_date..'. ')&lt;br /&gt;
	else&lt;br /&gt;
		table.insert(t_footer,'Updated to match(es) played on '..update..'. ')&lt;br /&gt;
	end&lt;br /&gt;
	table.insert(t_footer,'Source: '..source)&lt;br /&gt;
	if (Args['matches_style'] or '') == 'FBR' then&lt;br /&gt;
		table.insert(t_footer, Args['team_header']&lt;br /&gt;
			and '&amp;lt;br /&amp;gt;Legend: Blue = left column team win; Yellow = draw; Red = top row team win.'&lt;br /&gt;
			or '&amp;lt;br /&amp;gt;Legend: Blue = home team win; Yellow = draw; Red = away team win.')&lt;br /&gt;
	elseif (Args['matches_style'] or '') == 'BSR' then&lt;br /&gt;
		table.insert(t_footer, Args['team_header']&lt;br /&gt;
			and '&amp;lt;br /&amp;gt;Legend: Blue = left column team win; Red = top row team win.'&lt;br /&gt;
			or '&amp;lt;br /&amp;gt;Legend: Blue = home team win; Red = away team win.')&lt;br /&gt;
	end&lt;br /&gt;
	if Args['a_note'] then&lt;br /&gt;
		table.insert(t_footer, '&amp;lt;br /&amp;gt;For upcoming matches, an &amp;quot;a&amp;quot; indicates there is an article about the rivalry between the two participants.')&lt;br /&gt;
	end&lt;br /&gt;
	if Args['ot_note'] then&lt;br /&gt;
		table.insert(t_footer, '&amp;lt;br /&amp;gt;Matches with lighter background shading were decided after overtime.')&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	&lt;br /&gt;
	local templatestyles = frame:extensionTag{&lt;br /&gt;
		name = 'templatestyles', args = { src = 'Module:Sports results/styles.css' }&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	-- Add notes (if applicable)&lt;br /&gt;
	if notes_exist then&lt;br /&gt;
		table.insert(t_footer,'&amp;lt;br&amp;gt;Notes:')&lt;br /&gt;
		t_footer = templatestyles .. '&amp;lt;div class=&amp;quot;sports-results-notes&amp;quot;&amp;gt;'..table.concat(t_footer)..'&amp;lt;/div&amp;gt;'&lt;br /&gt;
		t_footer = t_footer..frame:expandTemplate{ title = 'notelist', args = { group='lower-alpha'} }&lt;br /&gt;
	else&lt;br /&gt;
		t_footer = templatestyles .. '&amp;lt;div class=&amp;quot;sports-results-notes&amp;quot;&amp;gt;'..table.concat(t_footer)..'&amp;lt;/div&amp;gt;'&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Add footer to main text table&lt;br /&gt;
	table.insert(t,t_footer)&lt;br /&gt;
	&lt;br /&gt;
	-- Rewrite anchor links&lt;br /&gt;
	for k=1,#t do&lt;br /&gt;
		if t[k]:match('%[%[#[^%[%]]*%|') then&lt;br /&gt;
			t[k] = mw.ustring.gsub(t[k], '(%[%[)(#[^%[%]]*%|)', '%1' .. baselink .. '%2')&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return '&amp;lt;div style=&amp;quot;overflow:hidden&amp;quot;&amp;gt;'&lt;br /&gt;
		.. '&amp;lt;div class=&amp;quot;noresize overflowbugx&amp;quot; style=&amp;quot;overflow:auto&amp;quot;&amp;gt;\n'&lt;br /&gt;
		.. table.concat(t) .. '&amp;lt;/div&amp;gt;&amp;lt;/div&amp;gt;'&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Other functions&lt;br /&gt;
local function get_short_name(s, t, n, ss)&lt;br /&gt;
	-- return short name if defined&lt;br /&gt;
	if s and s ~= '' then&lt;br /&gt;
		return s&lt;br /&gt;
	end&lt;br /&gt;
	-- deflag if necessary&lt;br /&gt;
	if ss and n then&lt;br /&gt;
		if ss == 'noflag' then&lt;br /&gt;
			n = mw.ustring.gsub(n, '%[%[[Ff][Ii][Ll][Ee]:[^%[%]]*%]%]', '')&lt;br /&gt;
		elseif ss == 'flag' then&lt;br /&gt;
			n = mw.ustring.gsub(n, '(&amp;lt;span class=&amp;quot;flagicon&amp;quot;&amp;gt;%s*%[%[[Ff][Ii][Ll][Ee]:[^%[%]]*link=)[^%|%[%]]*(%]%][^&amp;lt;&amp;gt;]*&amp;lt;/span&amp;gt;)%s*%[%[([^%[%]%|]*)%|[^%[%]]*%]%]', '%1%3%2')&lt;br /&gt;
			n = mw.ustring.gsub(n, '.*(&amp;lt;span class=&amp;quot;flagicon&amp;quot;&amp;gt;%s*%[%[[Ff][Ii][Ll][Ee]:[^%[%]]*%]%][^&amp;lt;&amp;gt;]*&amp;lt;/span&amp;gt;).*', '%1')&lt;br /&gt;
			n = mw.ustring.gsub(n, '&amp;amp;nbsp;(&amp;lt;/span&amp;gt;)', '%1')&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- replace link text in name with team abbr if possible&lt;br /&gt;
	if n and t and n:match('(%[%[[^%[%]]*%]%])') then&lt;br /&gt;
		n = mw.ustring.gsub(n, '(%[%[[^%|%]]*%|)[^%|%]]*(%]%])', '%1' .. t .. '%2')&lt;br /&gt;
		n = mw.ustring.gsub(n, '(%[%[[^%|%]]*)(%]%])', '%1|' .. t .. '%2')&lt;br /&gt;
		n = mw.ustring.gsub(n, '(%[%[[^%|%]]*%|)([A-Z][A-Z][A-Z])(%]%])&amp;amp;nbsp;&amp;lt;span[^&amp;lt;&amp;gt;]*&amp;gt;%([A-Z][A-Z][A-Z]%)&amp;lt;/span&amp;gt;', '%1%2%3')&lt;br /&gt;
		return n&lt;br /&gt;
	end&lt;br /&gt;
	-- nothing worked, so just return the unlinked team abbr&lt;br /&gt;
	return t or ''&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function get_score_background(s, c)&lt;br /&gt;
	local s1, s2&lt;br /&gt;
	-- Define the colouring&lt;br /&gt;
	local wc, lc, tc&lt;br /&gt;
	if c == 'level2' then&lt;br /&gt;
	wc, lc, tc = '#CCF9FF', '#FCC', '#FFC' -- blue2, red2, yellow2&lt;br /&gt;
	elseif c == 'level3' then&lt;br /&gt;
	wc, lc, tc = '#DDFCFF', '#FDD', '#FFD' -- blue3, red3, yellow3&lt;br /&gt;
	elseif c == 'level4' then&lt;br /&gt;
	wc, lc, tc = '#EEFFFF', '#FEE', '#FFE' -- blue4, red4, yellow4&lt;br /&gt;
	else&lt;br /&gt;
	wc, lc, tc = '#BBF3FF', '#FBB', '#FFB' -- blue1, red1, yellow1&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- check for override&lt;br /&gt;
	if s:match('^%s*&amp;lt;span%s%s*style%s*=[&amp;quot;\'%s]*background[%-colr]*%s*:([^\'&amp;quot;;&amp;lt;&amp;gt;]*).-$') then&lt;br /&gt;
		local c = mw.ustring.gsub(s,'^%s*&amp;lt;span%s%s*style%s*=[&amp;quot;\'%s]*background[%-colr]*%s*:([^\'&amp;quot;;&amp;lt;&amp;gt;]*).-$', '%1')&lt;br /&gt;
		return c&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- delink if necessary&lt;br /&gt;
	if s:match('^%s*%[%[[^%[%]]*%|([^%[%]]*)%]%]') then&lt;br /&gt;
		s = s:match('^%s*%[%[[^%[%]]*%|([^%[%]]*)%]%]')&lt;br /&gt;
	end&lt;br /&gt;
	if s:match('^%s*%[[^%[%]%s]*%s([^%[%]]*)%]') then&lt;br /&gt;
		s = s:match('^%s*%[[^%[%]%s]*%s([^%[%]]*)%]')&lt;br /&gt;
	end&lt;br /&gt;
	if s:match('&amp;lt;span[^&amp;lt;&amp;gt;]*&amp;gt;(.-)&amp;lt;/span&amp;gt;') then&lt;br /&gt;
		s = s:match('&amp;lt;span[^&amp;lt;&amp;gt;]*&amp;gt;(.-)&amp;lt;/span&amp;gt;')&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- get the scores&lt;br /&gt;
	s1 = tonumber(mw.ustring.gsub( s or '',&lt;br /&gt;
		'^%s*([%d%.][%d%.]*)%s*–%s*([%d%.][%d%.]*).*', '%1' ) or '') or ''&lt;br /&gt;
	s2 = tonumber(mw.ustring.gsub( s or '',&lt;br /&gt;
		'^%s*([%d%.][%d%.]*)%s*–%s*([%d%.][%d%.]*).*', '%2' ) or '') or ''&lt;br /&gt;
&lt;br /&gt;
	-- return colouring if possible&lt;br /&gt;
	if s1 ~= '' and s2 ~= '' then&lt;br /&gt;
		return (s1 &amp;gt; s2) and wc or ((s2 &amp;gt; s1) and lc or tc)&lt;br /&gt;
	else&lt;br /&gt;
		return 'transparent'&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function format_score(s)&lt;br /&gt;
	s = mw.ustring.gsub(s or '', '^%s*([%d%.]+)%s*[–−—%-]%s*([%d%.]+)', '%1–%2')&lt;br /&gt;
	s = mw.ustring.gsub(s, '^%s*([%d%.]+)%s*&amp;amp;[MmNn][Dd][Aa][Ss][Hh];%s*([%d%.]+)', '%1–%2')&lt;br /&gt;
	s = mw.ustring.gsub(s, '^%s*(%[%[[^%[%]]*%|[%d%.]+)%s*%-%s*([%d%.]+)', '%1–%2')&lt;br /&gt;
	s = mw.ustring.gsub(s, '^%s*(%[[^%[%]%s]*%s+[%d%.]+)%s*%-%s*([%d%.]+)', '%1–%2')&lt;br /&gt;
	s = mw.ustring.gsub(s, '^%s*(%[%[[^%[%]]*%|[%d%.]+)%s*&amp;amp;[MmNn][Dd][Aa][Ss][Hh];%s*([%d%.]+)', '%1–%2')&lt;br /&gt;
	s = mw.ustring.gsub(s, '^%s*(%[[^%[%]%s]*%s+[%d%.]+)%s*&amp;amp;[MmNn][Dd][Aa][Ss][Hh];%s*([%d%.]+)', '%1–%2')&lt;br /&gt;
	return s&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.header(tt,Args,p_sub,N_teams,team_list,legs,multirowlegs)&lt;br /&gt;
	local ii, team_code_ii, short_name&lt;br /&gt;
	legs = legs or 1&lt;br /&gt;
&lt;br /&gt;
	-- Set match column width&lt;br /&gt;
	local col_width = Args['match_col_width'] or '28'&lt;br /&gt;
&lt;br /&gt;
	-- Get some default values in case it doesn't start at 1&lt;br /&gt;
	local top_pos = tonumber(Args['highest_pos']) or 1&lt;br /&gt;
&lt;br /&gt;
	for l=1,legs do&lt;br /&gt;
		if multirowlegs and l &amp;gt; 1 then&lt;br /&gt;
			break&lt;br /&gt;
		end&lt;br /&gt;
		for ii=top_pos,N_teams do&lt;br /&gt;
			team_code_ii = team_list[ii]&lt;br /&gt;
			short_name = get_short_name(Args['short_'..team_code_ii],&lt;br /&gt;
				team_code_ii, Args['name_'..team_code_ii], Args['short_style'] or '')&lt;br /&gt;
			local bl = legs &amp;gt; 1 and ii == top_pos and ' style=&amp;quot;border-left:2px solid #aaa;&amp;quot;' or ''&lt;br /&gt;
			tt = p_sub.colhead(tt,col_width .. bl,short_name)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return tt&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.row(tt,Args,N_teams,team_list,ii,ii_show,legs,multirowlegs)&lt;br /&gt;
	-- Note ii is the row number being shown&lt;br /&gt;
	local jj, fw, bg, result, result_extra, team_code_ii, team_code_jj&lt;br /&gt;
	legs = legs or 1&lt;br /&gt;
&lt;br /&gt;
	-- Set score cell style&lt;br /&gt;
	local matches_style = Args['matches_style'] or ''&lt;br /&gt;
&lt;br /&gt;
	team_code_ii = team_list[ii]&lt;br /&gt;
&lt;br /&gt;
	-- Get some default values in case it doesn't start at 1&lt;br /&gt;
	local top_pos = tonumber(Args['highest_pos']) or 1&lt;br /&gt;
	for l=1,legs do&lt;br /&gt;
		if multirowlegs and l &amp;gt; 1 then&lt;br /&gt;
			table.insert(tt,'|- \n')  -- New row&lt;br /&gt;
		end&lt;br /&gt;
		for jj=top_pos,N_teams do&lt;br /&gt;
			team_code_jj = team_list[jj]&lt;br /&gt;
			local m = (legs == 1) and 'match_' or 'match' .. l .. '_'&lt;br /&gt;
			result = Args[m..team_code_ii..'_'..team_code_jj] or ''&lt;br /&gt;
			result_extra = Args['result_'..team_code_ii..'_'..team_code_jj] or ''&lt;br /&gt;
			local bl = legs &amp;gt; 1 and jj == top_pos and 'border-left:2px solid #aaa;' or ''&lt;br /&gt;
&lt;br /&gt;
			if ii == jj or result == 'null' then&lt;br /&gt;
				-- Solid cell&lt;br /&gt;
				fw = 'font-weight:' .. (ii==ii_show and 'bold' or 'normal') .. ';'&lt;br /&gt;
				bg = 'background:transparent;'&lt;br /&gt;
&lt;br /&gt;
				-- Grey background color for solid cell&lt;br /&gt;
				if Args['solid_cell'] == 'grey' then&lt;br /&gt;
					table.insert(tt,'| style=&amp;quot;'..fw..bl..'background:#bbb;&amp;quot; |\n')&lt;br /&gt;
				else&lt;br /&gt;
					table.insert(tt,'| style=&amp;quot;'..fw..bl..bg..'&amp;quot; | &amp;amp;mdash;\n')&lt;br /&gt;
				end&lt;br /&gt;
			else&lt;br /&gt;
				-- Content cell&lt;br /&gt;
				-- Set bolding and background&lt;br /&gt;
				fw = 'font-weight:' .. ((ii==ii_show or jj == ii_show) and 'bold' or 'normal') .. ';'&lt;br /&gt;
				bg = 'background:transparent;'&lt;br /&gt;
&lt;br /&gt;
				-- Reformat dashes&lt;br /&gt;
				if result ~= '' then&lt;br /&gt;
					result = format_score(result)&lt;br /&gt;
				end&lt;br /&gt;
				-- Background coloring if enabled&lt;br /&gt;
				if matches_style == 'FBR' and result ~= '' then&lt;br /&gt;
					if result_extra == 'OT' then&lt;br /&gt;
						bg = 'background:' .. get_score_background(result,'level2') .. ';'&lt;br /&gt;
					elseif result_extra == 'PK' then&lt;br /&gt;
						bg = 'background:' .. get_score_background(result,'level3') .. ';'&lt;br /&gt;
					else&lt;br /&gt;
						bg = 'background:' .. get_score_background(result,'') .. ';'&lt;br /&gt;
					end&lt;br /&gt;
				elseif matches_style == 'BSR' and result ~= '' then&lt;br /&gt;
					if result_extra == 'OT' then&lt;br /&gt;
						bg = 'background:' .. get_score_background(result,'level3') .. ';'&lt;br /&gt;
					elseif result_extra == 'OTL' then&lt;br /&gt;
						bg = 'background:' .. get_score_background('0–1','level3') .. ';'&lt;br /&gt;
					elseif result_extra == 'OTW' then&lt;br /&gt;
						bg = 'background:' .. get_score_background('1–0','level3') .. ';'&lt;br /&gt;
					elseif result_extra == 'L' then&lt;br /&gt;
						bg = 'background:' .. get_score_background('0–1','') .. ';'&lt;br /&gt;
					elseif result_extra == 'W' then&lt;br /&gt;
						bg = 'background:' .. get_score_background('1–0','') .. ';'&lt;br /&gt;
					else&lt;br /&gt;
						bg = 'background:' .. get_score_background(result,'') .. ';'&lt;br /&gt;
					end&lt;br /&gt;
				end&lt;br /&gt;
				table.insert(tt,'| style=&amp;quot;white-space:nowrap;'..fw..bl..bg..'&amp;quot; |'..result..'\n')&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return tt&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Zoran</name></author>
	</entry>
</feed>