}
:><table class="units">
<thead><tr>
- <th></th>
- <th><:= coltoggle('name', '') :></th>
+ <th><:= coltoggle(exists $get{order} ? 'race' : 'source' => '') :></th>
+ <th><:= coltoggle(name => 'name') :></th>
<th class="val min" title=minerals>cost</th>
<th class="val gas">gas</th>
<th class="val time"><:= coltoggle(qw'build cost') :></th>
if (exists $get{order}) {
$grouped = 0;
$get{order} ||= '';
- if ($get{order} eq 'size') {
- $_->{order} = (
- $_->{pop}*16 + ($_->{size} // $_->{suit}) + $_->{cargo}/8
- + $_->{hp}/512 + $_->{min}/8192
- ) for @rows;
+ if ($get{order} eq 'name') {
+ @rows = sort {$a->{name} cmp $b->{name}} @rows;
}
elsif ($get{order} eq 'cost') {
$_->{order} = (
$_->{gas}*1.5 + $_->{min} + $_->{pop}/8 + $_->{build}/256/8
) for @rows;
}
+ elsif ($get{order} eq 'size') {
+ $_->{order} = (
+ $_->{pop}*16 + ($_->{size} // $_->{suit}) + $_->{cargo}/8
+ + $_->{hp}/512 + $_->{min}/8192
+ ) for @rows;
+ }
elsif ($get{order} eq 'attack') {
$_->{order} = $_->{hp} / 1024 + $_->{shield} / 1008 + max(
map {