print "<p>Unit properties as seen or measured in $scver{name}\n$patch.\n</p>\n\n";
+sub addupgrade {
+ my ($ref, $increase) = @_;
+ if (ref $increase eq 'HASH') {
+ addupgrade(\${$ref}->{$_}, $increase->{$_}) for keys %{$increase};
+ }
+ elsif (ref $increase eq 'ARRAY') {
+ addupgrade(\${$ref}->[$_], $increase->[$_]) for 0 .. $#{$increase};
+ }
+ ${$ref} += $increase if $increase =~ /^-?[0-9.]+/;
+}
+
for my $unit (@{$units}) {
- for my $upgrade (@{ $unit->{upgrade} // $unit->{update} // [] }) {
+ for my $upgrade (@{ $unit->{upgrade} }) {
while (my ($col, $increase) = each %{$upgrade}) {
defined $unit->{$col} or next;
-
- if (ref $increase eq 'ARRAY') {
- for my $incrow (0 .. $#{$increase}) {
- while (my ($inccol, $subinc) = each %{ $increase->[$incrow] }) {
- $unit->{upgraded}->{$col}->[$incrow]->{$inccol}
- //= ref $unit->{$col}->[$incrow]->{$inccol}
- ? $unit->{$col}->[$incrow]->{$inccol}->[-1]
- : $unit->{$col}->[$incrow]->{$inccol};
- $unit->{upgraded}->{$col}->[$incrow]->{$inccol}
- += ref $subinc ? $subinc->[-1] : $subinc;
- }
- }
- }
- elsif ($increase =~ /^-?[0-9.]+/) {
- $unit->{upgraded}->{$col} //= $unit->{$col};
- $unit->{upgraded}->{$col} += $increase;
- }
+ addupgrade(\( $unit->{upgraded}->{$col} //= $unit->{$col} ), $increase);
}
}
}
$out .= '">';
my $upattack = $row->{upgraded}->{attack}->[$area];
- my $maxdamage =
my $damage = $attack->{damage};
- ($damage, $maxdamage) = ($damage->[0], $upattack->{damage} // $damage->[-1])
- if ref $damage;
+ my $maxdamage = $upattack->{damage} // $damage;
+ $damage = $damage->[0] if ref $damage;
+ $maxdamage = $maxdamage->[-1] if ref $maxdamage;
+ $out .= "<small>$attack->{count}× </small>" if $attack->{count} > 1;
$out .= showrange($damage, $maxdamage);
$out .= sprintf('<span class="unit-splash" title="%s">%s</span>',
$attack->{splash} eq 'line' ? ('linear', '×') : ('splash', '+')