X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/765cc0dd3089fcc723c69627044c91a845da46ae..70cddeb28fadb6c81c9af75483c179a521a1dcdf:/sc.plp diff --git a/sc.plp b/sc.plp index 08cbc45..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} // $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); } } } @@ -113,27 +108,23 @@ sub showrange { my $attack = $row->{attack}->[$area] or return ''; - my $tagbase = ''; - $tagbase .= '' . '▽' x !!($attack->{anti} & 1); - $tagbase .= '' . '△' x !!($attack->{anti} & 2); - $tagbase .= ''; + my $out = ''; + $out .= '' . '▽' x !!($attack->{anti} & 1); + $out .= '' . '△' x !!($attack->{anti} & 2); + $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; - my $out = showrange($damage, $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', '+') ) if $attack->{splash}; @@ -154,7 +145,7 @@ sub showrange { $out .= showrange($damage, $maxdamage); } - return $tagbase . $out; + return $out; } sub showmagic { @@ -364,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