X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fcql2ccl.c;h=4a3932e2ccd5a0bc012b2834a0d77b336f1d3a3f;hb=4a7e5fa76ce41e82c7e028aea763bcf63cd0237b;hp=90ee5d647637ebb64e93850b1a4ec9eb6ea22403;hpb=02d2f2409c58ab49ab535758d85d70fae0f651f4;p=yaz-moved-to-github.git diff --git a/src/cql2ccl.c b/src/cql2ccl.c index 90ee5d6..4a3932e 100644 --- a/src/cql2ccl.c +++ b/src/cql2ccl.c @@ -3,7 +3,7 @@ * See the file LICENSE for details. */ /** - * \file xcqlutil.c + * \file cql2ccl.c * \brief Implements CQL to XCQL conversion. */ #if HAVE_CONFIG_H @@ -21,14 +21,24 @@ static int cql_to_ccl_r(struct cql_node *cn, void *client_data); static void pr_term(struct cql_node *cn, - void (*pr)(const char *buf, void *client_data), - void *client_data) + void (*pr)(const char *buf, void *client_data), + void *client_data) { while (cn) { - pr("\"", client_data); - pr(cn->u.st.term, client_data); - pr("\"", client_data); + const char *cp; + cp = cn->u.st.term; + while (*cp) + { + char x[2]; + if (*cp == '*') + x[0] = '?'; + else + x[0] = *cp; + x[1] = 0; + pr(x, client_data); + cp++; + } if (cn->u.st.extra_terms) pr(" ", client_data); cn = cn->u.st.extra_terms; @@ -98,7 +108,10 @@ static int node(struct cql_node *cn, while (*cp && *cp != ' ') { char x[2]; - x[0] = *cp; + if (*cp == '*') + x[0] = '?'; + else + x[0] = *cp; x[1] = '\0'; pr(x, client_data); cp++; @@ -111,7 +124,6 @@ static int node(struct cql_node *cn, pr(split_op, client_data); pr(" ", client_data); } - return -1; } return 0; } @@ -121,15 +133,19 @@ static int bool(struct cql_node *cn, void (*pr)(const char *buf, void *client_data), void *client_data) { + char *value = cn->u.boolean.value; int r; + /* Rather lame initial attempt at interpreting proximity */ + if (!strcmp(value, "prox")) value = "!"; + pr("(", client_data); r = cql_to_ccl_r(cn->u.boolean.left, pr, client_data); if (r) return r; pr(" ", client_data); - pr(cn->u.boolean.value, client_data); + pr(value, client_data); pr(" ", client_data); r = cql_to_ccl_r(cn->u.boolean.right, pr, client_data); @@ -171,13 +187,16 @@ void cql_to_ccl_stdio(struct cql_node *cn, FILE *f) int cql_to_ccl_buf(struct cql_node *cn, char *out, int max) { struct cql_buf_write_info info; + int r; info.off = 0; info.max = max; info.buf = out; - cql_to_ccl(cn, cql_buf_write_handler, &info); + r = cql_to_ccl(cn, cql_buf_write_handler, &info); if (info.off >= 0) info.buf[info.off] = '\0'; - return info.off; + else + return -2; /* buffer overflow */ + return r; } /*