X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/0717d6cc5980a7fed67caf8aa227b9bff003b47b..7affe2df7fee946f49e1561a5f58240bd0309b4f:/browser.plp diff --git a/browser.plp b/browser.plp index 863f806..8c6b5ed 100644 --- a/browser.plp +++ b/browser.plp @@ -69,7 +69,7 @@ if (my ($somerow) = values %{ $caniuse->{data} }) { } } my @browsers = grep { $versions{$_} } - qw(trident gecko webkit_saf ios_saf webkit_chr android presto op_mob op_mini); + qw(trident ie gecko firefox webkit_saf safari ios_saf webkit_chr chrome android presto opera op_mob op_mini); print <<'';

Alternate rendition of Fyrd's when can I use... page @@ -79,7 +79,7 @@ given ($get{usage} // 'wm') { when (!$_) { # none } - when (!/^\w+$/) { + when (!/^[a-z][\w-]+$/) { printf "

Invalid browser usage data request: %s", 'identifier must be alphanumeric name or 0'; } @@ -265,14 +265,23 @@ sub saystatuscol { sub saybrowsercols { my ($id, $browser) = @_; my $data = $caniuse->{data}->{$id}->{stats}->{$browser}; + if (ref $data eq 'ARRAY') { + # special case for unsupported + my $release = $caniuse->{agents}->{$browser}->{verrelease}; + $data = { + map { $_ => defined $release->{$_} ? 'u' : 'n' } keys %$release + }; + } my ($prev, @span); for my $ver (@{ $versions{$browser} }, undef) { my $compare = ( !defined $ver ? undef : # last column if nameless - ref $data ne 'HASH' ? 'u' : # unsupported if no support hash - $data->{$ver} # known - || 'u' # unsure unless oldest is unsupported + ref $data ne 'HASH' ? '' : # unclassified if no support hash + $data->{$ver} // $prev # known or inherit from predecessor + // (grep { defined } @{$data}{ @{ $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);