X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?p=ypp-sc-tools.main.git;a=blobdiff_plain;f=yarrg%2Frsmain.c;h=67d338b502d961dc3279874cacb1344ab173e4ba;hp=345c8825d2443ba576fa7625a7a46449620d5d0c;hb=27d9c020c52e2ad3d6e8ae5c4b113f062ec01251;hpb=6a0ab469d7d4fbd3cc8c3d4a031d9102b222e384 diff --git a/yarrg/rsmain.c b/yarrg/rsmain.c index 345c882..67d338b 100644 --- a/yarrg/rsmain.c +++ b/yarrg/rsmain.c @@ -1,4 +1,29 @@ -/**/ +/* + * Route searcher - command line parsing and result printing + */ +/* + * This is part of the YARRG website, a tool for assisting + * players of Yohoho Puzzle Pirates. + * + * Copyright (C) 2009 Ian Jackson + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + * + * Yohoho and Puzzle Pirates are probably trademarks of Three Rings and + * are used without permission. This program is not endorsed or + * sponsored by Three Rings. + */ #include "rscommon.h" @@ -31,6 +56,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 +68,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); @@ -92,6 +123,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 +242,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