git.shiar.nl
/
sheet.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
browser: abbreviate browser names, version numbers
[sheet.git]
/
browser.plp
diff --git
a/browser.plp
b/browser.plp
index 0f5b704d473a5e88a16387188b512ab37de10d3d..330b443c1e944c6614e4087473dd8b7b6c27621a 100644
(file)
--- a/
browser.plp
+++ b/
browser.plp
@@
-47,9
+47,11
@@
my $caniuse = from_json($source, {
my %CSTATS = (
n => 'di-b',
y => 'di-aa',
my %CSTATS = (
n => 'di-b',
y => 'di-aa',
- a => 'di-d',
- j => 'di-prop',
- p => 'di-prop',
+ a => 'di-d',
+ 'a x' => 'di-d',
+ j => 'di-prop',
+ p => 'di-prop',
+ 'p j' => 'di-prop',
'y x' => 'di-a',
);
my %CSTATUS = (
'y x' => 'di-a',
);
my %CSTATUS = (
@@
-68,10
+70,10
@@
if (my ($somerow) = values %{ $caniuse->{data} }) {
}
}
}
}
-my $canihas = do 'browser-usage.inc.pl'
;
-for ($! || $@ || ()) {
-
printf "<p>Browser usage data not found: <em>%s</em>.</p>\n", $_
;
-}
+my $canihas = do 'browser-usage.inc.pl'
or do {
+ printf "<p>Browser usage data not found: <em>%s</em>.</p>\n", $_
+
for $! || $@
;
+}
;
my $scorediv = (max(map { sum(values %$_) } values %$canihas) // 1) / 100;
print '<table class="mapped">';
my $scorediv = (max(map { sum(values %$_) } values %$canihas) // 1) / 100;
print '<table class="mapped">';
@@
-81,19
+83,39
@@
print "\n";
print '<thead><tr>';
print '<th colspan="3">feature';
print '<thead><tr>';
print '<th colspan="3">feature';
-printf '<th colspan="%d">%s',
- scalar @{ $versions{$_} }, $caniuse->{agents}->{$_}->{browser}
- for @browsers;
+printf('<th colspan="%d">%s',
+ scalar @{ $versions{$_} },
+ do {
+ my $name = $caniuse->{agents}->{$_}->{browser};
+ length $name < 16 ? $name : $caniuse->{agents}->{$_}->{abbr};
+ },
+) for @browsers;
+print '<th>%';
# preceding row without any colspan to work around gecko bug
# preceding row without any colspan to work around gecko bug
-print '<tr>';
-print '<td>' x $_ for 3, (map { scalar @{ $versions{$_} } } @browsers), 1;
+print "\n<tr>";
+print '<td>' x 3;
+for my $browser (@browsers) {
+ printf('<td title="%.1f%%">%s',
+ $canihas->{$browser}->{$_}, showversions($_),
+ ) for @{ $versions{$browser} };
+}
+print '<td>' x 1;
print "</thead>\n";
sub featurescore {
# relative amount of support for given feature
print "</thead>\n";
sub featurescore {
# relative amount of support for given feature
- state $statspts = { y=>10, 'y x'=>9, a=>5,
j
=>2, p=>1 };
+ state $statspts = { y=>10, 'y x'=>9, a=>5,
'a x'=>5, j=>2, 'p j'
=>2, p=>1 };
my $rank = 0;
if (my $row = shift) {
my $rank = 0;
if (my $row = shift) {
+ if ($canihas) {
+ while (my ($browser, $versions) = each %$row) {
+ while (my ($version, $_) = each %$versions) {
+ $rank += $canihas->{$browser}->{$version} * $statspts->{$_};
+ }
+ }
+ return $rank;
+ }
+
while (my ($browser, $vercols) = each %versions) {
my $div = 0; # multiplier exponent (decreased to lower value)
my @vers = map { $row->{$browser}->{$_} } @$vercols;
while (my ($browser, $vercols) = each %versions) {
my $div = 0; # multiplier exponent (decreased to lower value)
my @vers = map { $row->{$browser}->{$_} } @$vercols;
@@
-143,7
+165,7
@@
for my $id (sort {
),
scalar @span,
$usage,
),
scalar @span,
$usage,
- showversions(
\
@span),
+ showversions(@span),
undef $prev;
@span = ();
}
undef $prev;
@span = ();
}
@@
-165,13
+187,12
@@
sub paddedver {
}
sub showversions {
}
sub showversions {
- my ($span) = @_;
- splice @$span, 1, -1;
- for (@$span) {
+ my @span = ($_[0], @_>1 ? $_[-1] : ());
+ for (@span) {
s/^\./0./;
s/x$/.*/;
}
s/^\./0./;
s/x$/.*/;
}
- return join('‒', @
$
span);
+ return join('‒', @span);
}
:>
}
:>