X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/c8b78d7e45756addbc07cc8591ff68ba95f538c3..c09dbeb9c62930fc46ec793d4f18eda815cd8c34:/sc.plp
diff --git a/sc.plp b/sc.plp
index 4105bec..0534c04 100644
--- a/sc.plp
+++ b/sc.plp
@@ -1,155 +1,53 @@
<(common.inc.plp)><:
-my $datafile = 'sc-units.inc.pl';
+my %scver = (
+ id => 'bw',
+ name => 'Brood War',
+ title => 'starcraft',
+ game => 'StarCraft',
+ major => 1,
+);
+
if ($ENV{PATH_INFO} and $ENV{PATH_INFO} eq '/2') {
- $datafile = 'sc2-units.inc.pl';
+ %scver = (
+ id => 'hots',
+ name => 'Heart of the Swarm',
+ title => 'starcraft2',
+ game => 'StarCraft II',
+ major => 2,
+ );
}
+my $datafile = "sc-units-$scver{id}.inc.pl";
Html({
- title => 'starcraft unit cheat sheet',
- version => 'v1.0',
+ title => "$scver{title} unit cheat sheet",
+ version => 'v1.1',
description => [
- 'Reference of StarCraft unit properties,'
- . ' comparing various statistics of all the units in Brood War'
+ "Reference of $scver{game} unit properties,"
+ . " comparing various statistics of all the units in $scver{name}"
. ' including costs, damage, defense, speed, ranges, and abilities.',
],
- keywords => [qw'
+ keywords => [
+ qw'
starcraft game unit statistics stats comparison table sheet cheat
reference software attributes properties
- '],
+ ',
+ $scver{major} < 2 ? qw' bw broodwar brood war ' : qw' starcraft2 hots ',
+ ],
stylesheet => [qw'light'],
+ raw => ' ',
data => [$datafile],
});
-:>
-
StarCraft units
-
-
-Unit properties as seen or measured in Brood War
-versionâ¥1.08 .
-
-
-
+print "Unit properties as seen or measured in $scver{name}\n$patch.\n
\n\n";
-<:
sub coltoggle {
my ($name, $id) = @_;
return sprintf(
@@ -165,7 +63,7 @@ sub coltoggle {
<:= coltoggle(qw'build cost') :>
- <:= coltoggle(qw'size size') :>
+ <:= coltoggle(qw'size size') :>
HP
shield
armor
@@ -178,6 +76,12 @@ sub coltoggle {
<:
sub showrange {
+ my ($min, $max) = @_;
+ $_ = int($_ + .5) for $min, $max; # round halves up
+ return $min == $max ? $min : "$min-$max";
+}
+
+sub showval {
my ($row, @elements) = @_;
my ($min, $max);
@@ -212,9 +116,7 @@ sub showrange {
$min /= 4;
}
}}
- $_ = int($_ + .5) for $min, $max; # round halves up
-
- return $min == $max ? $min : "$min-$max";
+ return showrange($min, $max);
}
sub showattack {
@@ -239,14 +141,15 @@ sub showrange {
}
$tagbase .= '">';
- my $out = showrange($row, 'attack', $area, 'damage');
+ my $out = showval($row, 'attack', $area, 'damage');
$out .= '+ ' if $attack->{splash};
$attack->{dps} = $attack->{cooldown} && [
map { 24 * $_ / $attack->{cooldown} * ($attack->{count} // 1) }
map { ref $_ ? @{$_} : $_ }
$attack->{damage}
+ #TODO: upgrade (zergling)
];
- $out .= '' . showrange($row, 'attack', $area, 'dps');
+ $out .= ' ' . showval($row, 'attack', $area, 'dps');
return $tagbase . $out;
}
@@ -278,6 +181,18 @@ sub showrange {
if ($_->{suit}) {
$suitchar = [qw/? s m l/]->[$_->{suit}];
}
+ elsif ($_->{cargo} > 0) {
+ $suitchar = [qw/? s m l l h h h h/]->[abs $_->{cargo}];
+ }
+ elsif ($_->{size}) {
+ $suitchar = [qw/s m l h h h/]->[$_->{size}];
+ }
+ elsif ($_->{attr} and $_->{attr}->{light}) {
+ $suitchar = 's';
+ }
+ elsif ($_->{attr} and $_->{attr}->{armored}) {
+ $suitchar = 'l';
+ }
return (
' ' . ($_->{min} // ''),
@@ -287,37 +202,45 @@ sub showrange {
$_->{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',
- ),
+ ' ' . (
+ defined $_->{unit} && $_->{unit} == .5 ? '½' : $_->{unit}
+ ),
+ ' ' . join('', grep { $_ }
+ (defined $_->{organic} || $_->{attr}->{organic})
+ && 'o ',
+ (defined $_->{organic} ? !$_->{organic} : $_->{attr}->{mech})
+ && 'm ',
+ $_->{attr}->{psionic}
+ && 'Ï ',
+ ),
+ ' ' . join('', grep { $_ }
+ $_->{attr}->{armored}
+ && 'A ',
+ $_->{attr}->{light}
+ && 'L ',
),
' ' . $_->{hp} // '',
' ' . (
$_->{shield} ? sprintf('%.0f%%', 100 * $_->{shield} / $_->{hp}) : ' '
),
- ' ' . showrange($_, 'armor'),
+ ' ' . showval($_, 'armor'),
showattack($_, 'ground'),
showattack($_, 'air'),
- ' ' . showrange($_, 'attack', 'range'),
+ ' ' . showval($_, 'attack', 'range'),
' ' . sprintf(
$_->{detect} ? '%s ' : '%s',
- showrange($_, 'sight')
+ showval($_, 'sight')
),
- ' ' . showrange($_, 'speed'),
+ ' ' . showval($_, 'speed'),
+ $_->{attr}->{massive} && 'â ',
' ' . showmagic($_),
"\n"
);
}
- my $units = do $datafile;
- die "Cannot open unit data: $_\n" for $@ || $! || ();
- my $grouped = !exists $get{order};
+ my $grouped = 1; # race headers
if (exists $get{order}) {
+ $grouped = 0;
$get{order} ||= '';
if ($get{order} eq 'size') {
$_->{order} = $_->{unit}*8 + $_->{suit} + $_->{hp}/512 + $_->{min}/8192 for @$units;
@@ -329,25 +252,32 @@ sub showrange {
$units->[$_]->{order} = $_ for 0 .. $#$units;
}
}
- my @rows = $grouped ? @$units : sort {$a->{order} <=> $b->{order}} @$units;
+ my @rows = @{$units};
+ @rows = sort {$a->{order} <=> $b->{order}} @rows unless $grouped;
my ($race, $cat) = ('', '');
for (@rows) {
- $race = $_->{race},
- printf ' %s '."\n", $race, ucfirst $race
- if $grouped and $race ne $_->{race};
- $_->{cat} = $_->{race} if not $grouped;
+ if ($grouped) {
+ printf '%s '."\n",
+ $race = $_->{race}, ucfirst $race
+ unless $race eq $_->{race};
+ }
+ else {
+ $_->{cat} = $_->{race};
+ }
+
print(
'',
- sprintf('%s', $cat ne $_->{cat} ? ('h', $cat = $_->{cat}) : ('d', ' ')),
- '' . $_->{name},
+ ' ', $cat ne $_->{cat} && ($cat = $_->{cat}),
+ ' ', $_->{name},
showunitcols($_),
);
- for my $alt (grep { $_->{alt} } @{ $_->{special} }) {
+ for my $subrow (@{ $_->{special} }) {
+ $subrow->{alt} or next;
print(
- ' ' . $alt->{alt},
- showunitcols($alt),
+ ' ', $subrow->{alt},
+ showunitcols($subrow),
);
}
}
@@ -366,9 +296,17 @@ sub showrange {
excludes construction of dependencies such as buildings
and + parent units
size
- affected by S mall,
+ <:
+if ($scver{major} > 1) {
+ :>transports can fit 8 S mall,
+ 4 M edium,
+ 2 L arge,
+ or a single H uge unit<:
+} else {
+ :>affected by S mall,
M edium,
- or L arge unit damage
+ or L arge unit damage<:
+} :>
number of command points taken per unit
o rganic/m echanic unit
HP