X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?a=blobdiff_plain;f=yarrg%2Frsmain.c;h=774f507e309857db3c603463ed276920a1c8bdb4;hb=6c413329d9f5db8c16f6c1c6378144d1edee4e2e;hp=2a172c9d95999fe91ef0537807383bd5d7a92d05;hpb=01422903688c153437cf6368a58fde42b3125efd;p=ypp-sc-tools.web-live.git diff --git a/yarrg/rsmain.c b/yarrg/rsmain.c index 2a172c9..774f507 100644 --- a/yarrg/rsmain.c +++ b/yarrg/rsmain.c @@ -31,6 +31,8 @@ int main(int argc, const char **argv) { int i, ap; int granui; const char *database=0; + const char *concur_base=0, *concur_rhs=0; + int concur_lim=-1; #ifndef debug_flags debug_flags= ~( dbg_sql2 ); @@ -41,6 +43,10 @@ int main(int argc, const char **argv) { if (arg[0] != '-') break; if (!strcmp(arg,"-d")) { database= *++argv; + } else if (!strcmp(arg,"-C")) { + concur_base= *++argv; + concur_rhs= *++argv; + concur_lim= atoi(*++argv); } else if (!strcmp(arg,"-g")) { granus= atoi(*++argv); assert(granus>=1 && granus<=GRANUS); @@ -49,8 +55,8 @@ int main(int argc, const char **argv) { debug_flags= 0; } else if (!strcmp(arg,"-D1")) { debug_flags= ~(dbg_sql2|dbg_lp|dbg_value2); - } else { #endif + } else { abort(); } } @@ -92,6 +98,28 @@ int main(int argc, const char **argv) { min_trade_maxprofit= atoi(*argv++); + if (concur_base) { + for (i=0; i= 0); + struct flock fl; + memset(&fl,0,sizeof(fl)); + fl.l_type= F_WRLCK; + r= fcntl(concfd, F_SETLK, &fl); + free(concfn); + if (!r) goto concur_ok; + sysassert( errno == EWOULDBLOCK ); + close(concfd); + } + fprintf(output,"@@@ concurrency limit exceeded (%d)\n", concur_lim); + exit(0); + + concur_ok: + /* deliberately leak concfd */ + fprintf(output,"concurrency slot %d\n", i); + } + setup_sql(database); setup_value(); setup_search(); @@ -189,9 +217,10 @@ int main(int argc, const char **argv) { int midisle= ports[nports/2]; int midarch= route2midarch(ports,nports); fprintf(output, - " @%2d %c#%2d | start%3d mid%d:%3d f%d:%3d | %5d %5d %4d |", + " @%2d %c#%2d | start%3d mid%d:%3d f%d:%3d" + " | %3dlg | %5d %5d %4d |", pos, "ap"[ap], nhighscores[granui][ap] - pos, - ports[0], midarch,midisle, finarch,finisle, + ports[0], midarch,midisle, finarch,finisle, pr->length, (int)hs->value, (int)pr->value[A], (int)pr->value[P]); for (i=0; i