X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?p=ypp-sc-tools.db-test.git;a=blobdiff_plain;f=yarrg%2Frsmain.c;h=976aa5a29e4d3a1ed81c44945dcb102a3950b293;hp=c76e7da0b9e0132af407a77cc7b05b88b4c324e6;hb=8dd381ffb993692b376e48eaa4b9ab506b3568e2;hpb=85fced6311966d8533ce8186f4f98ff8b6303619 diff --git a/yarrg/rsmain.c b/yarrg/rsmain.c index c76e7da..976aa5a 100644 --- a/yarrg/rsmain.c +++ b/yarrg/rsmain.c @@ -9,21 +9,32 @@ double max_mass=-1, max_volu=-1, max_capi=-1; double distance_loss_factor_per_league; int max_dist= -1; -#define CTR(x) int ctr_##x; +FILE *debug_file; +FILE *output; + +#define tabdebugf printf + + +#define CTR(x) int ctr_##x; +#define CTRA(x,n) int ctr_##x[n]; COUNTER_LIST #undef CTR +#undef CTRA + +static PotentialResult ****results[GRANUS]; + /* results[GRANUS][start_isle_ix][finalisle][midisle]-> */ -static PotentialResult ****results; - /* results[start_isle_ix][finalisle][midisle]-> */ +static pid_t debugoutpid; int main(int argc, const char **argv) { const char *arg; + int i, ap; + int granui; #ifndef debug_flags debug_flags= ~( dbg_sql2 ); #endif - sysassert( !setvbuf(debug,0,_IOLBF,0) ); - + for (;;) { arg= *++argv; if (arg[0] != '-') break; @@ -37,20 +48,51 @@ int main(int argc, const char **argv) { } } + if (debug_flags) { + /* glpk insists on writing stuff to stdout, and it does buffering, + * so we route all our debug through it this too */ + int realstdout; + sysassert( (realstdout= dup(1)) > 2 ); + sysassert( output= fdopen(realstdout,"w") ); + + int pfd[2]; + sysassert(! pipe(pfd) ); + sysassert( (debugoutpid= fork()) >=0 ); + if (!debugoutpid) { + sysassert( dup2(pfd[0],0)==0 ); + sysassert( dup2(2,1)==1 ); + sysassert(! close(pfd[0]) ); + sysassert(! close(pfd[1]) ); + sysassert(! execlp("cat","cat",(char*)0) ); + } + sysassert( dup2(pfd[1],1)==1 ); + sysassert(! close(pfd[0]) ); + sysassert(! close(pfd[1]) ); + + debug_file= stdout; + } else { + output= stdout; + debug_file= stderr; + } + + const char *database= *argv++; + + sysassert( !setvbuf(debug,0,_IOLBF,0) ); + max_mass= atof(*argv++); max_volu= atof(*argv++); max_capi= atof(*argv++); double loss_per_league= atof(*argv++); - - if (!loss_per_league) loss_per_league= 1e-7; distance_loss_factor_per_league= 1.0 - loss_per_league; - setup_sql(); + setup_sql(database); setup_value(); setup_search(); - fprintf(stderr,"setup complete, starting search\n"); - + for (i=0; iabsolute)); - fprintf(stderr," "); - fprintf(stderr,"%4d",(int)(result->perleague)); + int mid, fin; + for (granui=0; granuivalue[A])); + tabdebugf(" "); + tabdebugf("%4d",(int)(result->value[P])); + } } + tabdebugf("\n"); } - fprintf(stderr,"\n"); - } - } + } /* i */ + + for (ap=0; appr; + if (!pr) continue; + const int *const ports= pr->ports[ap]; + int nports; + for (nports=0; nports=0; nports++); + int finisle= ports[nports-1]; + int finarch= isle2arch(finisle); + 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, + ports[0], midarch,midisle, finarch,finisle, + (int)hs->value, (int)pr->value[A], (int)pr->value[P]); + for (i=0; ipr; \ - 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