X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=util%2Fcql2pqf.c;h=0baa17570cc19b2f78dc68b7df5c0ca5f379482a;hp=9f76c3ad480cc03af0f5935aa0c5dcf5e90baab8;hb=5ef9ca5de57e415b34c21fe0d17a79f7b8e6b636;hpb=d0e351c12fff564d876958e860338d43716dc269 diff --git a/util/cql2pqf.c b/util/cql2pqf.c index 9f76c3a..0baa175 100644 --- a/util/cql2pqf.c +++ b/util/cql2pqf.c @@ -1,5 +1,5 @@ /* This file is part of the YAZ toolkit. - * Copyright (C) 1995-2010 Index Data + * Copyright (C) Index Data * See the file LICENSE for details. */ #if HAVE_CONFIG_H @@ -10,12 +10,17 @@ #include #include +#include #include #include static void usage(void) { - fprintf(stderr, "usage\n cql2pqf [-n ] [-r] []\n"); + fprintf(stderr, "usage\n cql2pqf [-n ] [-r] [-s] [-S] " + "[]\n"); + fprintf(stderr, " -r reverse conversion (RPN to Solr/CQL)\n"); + fprintf(stderr, " -s Solr instead of CQL\n"); + fprintf(stderr, " -S strict CQL 2.0\n"); exit(1); } @@ -26,11 +31,14 @@ int main(int argc, char **argv) char *query = 0; char *fname = 0; int reverse = 0; + int solr = 0; + int verbose = 0; + int do_strict = 0; int ret; char *arg; - while ((ret = options("n:r", argv, argc, &arg)) != -2) + while ((ret = options("n:rsSv", argv, argc, &arg)) != -2) { switch (ret) { @@ -40,33 +48,51 @@ int main(int argc, char **argv) else query = arg; break; + case 'n': + iterations = atoi(arg); + break; case 'r': reverse = 1; break; - case 'n': - iterations = atoi(arg); + case 'S': + do_strict = 1; + break; + case 's': + solr = 1; + break; + case 'v': + verbose = 1; break; default: usage(); } } - if (!fname) - usage(); - if (!strcmp(fname, "-")) - ct = cql_transform_create(); - else - ct = cql_transform_open_fname(fname); - if (!ct) + if (fname) { - fprintf(stderr, "failed to read properties %s\n", fname); - exit(1); + ct = cql_transform_open_fname(fname); + if (!ct) + { + fprintf(stderr, "failed to read properties %s\n", fname); + exit(1); + } } + else + ct = cql_transform_create(); if (reverse) { + char buf[1024]; + if (!query) - usage(); - else + { + if (fgets(buf, sizeof buf, stdin)) + { + if (*buf && buf[strlen(buf)-1] == '\n') + buf[strlen(buf)-1] = '\0'; + query = buf; + } + } + if (query) { ODR odr = odr_createmem(ODR_ENCODE); YAZ_PQF_Parser pp = yaz_pqf_create(); @@ -75,11 +101,15 @@ int main(int argc, char **argv) { fprintf(stderr, "PQF syntax error\n"); } - else + else { - int ret = cql_transform_rpn2cql_stream(ct, cql_fputs, + int ret = 0; + if (solr) + ret = solr_transform_rpn2solr_stream(ct, cql_fputs, + stdout, rpn); + else + ret = cql_transform_rpn2cql_stream(ct, cql_fputs, stdout, rpn); - if (ret) { const char *addinfo; @@ -97,17 +127,24 @@ int main(int argc, char **argv) { CQL_parser cp = cql_parser_create(); int r = 0; - + + cql_parser_strict(cp, do_strict); if (query) { + if (verbose) + printf("Parsing CQL %s\n", query); for (i = 0; i