X-Git-Url: http://sru.miketaylor.org.uk/?a=blobdiff_plain;ds=sidebyside;f=src%2Fyaz-cql2rpn.cpp;h=cf597915c8897b754269e23fa00ce172a114e3f7;hb=86726b00b052694e65b036c262f5fe9096554175;hp=ec3fa54797b81ab6128b14c5cb37db88ecf841cf;hpb=307a8638d6429b0f77ad762d52309c550e45648c;p=yazpp-moved-to-github.git diff --git a/src/yaz-cql2rpn.cpp b/src/yaz-cql2rpn.cpp index ec3fa54..cf59791 100644 --- a/src/yaz-cql2rpn.cpp +++ b/src/yaz-cql2rpn.cpp @@ -1,13 +1,15 @@ /* - * Copyright (c) 1998-2003, Index Data. + * Copyright (c) 1998-2004, Index Data. * See the file LICENSE for details. * - * $Id: yaz-cql2rpn.cpp,v 1.1 2003-12-16 14:17:01 adam Exp $ + * $Id: yaz-cql2rpn.cpp,v 1.7 2005-06-02 06:40:21 adam Exp $ */ #include #include -#include +#include + +using namespace yazpp_1; Yaz_cql2rpn::Yaz_cql2rpn() { @@ -27,8 +29,10 @@ void Yaz_cql2rpn::set_pqf_file(const char *fname) } int Yaz_cql2rpn::query_transform(const char *cql_query, - Z_RPNQuery **rpnquery, ODR o) + Z_RPNQuery **rpnquery, ODR o, + char **addinfop) { + const char *addinfo = 0; if (!m_transform) return -3; CQL_parser cp = cql_parser_create(); @@ -36,8 +40,8 @@ int Yaz_cql2rpn::query_transform(const char *cql_query, int r = cql_parser_string(cp, cql_query); if (r) { - yaz_log(LOG_LOG, "CQL Parse Error"); - return r; + yaz_log(YLOG_LOG, "CQL Parse Error"); + r = 10; } else { @@ -54,21 +58,23 @@ int Yaz_cql2rpn::query_transform(const char *cql_query, size_t off; const char *pqf_msg; int code = yaz_pqf_error(pp, &pqf_msg, &off); - yaz_log(LOG_WARN, "PQF Parser Error %s (code %d)", + yaz_log(YLOG_WARN, "PQF Parser Error %s (code %d)", pqf_msg, code); - yaz_pqf_destroy(pp); - return -1; + r = -1; } yaz_pqf_destroy(pp); } else { - const char *addinfo; - cql_transform_error(m_transform, &addinfo); - yaz_log(LOG_LOG, "CQL Transform Error %d %s", r, + r = cql_transform_error(m_transform, &addinfo); + yaz_log(YLOG_LOG, "CQL Transform Error %d %s", r, addinfo ? addinfo : ""); - return -2; } } - return 0; + cql_parser_destroy(cp); + if (addinfo) + *addinfop = odr_strdup(o, addinfo); + else + *addinfop = 0; + return r; }