chiark / gitweb /
routesearch: parse output in query_routesearch
authorIan Jackson <ian@liberator.relativity.greenend.org.uk>
Wed, 14 Oct 2009 22:34:45 +0000 (23:34 +0100)
committerIan Jackson <ian@liberator.relativity.greenend.org.uk>
Wed, 14 Oct 2009 22:34:45 +0000 (23:34 +0100)
yarrg/rsmain.c
yarrg/web/query_routesearch

index dd3748f..eaa16c5 100644 (file)
@@ -181,8 +181,8 @@ int main(int argc, const char **argv) {
          int midisle= ports[nports/2];
          int midarch= route2midarch(ports,nports);
          fprintf(output,
-                 " @%2d #%2d | start%3d mid%d:%3d f%d:%3d | %5d %5d %4d |",
-                 pos, nhighscores[granui][ap] - 1 - pos,
+                 " @%2d %c#%2d | start%3d mid%d:%3d f%d:%3d | %5d %5d %4d |",
+                 pos, "ap"[ap], nhighscores[granui][ap] - 1 - pos,
                  ports[0], midarch,midisle, finarch,finisle,
                  (int)hs->value, (int)pr->value[A], (int)pr->value[P]);
          for (i=0; i<nports; i++) fprintf(output," %d",ports[i]);
index 9accc54..af18d36 100644 (file)
@@ -55,6 +55,7 @@ my @islandids;
 my $qa= \%ARGS;
 my $routeparams= { EmsgRef => \$emsg, SayRequiredCapacity => 1 };
 my $maxdist;
+my $maxcountea=10;
 
 </%perl>
 
@@ -112,7 +113,7 @@ foreach my $k (qw(MaxMass MaxVolume MaxCapital)) {
 }
 push @rsargs, defined $routeparams->{LossPerLeaguePct}
        ? $routeparams->{LossPerLeaguePct}*0.01 : 1e-9;
-push @rsargs, qw(search 10 10), $maxdist, 'any', @islandids;
+push @rsargs, 'search', $maxcountea,$maxcountea, $maxdist, 'any', @islandids;
 
 m/[^-.0-9a-zA-Z]/ and die "$_ $& ?" foreach @rsargs;
 
@@ -127,6 +128,8 @@ if ($qa->{'debug'}) {
 
 unshift @rsargs, sourcebasedir().'/yarrg/routesearch';
 
+my %results; # $results{$ap}{"5 6 9 10"} = { stuff }
+
 my $fh= new IO::File;
 my $child= $fh->open("-|"); defined $child or die $!;
 if (!$child) {
@@ -145,6 +148,13 @@ while (<$fh>) {
 <% $_ |h %>
 <%perl>
        }
+       next unless
+  m/^ \@ *\d+ ([ap])\# *\d+ \|.*\| *\d+ +(\d+) +(\d+) *\| ([0-9 ]+)$/;
+       my ($ap,$isles) = (uc $1,$4);
+       next if $results{$ap} && %{$results{$ap}} >= $maxcountea;
+       my $item= { A => $2, P => $3 };
+#      my @isles= map { @islenames[$_] }, split / /, @isles;
+       $results{$ap}{$isles}= $item;
 }
 
 if ($qa->{'debug'}) {
@@ -152,3 +162,23 @@ if ($qa->{'debug'}) {
 }
 
 </%perl>
+% foreach my $ap (qw(A P)) {
+<h2>ap=<% $ap %></h2>
+<table rules=all>
+%      foreach my $isles (sort {
+%                      $results{$ap}{$a}{Values}{$ap} <=>
+%                      $results{$ap}{$b}{Values}{$ap}
+%              } keys %{$results{$ap}}) {
+%              my $item= $results{$ap}{$isles};
+<tr>
+<td align=right><% $item->{A} |h %>
+<td align=right><% $item->{P} |h %>
+<td align=center><% $isles |h %>
+</td>
+%      } # $isles
+</table>
+% } # $ap
+<%perl>
+
+
+</%perl>