X-Git-Url: http://lists.indexdata.dk/cgi-bin?a=blobdiff_plain;f=src%2Fclient.c;h=e0b9ee1c0fd438be8462f86745bdf09bd2dcfa7b;hb=74580d1462b54e3659ea399c2352e44d8febfc4b;hp=ba2567dc643b03722648e8d2f08bc76339d39653;hpb=f8d8d8ddec7c889411a09248f02e565de1d94cbc;p=pazpar2-moved-to-github.git diff --git a/src/client.c b/src/client.c index ba2567d..e0b9ee1 100644 --- a/src/client.c +++ b/src/client.c @@ -916,10 +916,14 @@ static char *make_solrquery(struct client *cl) ODR odr_out = odr_createmem(ODR_ENCODE); zquery = p_query_rpn(odr_out, cl->pquery); + if (zquery == 0) { + yaz_log(YLOG_WARN, "Failed to generate RPN from PQF: %s", cl->pquery); + return 0; + } yaz_log(YLOG_LOG, "PQF: %s", cl->pquery); if ((status = solr_transform_rpn2solr_wrbuf(sqlt, wrb, zquery))) { - yaz_log(YLOG_WARN, "Failed to generate SOLR query, code=%d", status); + yaz_log(YLOG_WARN, "Failed to generate SOLR query from PQF %s, code=%d", cl->pquery, status); r = 0; } else @@ -939,6 +943,7 @@ static void apply_limit(struct session_database *sdb, int i = 0; const char *name; const char *value; + NMEM nmem_tmp = nmem_create(); for (i = 0; (name = facet_limits_get(facet_limits, i, &value)); i++) { struct setting *s = 0; @@ -948,32 +953,55 @@ static void apply_limit(struct session_database *sdb, const char *p = strchr(s->name + 3, ':'); if (p && !strcmp(p + 1, name) && s->value) { + char **values = 0; + int i, num = 0; + nmem_strsplit_escape2(nmem_tmp, "|", value, &values, + &num, 1, '\\', 1); + if (!strncmp(s->value, "rpn:", 4)) { const char *pqf = s->value + 4; + wrbuf_puts(w_pqf, "@and "); wrbuf_puts(w_pqf, pqf); wrbuf_puts(w_pqf, " "); - yaz_encode_pqf_term(w_pqf, value, strlen(value)); + for (i = 0; i < num; i++) + { + if (i < num - 1) + wrbuf_puts(w_pqf, "@or "); + yaz_encode_pqf_term(w_pqf, values[i], + strlen(values[i])); + } } else if (!strncmp(s->value, "ccl:", 4)) { const char *ccl = s->value + 4; - wrbuf_puts(w_ccl, " and "); - wrbuf_puts(w_ccl, ccl); - wrbuf_puts(w_ccl, "=\""); - wrbuf_puts(w_ccl, value); - wrbuf_puts(w_ccl, "\""); + + wrbuf_puts(w_ccl, " and ("); + + for (i = 0; i < num; i++) + { + if (i) + wrbuf_puts(w_ccl, " or "); + wrbuf_puts(w_ccl, ccl); + wrbuf_puts(w_ccl, "=\""); + wrbuf_puts(w_ccl, values[i]); + wrbuf_puts(w_ccl, "\""); + } + wrbuf_puts(w_ccl, ")"); + } break; } } + nmem_reset(nmem_tmp); if (!s) { - yaz_log(YLOG_WARN, "limit %s used, but no limitmap defined", - name); + yaz_log(YLOG_WARN, "Target %s: limit %s used, but no limitmap defined", + (sdb->database ? sdb->database->url : ""), name); } } + nmem_destroy(nmem_tmp); } // Parse the query given the settings specific to this client