X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?a=blobdiff_plain;f=yarrg%2Frsmain.c;h=c76e7da0b9e0132af407a77cc7b05b88b4c324e6;hb=85fced6311966d8533ce8186f4f98ff8b6303619;hp=a498022649042309a704165ad2ce4e3a6abf7fd2;hpb=39c06791f9cefbedf3438c2a661716142c889bee;p=ypp-sc-tools.db-live.git diff --git a/yarrg/rsmain.c b/yarrg/rsmain.c index a498022..c76e7da 100644 --- a/yarrg/rsmain.c +++ b/yarrg/rsmain.c @@ -2,6 +2,8 @@ #include "rscommon.h" +#include + int o_quiet= 0; double max_mass=-1, max_volu=-1, max_capi=-1; double distance_loss_factor_per_league; @@ -58,22 +60,39 @@ int main(int argc, const char **argv) { double val= value_route(ni, ia, 0); printf("route value is %g\n", val); } else if (!strcmp(arg,"search")) { - results= mcalloc(sizeof(*results)*argc); + MCALLOC(results, argc); + max_dist= atoi(*argv++); + nhighscores_absolute= atoi(*argv++); + nhighscores_perleague= atoi(*argv++); + const char *final_isle_spec= *argv++; + + MCALLOC(highscores_absolute, nhighscores_absolute); + MCALLOC(highscores_perleague, nhighscores_perleague); + int resultsix= 0; - while ((arg= *argv++)) { - search(atoi(arg), &results[resultsix]); + while ((arg= argv[resultsix])) { + int init_isle= atoi(arg); + + int final_isle; + if (!strcmp(final_isle_spec,"circ")) final_isle= init_isle; + else if (!strcmp(final_isle_spec,"any")) final_isle= -1; + else final_isle= atoi(final_isle_spec); + assert(final_isle); + + search(init_isle, final_isle, &results[resultsix]); resultsix++; } int i, midarch, finarch; for (i=0; iabsolute < 100) fprintf(stderr,"| ."); - else fprintf(stderr,"|%3d",(int)(result->absolute / 100)); + fprintf(stderr,"|%5d",(int)(result->absolute)); fprintf(stderr," "); - if (result->perleague < 10) fprintf(stderr," ."); - else fprintf(stderr,"%3d",(int)(result->perleague / 10)); + fprintf(stderr,"%4d",(int)(result->perleague)); } } fprintf(stderr,"\n"); } } + + int pos; +#define OUT(absperl) \ + fprintf(stderr,"\n================== " #absperl " ==================\n"); \ + for (pos=0; pospr; \ + if (!pr) continue; \ + const int *const ports= pr->absperl##_ports; \ + int nports; \ + for (nports=0; nports=0; nports++); \ + int finisle= ports[nports-1]; int finarch= isle2arch(finisle); \ + int midarch= route2midarch(ports,nports); \ + fprintf(stderr, \ + " @%2d #%2d | start%3d mid%d f%d:%3d | %5d %5d %4d |", \ + pos, nhighscores_##absperl - 1 - pos, \ + ports[0], midarch, finarch,finisle, \ + (int)hs->value, (int)pr->absolute, (int)pr->perleague); \ + for (i=0; i