X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fclient.c;h=16099ba7d13782bf2071fa3468863853fd0d7ca2;hb=5b3c0fa381448c474b59959e0443870f2e6bc7ef;hp=dd3b58c1e3d71a1e658e348af861f03d0c3cd18e;hpb=ebf44db2f0c270b3ae1c25a5dc627f8e2a932da7;p=pazpar2-moved-to-github.git diff --git a/src/client.c b/src/client.c index dd3b58c..16099ba 100644 --- a/src/client.c +++ b/src/client.c @@ -425,40 +425,42 @@ static int nativesyntax_to_type(struct session_database *sdb, char *type, */ void client_report_facets(struct client *cl, ZOOM_resultset rs) { - int facet_idx; struct session_database *sdb = client_get_database(cl); ZOOM_facet_field *facets = ZOOM_resultset_facets(rs); - int facet_num; - struct session *se = client_get_session(cl); - struct setting *s; - facet_num = ZOOM_resultset_facets_size(rs); - yaz_log(YLOG_DEBUG, "client_report_facets: %d", facet_num); - for (s = sdb->settings[PZ_FACETMAP]; s; s = s->next) + if (sdb && facets) { - const char *p = strchr(s->name + 3, ':'); - if (p && p[1] && s->value && s->value[0]) + struct session *se = client_get_session(cl); + int facet_num = ZOOM_resultset_facets_size(rs); + struct setting *s; + + for (s = sdb->settings[PZ_FACETMAP]; s; s = s->next) { - p++; /* p now holds logical facet name */ - for (facet_idx = 0; facet_idx < facet_num; facet_idx++) + const char *p = strchr(s->name + 3, ':'); + if (p && p[1] && s->value && s->value[0]) { - const char *native_name = - ZOOM_facet_field_name(facets[facet_idx]); - if (native_name && !strcmp(s->value, native_name)) + int facet_idx; + p++; /* p now holds logical facet name */ + for (facet_idx = 0; facet_idx < facet_num; facet_idx++) { - size_t term_idx; - size_t term_num = - ZOOM_facet_field_term_count(facets[facet_idx]); - for (term_idx = 0; term_idx < term_num; term_idx++ ) + const char *native_name = + ZOOM_facet_field_name(facets[facet_idx]); + if (native_name && !strcmp(s->value, native_name)) { - int freq; - const char *term = - ZOOM_facet_field_get_term(facets[facet_idx], - term_idx, &freq); - if (term) - add_facet(se, p, term, freq); + size_t term_idx; + size_t term_num = + ZOOM_facet_field_term_count(facets[facet_idx]); + for (term_idx = 0; term_idx < term_num; term_idx++ ) + { + int freq; + const char *term = + ZOOM_facet_field_get_term(facets[facet_idx], + term_idx, &freq); + if (term) + add_facet(se, p, term, freq); + } + break; } - break; } } } @@ -949,29 +951,18 @@ int client_parse_query(struct client *cl, const char *query) struct session *se = client_get_session(cl); struct session_database *sdb = client_get_database(cl); struct ccl_rpn_node *cn; - struct ccl_rpn_node *cn_recordfilter = 0; int cerror, cpos; CCL_bibset ccl_map = prepare_cclmap(cl); const char *sru = session_setting_oneval(sdb, PZ_SRU); const char *pqf_prefix = session_setting_oneval(sdb, PZ_PQF_PREFIX); const char *pqf_strftime = session_setting_oneval(sdb, PZ_PQF_STRFTIME); const char *query_syntax = session_setting_oneval(sdb, PZ_QUERY_SYNTAX); - /* Collected, Mixed, Remote */ - const char *option_recordfilter = session_setting_oneval(sdb, PZ_OPTION_RECORDFILTER); const char *record_filter = session_setting_oneval(sdb, PZ_RECORDFILTER); if (!ccl_map) return -1; yaz_log(YLOG_DEBUG, "query: %s", query); cn = ccl_find_str(ccl_map, query, &cerror, &cpos); - if (strcmp("remote", option_recordfilter) == 0 && record_filter != 0 && record_filter[0] != 0) { - int cerror, cpos; - yaz_log(YLOG_DEBUG, "record_filter: %s", record_filter); - cn_recordfilter = ccl_find_str(ccl_map, record_filter, &cerror, &cpos); - if (!cn_recordfilter) - session_log(se, YLOG_WARN, "Failed to parse CCL record filter '%s' for %s", - record_filter, client_get_database(cl)->database->url); - } ccl_qual_rm(&ccl_map); if (!cn) { @@ -988,12 +979,6 @@ int client_parse_query(struct client *cl, const char *query) wrbuf_puts(se->wrbuf, " "); } - if (cn_recordfilter) { - wrbuf_puts(se->wrbuf, "@and "); - ccl_pquery(se->wrbuf, cn_recordfilter); - wrbuf_puts(se->wrbuf, " "); - } - if (!pqf_strftime || !*pqf_strftime) ccl_pquery(se->wrbuf, cn); else