X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/4046ca0415407613a8e641945f4a77368dfe50a6..70cddeb28fadb6c81c9af75483c179a521a1dcdf:/sc.plp diff --git a/sc.plp b/sc.plp index 3174511..b06f22e 100644 --- a/sc.plp +++ b/sc.plp @@ -48,27 +48,22 @@ my $patch = shift @{$units} print "

Unit properties as seen or measured in $scver{name}\n$patch.\n

\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} }) { 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); } } } @@ -116,24 +111,19 @@ sub showrange { my $out = ''; $out .= '' . '▽' x !!($attack->{anti} & 1); $out .= '' . '△' x !!($attack->{anti} & 2); - $out .= ''; + $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 .= "$attack->{count}× " if $attack->{count} > 1; + $out .= '*' + if $attack->{type} eq 'explosive'; + $out .= '~' + if $attack->{type} eq 'implosive'; $out .= showrange($damage, $maxdamage); $out .= sprintf('%s', $attack->{splash} eq 'line' ? ('linear', '×') : ('splash', '+') @@ -365,9 +355,9 @@ if ($scver{major} > 1) { 1 second of in-game time
splash damage hits all objects nearby + or in a straight line ×. -
explosive damage does only +
*explosive damage does only 50% damage to small units, 75% to medium, 100% to large -
concussive/plasma damage does +
~concussive/plasma damage does 25% to large, 50% medium, 100% to small units
sight
range in which the unit detects other units