X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/ca987f558f793b296a159060a2fbe3f8f164eb67..67ec2894e74854c57a71690314d268a9c1c179f0:/sc.plp
diff --git a/sc.plp b/sc.plp
index 7ae2805..76974c9 100644
--- a/sc.plp
+++ b/sc.plp
@@ -1,7 +1,12 @@
<(common.inc.plp)><:
+my $datafile = 'sc-units.inc.pl';
+if ($ENV{PATH_INFO} and $ENV{PATH_INFO} eq '/2') {
+ $datafile = 'sc2-units.inc.pl';
+}
+
Html({
- title => 'starcraft unit cheat sheets',
+ title => 'starcraft unit cheat sheet',
version => 'v1.0',
description => [
'Reference of StarCraft unit properties,'
@@ -13,10 +18,11 @@ Html({
reference software attributes properties
'],
stylesheet => [qw'light'],
+ data => [$datafile],
});
:>
-
Unit properties as seen or measured in Brood War
@@ -25,15 +31,16 @@ Unit properties as seen or measured in Brood War
<:
@@ -126,8 +159,8 @@ sub coltoggle {
|
<:= coltoggle('name', '') :> |
- |
- |
+ |
+ |
<:= coltoggle(qw'build cost') :> |
<:= coltoggle(qw'size size') :> |
HP |
@@ -140,7 +173,6 @@ sub coltoggle {
speed |
specials |
-
<:
sub showrange {
my ($row, @elements) = @_;
@@ -166,16 +198,18 @@ sub showrange {
}
}
- if ($elements[0] eq 'attack' and $elements[1] ne 'range' and $elements[2] eq 'cmp') {{
- my $type = $row->{$elements[0]}->{$elements[1]}->{type} or next;
+ if ($elements[0] eq 'attack' and $elements[1] ne 'range' and $elements[2] eq 'dps') {{
+ my $attack = $row->{ $elements[0] }->{ $elements[1] };
+ ref $attack or $attack = $row->{ $elements[0] }->{$attack}; # follow
+ my $type = $attack->{type} or next;
if ($type eq 'explosive') {
$min /= 2;
}
elsif ($type eq 'implosive') {
$min /= 4;
}
- $min = int($min + .5); # round halves up
}}
+ $_ = int($_ + .5) for $min, $max; # round halves up
return $min == $max ? $min : "$min-$max";
}
@@ -183,6 +217,11 @@ sub showrange {
sub showattack {
my ($row, $area) = @_;
local $_ = $row->{attack}->{$area};
+ if (not ref $_) {
+ # reference to another area
+ $area = $_;
+ $_ = $row->{attack}->{$area};
+ }
return '' unless $_;
@@ -199,7 +238,7 @@ sub showrange {
my $out = showrange($row, 'attack', $area, 'damage');
$out .= '+' if $_->{splash};
- $out .= ' | ' . showrange($row, 'attack', $area, 'cmp');
+ $out .= ' | ' . showrange($row, 'attack', $area, 'dps');
return $tagbase . $out;
}
@@ -220,13 +259,56 @@ sub showrange {
} @$specials;
}
- my $units = do 'sc-units.inc.pl';
- die "Cannot open unit data: $_\n" for $! || $@ || ();
+ sub showunitcols {
+ my ($row) = @_;
+ local $_ = $row;
+ my $suitchar = '';
+ if ($_->{suit}) {
+ $suitchar = [qw/? s m l/]->[$_->{suit}];
+ }
+
+ return (
+ ' | ' . ($_->{min} // ''),
+ ' | ' . ($_->{gas} || ''),
+ !defined $_->{build} ? ' | ' : sprintf(' | %s%.0f',
+ !!$_->{base} && '+',
+ $_->{build} || '0',
+ ),
+ !$suitchar ? ' | ' : sprintf(' | %s', $suitchar, ucfirst $suitchar),
+ ' | ' . join('',
+ defined $_->{unit} && $_->{unit} == .5 ? '½' : $_->{unit},
+ defined $_->{organic} && sprintf(
+ '%s',
+ $_->{organic} ? 'o' : 'u',
+ $_->{organic} ? 'organic' : 'mechanic',
+ $_->{organic} ? 'o' : 'm',
+ ),
+ ),
+ ' | ' . $_->{hp} // '',
+ ' | ' . (
+ $_->{shield} ? sprintf('%.0f%%', 100 * $_->{shield} / $_->{hp}) : ' '
+ ),
+ ' | ' . showrange($_, 'armor'),
+ showattack($_, 'ground'),
+ showattack($_, 'air'),
+ ' | ' . showrange($_, 'attack', 'range'),
+ ' | ' . sprintf(
+ $_->{detect} ? '%s' : '%s',
+ showrange($_, 'sight')
+ ),
+ ' | ' . showrange($_, 'speed'),
+ ' | ' . showmagic($_),
+ "\n"
+ );
+ }
+
+ my $units = do $datafile;
+ die "Cannot open unit data: $_\n" for $@ || $! || ();
my $grouped = !exists $get{order};
if (exists $get{order}) {
$get{order} ||= '';
if ($get{order} eq 'size') {
- $_->{order} = $_->{unit}*8 + $_->{size} + $_->{hp}/512 + $_->{min}/8192 for @$units;
+ $_->{order} = $_->{unit}*8 + $_->{suit} + $_->{hp}/512 + $_->{min}/8192 for @$units;
}
elsif ($get{order} eq 'cost') {
$_->{order} = $_->{gas}*1.5 + $_->{min} + $_->{unit}/8 + $_->{build}/256/8 for @$units;
@@ -240,75 +322,44 @@ sub showrange {
my ($race, $cat) = ('', '');
for (@rows) {
$race = $_->{race},
- printf ' |