From: Mischa POSLAWSKY Date: Tue, 15 Feb 2011 22:14:49 +0000 (+0100) Subject: browser: deallocate columns for unused browser versions X-Git-Tag: v1.5~65 X-Git-Url: http://git.shiar.nl/sheet.git/commitdiff_plain/08b6414f6e36757737a9a796c697700e70af05c3 browser: deallocate columns for unused browser versions --- diff --git a/browser.plp b/browser.plp index da50b2d..1158334 100644 --- a/browser.plp +++ b/browser.plp @@ -110,6 +110,24 @@ if ($usage) { # first() does not work inside given >:( $row->{$version} = 0; # balance browser total } + # build row list for each version + if (my $minusage = .2) { + my @vershown; # $verlist replacement + my ($rowusage, @verrow) = (0); # replacement row tracking + for (@$verlist) { + push @verrow, $_; # queue each version + if (($rowusage += $row->{$_}) >= $minusage) { + push @vershown, [@verrow]; # add row + ($rowusage, @verrow) = (0); # reset row tracking + } + } + push @vershown, \@verrow if @verrow; # always add latest + @$verlist = @vershown; + } + else { + @$verlist = map { [$_] } @$verlist; + } + # reusable aggregates (grouped by prefix (engine) and browser) $engineuse{ $caniuse->{agents}->{$browser}->{prefix} } += $row->{-total} = sum(values %$row); @@ -155,7 +173,7 @@ my $usagemax = (max(map { ref $_ eq 'HASH' && sum(values %$_) } values %$canihas my $usagepct = 1; # score multiplier for 0..100 result # normalise usage percentage to only include shown browsers $usagepct = 100.01 / featurescore({ # yes for every possible version - map { $_ => { map {$_ => 'y'} @{$versions{$_}} } } keys %versions + map { $_ => { map {$_ => 'y'} map { @{$_} } @{$versions{$_}} } } keys %versions }); print ''; @@ -190,17 +208,18 @@ print '', $header; print "\n"; print '
' x 3; for my $browser (@browsers) { - for my $_ (@{ $versions{$browser} }) { - my $release = $caniuse->{agents}->{$browser}->{verrelease}->{$_}; + for (@{ $versions{$browser} }) { + my $lastver = $_->[-1]; + my $release = $caniuse->{agents}->{$browser}->{verrelease}->{$lastver}; my $future = defined $release; printf('%s', join(' ', - sprintf('%.1f%%', $canihas->{$browser}->{$_} * $usagepct), + sprintf('%.1f%%', sum(@{ $canihas->{$browser} }{@$_}) * $usagepct), $future ? 'development' : (), - "version $_", + 'version ' . join(', ', @{$_}), ), $future && ' class="ex"', - showversions($_), + showversions($lastver), ); } } @@ -301,13 +320,13 @@ sub saybrowsercols { my $compare = ( !defined $ver ? undef : # last column if nameless ref $data ne 'HASH' ? '' : # unclassified if no support hash - $data->{$ver} // $prev # known or inherit from predecessor - // (grep { defined } @{$data}{ @{ $versions{$browser} } })[0] + $data->{ $ver->[-1] } // $prev # known or inherit from predecessor + // (grep { defined } @{$data}{ map { $_->[0] } @{ $versions{$browser} } })[0] ~~ 'n' && 'n' # first known version is unsupported || 'u' # unsure ); unless (!defined $prev or $prev ~~ $compare) { - my $usage = sum(map { $canihas->{$browser}->{$_} } @span); + my $usage = sum(@{ $canihas->{$browser} }{ map { @{$_} } @span }); printf '%s', join(' ', X => $CSTATS{$prev}, @@ -324,11 +343,11 @@ sub saybrowsercols { map { split / /, $_ } $prev )), - showversions(@span), + showversions($span[0]->[0], @span > 1 ? ($span[-1]->[-1]) : ()), undef $prev; @span = (); } - push @span, $ver; + push @span, $ver && [ grep { $data->{ $_ } eq $data->{ $ver->[-1] } } @{$ver} ]; $prev = $compare; } }