X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fpazpar2_play.c;h=4ecbbbe4aab8641f662799e4c22ac42ea53f18f8;hb=64dccf5757a22cedd3c21ca834e3e02f39dd0504;hp=622885a873b19f34a62cd024e950c28175942cb5;hpb=63771e0c2740834e4496fb6793d058b9b369ad07;p=pazpar2-moved-to-github.git diff --git a/src/pazpar2_play.c b/src/pazpar2_play.c index 622885a..4ecbbbe 100644 --- a/src/pazpar2_play.c +++ b/src/pazpar2_play.c @@ -1,5 +1,5 @@ /* This file is part of Pazpar2. - Copyright (C) 2006-2011 Index Data + Copyright (C) Index Data Pazpar2 is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free @@ -41,7 +41,7 @@ struct con { }; -static int run(FILE *inf, struct addrinfo *res) +static int run(int verbose, FILE *inf, struct addrinfo *res) { long long tv_sec0 = 0; long long tv_usec0 = 0; @@ -54,6 +54,7 @@ static int run(FILE *inf, struct addrinfo *res) long long id; int sz, r, c; char req[100]; + char request_type[100]; size_t i; struct con **conp; c = fgetc(inf); @@ -66,12 +67,15 @@ static int run(FILE *inf, struct addrinfo *res) c = fgetc(inf); } req[i] = 0; - r = sscanf(req, "%lld %lld %lld %d", &tv_sec1, &tv_usec1, &id, &sz); - if (r != 4) + r = sscanf(req, "%s %lld %lld %lld %d", request_type, + &tv_sec1, &tv_usec1, &id, &sz); + if (r != 5) { fprintf(stderr, "bad line %s\n", req); return -1; } + if (verbose) + fprintf(stderr, "read line: %s\n", req); if (tv_sec0) { struct timeval spec; @@ -84,7 +88,7 @@ static int run(FILE *inf, struct addrinfo *res) } else spec.tv_usec = tv_usec1 - tv_usec0; - + select(0, 0, 0, 0, &spec); } tv_sec0 = tv_sec1; @@ -145,11 +149,20 @@ static int run(FILE *inf, struct addrinfo *res) (long long) toread, (long long) r); return -1; } - w = write((*conp)->fd, buf, toread); - if (w != toread) + if (verbose) { - fprintf(stderr, "write truncated\n"); - return -1; + fprintf(stderr, "read %ld bytes\n---\n", (long) r); + fwrite(buf, 1, r, stderr); + fprintf(stderr, "\n----\n"); + } + if (*request_type == 'r') + { /* Only deal with things that Pazpar2 received */ + w = write((*conp)->fd, buf, toread); + if (w != toread) + { + fprintf(stderr, "write truncated\n"); + return -1; + } } cnt += toread; } @@ -170,6 +183,7 @@ int main(int argc, char **argv) int ret; char *arg; char *host = 0; + int verbose = 0; const char *file = 0; while ((ret = options("v:", argv, argc, &arg)) != -2) { @@ -208,7 +222,7 @@ int main(int argc, char **argv) hints.ai_addr = NULL; hints.ai_canonname = NULL; hints.ai_next = NULL; - + cp = strchr(host, ':'); if (*cp) { @@ -231,7 +245,7 @@ int main(int argc, char **argv) fprintf(stderr, "cannot open %s\n", file); exit(1); } - run(inf, res); + run(verbose, inf, res); fclose(inf); } else