<?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_table%2FCricketRR</id>
	<title>Module:Sports table/CricketRR - 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_table%2FCricketRR"/>
	<link rel="alternate" type="text/html" href="https://mywikibiz.com/index.php?title=Module:Sports_table/CricketRR&amp;action=history"/>
	<updated>2026-06-19T01:49:21Z</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_table/CricketRR&amp;diff=479580&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_table/CricketRR&amp;diff=479580&amp;oldid=prev"/>
		<updated>2021-07-16T07:20:14Z</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;-- Style for cricket tables&lt;br /&gt;
local pp = { }&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
local function args_points(Args)&lt;br /&gt;
    local pts = {}&lt;br /&gt;
&lt;br /&gt;
    -- Do not change these defaults without first checking which tables use them&lt;br /&gt;
    pts.win = tonumber(Args['winpoints']) or 2&lt;br /&gt;
    pts.tie = tonumber(Args['tiepoints']) or 1&lt;br /&gt;
    pts.nr = tonumber(Args['nrpoints']) or 1&lt;br /&gt;
    pts.loss = tonumber(Args['losspoints']) or 0&lt;br /&gt;
    pts.bonus = tonumber(Args['bonuspoints']) or 1&lt;br /&gt;
&lt;br /&gt;
    return pts&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local function abbr_header(txt, abbr, show_header_pts, pts)&lt;br /&gt;
    if show_header_pts then&lt;br /&gt;
        txt = txt .. ' – ' .. pts .. (pts == 1 and ' point' or ' points')&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    return '&amp;lt;abbr title=&amp;quot;' .. txt .. '&amp;quot;&amp;gt;' .. abbr .. '&amp;lt;/abbr&amp;gt;'&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function pp.header(t, Args, p_sub, pos_label, group_col, VTE_text, full_table, results_header_txt)&lt;br /&gt;
	-- Load relevant modules&lt;br /&gt;
    local yesno = require('Module:Yesno')&lt;br /&gt;
	&lt;br /&gt;
	-- Create table header&lt;br /&gt;
	-- Pre stuff&lt;br /&gt;
&lt;br /&gt;
    local team_width = Args['teamwidth'] or '180'&lt;br /&gt;
    local sort_text = yesno(Args['sortable_table'] or 'no') and ' sortable' or ''&lt;br /&gt;
&lt;br /&gt;
	table.insert(t,'{|class=&amp;quot;wikitable'..sort_text..'&amp;quot; style=&amp;quot;text-align:center;&amp;quot;\n')            			-- Open table&lt;br /&gt;
&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;
&lt;br /&gt;
    --Header specific options&lt;br /&gt;
    local show_pts = yesno(Args['show_header_pts'] or 'no')&lt;br /&gt;
    local pts = args_points(Args)&lt;br /&gt;
&lt;br /&gt;
	local group_head_text = Args['group_header'] or '&amp;lt;abbr title=&amp;quot;Group&amp;quot;&amp;gt;Grp&amp;lt;/abbr&amp;gt;'&lt;br /&gt;
	local team_head_text = Args['team_header'] or 'Team'&lt;br /&gt;
    local tie_head_text = Args['tie_header'] or abbr_header('Tied', 'T', show_pts, pts.tie)&lt;br /&gt;
    local nr_head_text  = Args['nr_header']  or abbr_header('No result', 'NR', show_pts, pts.nr)&lt;br /&gt;
    local bonus_head_text = Args['bonus_header'] or '&amp;lt;abbr title=&amp;quot;Bonus points&amp;quot;&amp;gt;BP&amp;lt;/abbr&amp;gt;'&lt;br /&gt;
    local deduct_head_text = Args['deduct_header'] or '&amp;lt;abbr title=&amp;quot;Deductions&amp;quot;&amp;gt;Ded&amp;lt;/abbr&amp;gt;'&lt;br /&gt;
    local nrr_head_text = Args['nrr_header'] or '&amp;lt;abbr title=&amp;quot;Net run rate&amp;quot;&amp;gt;[[Net run rate|NRR]]&amp;lt;/abbr&amp;gt;'&lt;br /&gt;
    -- &lt;br /&gt;
    local loss_first = yesno(Args['loss_before_tie']  or 'yes')&lt;br /&gt;
    local show_tie = yesno(Args['show_tie'] or 'yes')&lt;br /&gt;
    local show_nr = yesno(Args['show_nr'] or 'yes')&lt;br /&gt;
    local show_deduct = yesno(Args['show_deductions'] or 'no')&lt;br /&gt;
    local show_bonus_points = yesno(Args['show_bonus_points'] or 'no')&lt;br /&gt;
    local show_nrr = yesno(Args['show_nrr'] or 'yes')&lt;br /&gt;
    local show_nrr_fa = yesno(Args['show_nrr_fa'] or 'no') and show_nrr&lt;br /&gt;
&lt;br /&gt;
    -- Initialize&lt;br /&gt;
    local tt = {}&lt;br /&gt;
	tt.count = 0 		-- Up by one after every call&lt;br /&gt;
&lt;br /&gt;
    tt.tab_text = t		-- Actual text&lt;br /&gt;
&lt;br /&gt;
	-- Actual headers&lt;br /&gt;
    if pos_label ~= nil then&lt;br /&gt;
        tt = p_sub.colhead(tt,28,pos_label)								-- Position col&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
	-- Add group header&lt;br /&gt;
	if full_table and group_col then&lt;br /&gt;
		tt = p_sub.colhead(tt,28,group_head_text)			-- Group col&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
    tt = p_sub.colhead(tt, team_width, team_head_text..VTE_text)        -- Team col&lt;br /&gt;
&lt;br /&gt;
    tt = p_sub.colhead(tt,28,'&amp;lt;abbr title=&amp;quot;Played&amp;quot;&amp;gt;Pld&amp;lt;/abbr&amp;gt;')			-- Matches played col&lt;br /&gt;
	&lt;br /&gt;
	if full_table then&lt;br /&gt;
&lt;br /&gt;
        tt = p_sub.colhead(tt,28,abbr_header('Won','W',show_pts,pts.win)) -- Win col&lt;br /&gt;
        local loss_head_text = abbr_header('Lost', 'L', show_pts, pts.loss)&lt;br /&gt;
		&lt;br /&gt;
        if loss_first then&lt;br /&gt;
            tt = p_sub.colhead(tt,28,loss_head_text)					-- Loss col&lt;br /&gt;
&lt;br /&gt;
			if show_tie then&lt;br /&gt;
                tt = p_sub.colhead(tt,28,tie_head_text)					-- Tie col&lt;br /&gt;
            end&lt;br /&gt;
		else&lt;br /&gt;
			if show_tie then&lt;br /&gt;
                tt = p_sub.colhead(tt,28,tie_head_text)					-- Tie col&lt;br /&gt;
            end&lt;br /&gt;
&lt;br /&gt;
            tt = p_sub.colhead(tt, 28, loss_head_text)					-- Loss col&lt;br /&gt;
        end&lt;br /&gt;
        if show_nr then&lt;br /&gt;
            tt = p_sub.colhead(tt,28,nr_head_text)	                    -- No result col&lt;br /&gt;
        end&lt;br /&gt;
        if show_bonus_points then&lt;br /&gt;
            tt = p_sub.colhead(tt,28,bonus_head_text)	                -- Bonus points col&lt;br /&gt;
        end&lt;br /&gt;
        if show_deduct then&lt;br /&gt;
            tt = p_sub.colhead(tt,28,deduct_head_text)	                -- Deduction col&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
    tt = p_sub.colhead(tt, 28, '&amp;lt;abbr title=&amp;quot;Points&amp;quot;&amp;gt;Pts&amp;lt;/abbr&amp;gt;')       -- Points col&lt;br /&gt;
	&lt;br /&gt;
	if full_table then&lt;br /&gt;
        if show_nrr then&lt;br /&gt;
            tt = p_sub.colhead(tt,28,nrr_head_text)	                    -- NRR col&lt;br /&gt;
        end&lt;br /&gt;
        if show_nrr_fa then&lt;br /&gt;
            tt = p_sub.colhead(tt, 60, 'For')&lt;br /&gt;
            tt = p_sub.colhead(tt, 60, 'Against')&lt;br /&gt;
        end&lt;br /&gt;
        tt.count = tt.count+1&lt;br /&gt;
		table.insert(tt.tab_text, results_header_txt)&lt;br /&gt;
    end&lt;br /&gt;
 &lt;br /&gt;
	return tt&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
local function rr_to_dec(runs, overs, balls_per_over)&lt;br /&gt;
    if overs == 0 then&lt;br /&gt;
        return 0&lt;br /&gt;
    end&lt;br /&gt;
    local balls = overs % 1&lt;br /&gt;
    return runs / (overs - balls + balls * 10 / balls_per_over)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
function pp.row(frame, t, Args, p_sub, notes_exist, hth_id_list, full_table, rand_val, team_list, team_code_ii, ii_start, ii_end, ii_fw, bg_col, N_teams, ii, ii_show)&lt;br /&gt;
	-- Build the inner parts of individual rows&lt;br /&gt;
	&lt;br /&gt;
	-- Sub-module usage&lt;br /&gt;
    local mm = require('Module:Math')&lt;br /&gt;
    local yesno = require('Module:Yesno')&lt;br /&gt;
&lt;br /&gt;
    -- table options, to match those in the header        &lt;br /&gt;
    local loss_first = yesno(Args['loss_before_tie']  or 'yes')&lt;br /&gt;
    local show_tie = yesno(Args['show_tie'] or 'yes')&lt;br /&gt;
    local show_nr = yesno(Args['show_nr'] or 'yes')&lt;br /&gt;
    local show_bonus_points = yesno(Args['show_bonus_points'] or 'no')&lt;br /&gt;
    local show_deduct = yesno(Args['show_deductions'] or 'no')&lt;br /&gt;
    local show_nrr = yesno(Args['show_nrr'] or 'yes')&lt;br /&gt;
    local show_nrr_fa = yesno(Args['show_nrr_fa'] or 'no') and show_nrr&lt;br /&gt;
&lt;br /&gt;
    -- Get some input&lt;br /&gt;
    local wins = tonumber(Args['win_'..team_code_ii])       or 0&lt;br /&gt;
	local ties = tonumber(Args['tie_'..team_code_ii])       or 0&lt;br /&gt;
 	local losses = tonumber(Args['loss_'..team_code_ii])    or 0&lt;br /&gt;
	local noresults = tonumber(Args['nr_'..team_code_ii])   or 0&lt;br /&gt;
    local bonuses = tonumber(Args['bonus_'..team_code_ii])  or 0&lt;br /&gt;
    local deductions = tonumber(Args['ded_'..team_code_ii]) or 0&lt;br /&gt;
    local nrr = tonumber(Args['nrr_'..team_code_ii]) or nil&lt;br /&gt;
&lt;br /&gt;
    local oversbowled = tonumber(Args['ob_'..team_code_ii])   or 0&lt;br /&gt;
 	local runsconceded = tonumber(Args['rc_'..team_code_ii])  or 0&lt;br /&gt;
	local oversreceived = tonumber(Args['or_'..team_code_ii]) or 0&lt;br /&gt;
	local runsscored = tonumber(Args['rs_'..team_code_ii])    or 0&lt;br /&gt;
    local balls_per_over = tonumber(Args['balls_per_over']) or 6&lt;br /&gt;
&lt;br /&gt;
	local hth_local = Args['hth_'..team_code_ii]             or nil&lt;br /&gt;
	&lt;br /&gt;
	-- Then calculate some values&lt;br /&gt;
    local matches = wins + losses + ties + noresults&lt;br /&gt;
&lt;br /&gt;
    local pts = args_points(Args)&lt;br /&gt;
    local s_bps = pts.bonus*bonuses&lt;br /&gt;
    local points = pts.win*wins + pts.loss*losses + pts.tie*ties + pts.nr*noresults + s_bps - deductions&lt;br /&gt;
    &lt;br /&gt;
    -- Some local vars&lt;br /&gt;
    local hth_string&lt;br /&gt;
    local tt_return = p_sub.hth(frame, Args, full_table, hth_id_list, hth_local, notes_exist, team_list, team_code_ii, ii_start, ii_end, rand_val)&lt;br /&gt;
    hth_string = tt_return.str&lt;br /&gt;
&lt;br /&gt;
    hth_id_list = tt_return.list&lt;br /&gt;
    notes_exist = tt_return.notes_exist&lt;br /&gt;
&lt;br /&gt;
            -- What to rank the teams by&lt;br /&gt;
    local ranking_style = Args['ranking_style'] or 'pts'&lt;br /&gt;
	local win_fw, win_string, pts_fw, pts_string&lt;br /&gt;
&lt;br /&gt;
    ranking_style = string.lower(ranking_style)&lt;br /&gt;
	if ranking_style=='p' or ranking_style=='pts' or ranking_style=='points' then&lt;br /&gt;
		-- Based on points&lt;br /&gt;
        win_fw = ii_fw&lt;br /&gt;
&lt;br /&gt;
        win_string = ''&lt;br /&gt;
		pts_fw = 'font-weight: bold;'&lt;br /&gt;
		pts_string = hth_string&lt;br /&gt;
	else&lt;br /&gt;
		-- Based on wins&lt;br /&gt;
        win_fw = 'font-weight: bold;'&lt;br /&gt;
&lt;br /&gt;
        win_string = hth_string&lt;br /&gt;
        pts_fw = ii_fw&lt;br /&gt;
&lt;br /&gt;
        pts_string = ''&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
    local nrr_for = rr_to_dec(runsscored, oversreceived, balls_per_over)&lt;br /&gt;
    local nrr_against = rr_to_dec(runsconceded, oversbowled, balls_per_over)&lt;br /&gt;
&lt;br /&gt;
    -- Set Net Run Rate. This is probabaly over-engineered and could just be done with a single precalculated value&lt;br /&gt;
    if nrr ~= nil then&lt;br /&gt;
        nrr = mm._precision_format(nrr, 3)&lt;br /&gt;
    elseif (oversbowled == 0) or (oversreceived == 0) then -- if 0 or null then have mdash rather than 0?&lt;br /&gt;
       nrr = '&amp;amp;mdash;'&lt;br /&gt;
    else&lt;br /&gt;
        nrr = mm._precision_format(nrr_for - nrr_against, 3)&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
	-- Row building&lt;br /&gt;
    table.insert(t,'| style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; |'..matches..'\n') 		-- Played&lt;br /&gt;
&lt;br /&gt;
	if full_table then&lt;br /&gt;
		-- Use actual values if wins, ties, and losses are not numeric. Copied this from other module.&lt;br /&gt;
		if (wins == 0 and ties == 0 and losses == 0) then&lt;br /&gt;
            local function numorval(s)&lt;br /&gt;
				return s and((s == '' and 0) or tonumber(s) or s) or 0&lt;br /&gt;
			end&lt;br /&gt;
            wins = numorval(Args['win_'..team_code_ii])&lt;br /&gt;
            ties = numorval(Args['tie_'..team_code_ii])&lt;br /&gt;
            losses = numorval(Args['loss_'..team_code_ii])&lt;br /&gt;
        end&lt;br /&gt;
        table.insert(t,'| style=&amp;quot;'..win_fw..bg_col..'&amp;quot; |'..wins..win_string..'\n')  -- Won&lt;br /&gt;
        if loss_first then&lt;br /&gt;
            table.insert(t,'| style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; |'..losses..'\n')             -- Lost&lt;br /&gt;
            if show_tie then&lt;br /&gt;
                table.insert(t,'| style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; |'..ties..'\n') 	        -- Ties&lt;br /&gt;
            end&lt;br /&gt;
        else&lt;br /&gt;
            if show_tie then&lt;br /&gt;
                table.insert(t,'| style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; |'..ties..'\n') 	        -- Ties&lt;br /&gt;
            end&lt;br /&gt;
            table.insert(t,'| style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; |'..losses..'\n')             -- Lost&lt;br /&gt;
        end&lt;br /&gt;
        if show_nr then&lt;br /&gt;
            table.insert(t,'| style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; |'..noresults..'\n')         -- No Results&lt;br /&gt;
        end&lt;br /&gt;
	    if show_bonus_points then&lt;br /&gt;
		    if s_bps&amp;lt; 0 then&lt;br /&gt;
                table.insert(t,'| style=&amp;quot;'..bg_col..'&amp;quot; | &amp;amp;minus;'..-s_bps..'\n')&lt;br /&gt;
		    else&lt;br /&gt;
			    table.insert(t,'| style=&amp;quot;'..bg_col..'&amp;quot; | '..s_bps..'\n')&lt;br /&gt;
		    end&lt;br /&gt;
    	end&lt;br /&gt;
    	if show_deduct then &lt;br /&gt;
    	table.insert(t,'| style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; | '..deductions..'\n')&lt;br /&gt;
    	end&lt;br /&gt;
	end&lt;br /&gt;
	if points&amp;lt;0 then&lt;br /&gt;
        table.insert(t,'| style=&amp;quot;'..pts_fw..bg_col..'&amp;quot; | &amp;amp;minus;'..-points..pts_string..'\n')&lt;br /&gt;
	else&lt;br /&gt;
		table.insert(t,'| style=&amp;quot;'..pts_fw..bg_col..'&amp;quot; | '..points..pts_string..'\n')&lt;br /&gt;
	end&lt;br /&gt;
	if full_table then&lt;br /&gt;
        if show_nrr then&lt;br /&gt;
            table.insert(t,'| style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; |'..nrr..'\n') 		-- Net run rate&lt;br /&gt;
        end&lt;br /&gt;
        if show_nrr_fa then&lt;br /&gt;
            local nrr_for_text = oversreceived &amp;gt; 0 and runsscored..'/'..oversreceived or '&amp;amp;mdash;'&lt;br /&gt;
            local nrr_against_text = oversbowled &amp;gt; 0 and runsconceded..'/'..oversbowled or '&amp;amp;mdash;'&lt;br /&gt;
            table.insert(t, '| data-sort-value=&amp;quot;'..nrr_for..'&amp;quot; style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; |'..nrr_for_text..'\n')&lt;br /&gt;
            table.insert(t, '| data-sort-value=&amp;quot;'..nrr_against..'&amp;quot; style=&amp;quot;'..ii_fw..bg_col..'&amp;quot; |'..nrr_against_text..'\n')&lt;br /&gt;
        end&lt;br /&gt;
    end&lt;br /&gt;
&lt;br /&gt;
	return {t=t, notes_exist=notes_exist, hth_id_list=hth_id_list}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function pp.status(Args)&lt;br /&gt;
	-- Declare status options&lt;br /&gt;
	-- ------------------------------------------------------------&lt;br /&gt;
	-- NOTE: If you add to status_code, also add to status_called and status_letters!!&lt;br /&gt;
	-- Or functionality will be compromised&lt;br /&gt;
	-- ------------------------------------------------------------&lt;br /&gt;
	local status_code, status_called = {},{}&lt;br /&gt;
&lt;br /&gt;
    status_code = {	A='Advances to a further round', C='Champion', D='Disqualified', &lt;br /&gt;
		E='Eliminated', G='Guest', H='Host', O='Play-off winner', P='Promoted', Q='Qualified to the phase indicated',&lt;br /&gt;
		R='Relegated', T='Qualified, but not yet to the particular phase indicated' }&lt;br /&gt;
	&lt;br /&gt;
	local status_letters = (Args['status_order'] or '') .. 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'&lt;br /&gt;
&lt;br /&gt;
    -- Status position(before or after read and default)&lt;br /&gt;
&lt;br /&gt;
    local stat_pos_val = string.lower(Args['status_pos'] or '')&lt;br /&gt;
	local status_position = 'after'-- Default location&lt;br /&gt;
	if stat_pos_val=='before' then&lt;br /&gt;
        status_position = 'before'&lt;br /&gt;
    elseif stat_pos_val=='after' then&lt;br /&gt;
        status_position = 'after'&lt;br /&gt;
    end&lt;br /&gt;
	&lt;br /&gt;
	for l in mw.text.gsplit(status_letters, '') do&lt;br /&gt;
		status_called[l] = false&lt;br /&gt;
		status_code[l] = status_code[l] or '?'&lt;br /&gt;
		status_letters = mw.ustring.gsub(status_letters, '(' .. l..'.-)' .. l, '%1')&lt;br /&gt;
&lt;br /&gt;
		if Args['status_text_'..l] then&lt;br /&gt;
            status_code[l] = Args['status_text_'..l]&lt;br /&gt;
        end&lt;br /&gt;
     end&lt;br /&gt;
	&lt;br /&gt;
	return {code=status_code, called=status_called, letters=status_letters, position=status_position}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return pp&lt;/div&gt;</summary>
		<author><name>Zoran</name></author>
	</entry>
</feed>