X-Git-Url: http://lists.indexdata.com/cgi-bin?a=blobdiff_plain;f=src%2Fsession.c;h=18ba514247f283f755d777028aca6fa24a827cae;hb=1a3f3cfb2f6aeb743716924d9081d6dce981b49f;hp=64920dab0ced4c9c4dcc62852bced78d2f3b9d81;hpb=bed60313a0ad69f2dc66ea48d7855bdafb293936;p=pazpar2-moved-to-github.git diff --git a/src/session.c b/src/session.c index 64920da..18ba514 100644 --- a/src/session.c +++ b/src/session.c @@ -622,34 +622,64 @@ int session_is_preferred_clients_ready(struct session *s) return res == 0; } -void session_sort(struct session *se, const char *field, int increasing) +static void session_clear_set(struct session *se, + const char *sort_field, int increasing) +{ + reclist_destroy(se->reclist); + se->reclist = 0; + if (nmem_total(se->nmem)) + session_log(se, YLOG_DEBUG, "NMEN operation usage %zd", + nmem_total(se->nmem)); + nmem_reset(se->nmem); + se->total_records = se->total_merged = 0; + se->num_termlists = 0; + + /* reset list of sorted results and clear to relevance search */ + se->sorted_results = nmem_malloc(se->nmem, sizeof(*se->sorted_results)); + se->sorted_results->field = nmem_strdup(se->nmem, sort_field); + se->sorted_results->increasing = increasing; + se->sorted_results->next = 0; + + se->reclist = reclist_create(se->nmem); +} + +void session_sort(struct session *se, const char *field, int increasing, + int clear_set) { struct session_sorted_results *sr; struct client_list *l; session_enter(se); - /* see if we already have sorted for this critieria */ - for (sr = se->sorted_results; sr; sr = sr->next) + yaz_log(YLOG_LOG, "session_sort field=%s", field); + if (clear_set) { - if (!strcmp(field, sr->field) && increasing == sr->increasing) - break; + session_clear_set(se, field, increasing); } - if (sr) + else { - session_log(se, YLOG_DEBUG, "search_sort: field=%s increasing=%d already fetched", - field, increasing); - session_leave(se); - return; + /* see if we already have sorted for this critieria */ + for (sr = se->sorted_results; sr; sr = sr->next) + { + if (!strcmp(field, sr->field) && increasing == sr->increasing) + break; + } + if (sr) + { + session_log(se, YLOG_DEBUG, "search_sort: field=%s increasing=%d already fetched", + field, increasing); + session_leave(se); + return; + } + session_log(se, YLOG_DEBUG, "search_sort: field=%s increasing=%d must fetch", + field, increasing); + sr = nmem_malloc(se->nmem, sizeof(*sr)); + sr->field = nmem_strdup(se->nmem, field); + sr->increasing = increasing; + sr->next = se->sorted_results; + se->sorted_results = sr; } - session_log(se, YLOG_DEBUG, "search_sort: field=%s increasing=%d must fetch", - field, increasing); - sr = nmem_malloc(se->nmem, sizeof(*sr)); - sr->field = nmem_strdup(se->nmem, field); - sr->increasing = increasing; - sr->next = se->sorted_results; - se->sorted_results = sr; - + for (l = se->clients_active; l; l = l->next) { struct client *cl = l->client; @@ -688,29 +718,16 @@ enum pazpar2_error_code session_search(struct session *se, session_reset_active_clients(se, 0); session_enter(se); - reclist_destroy(se->reclist); - se->reclist = 0; se->settings_modified = 0; + session_clear_set(se, sort_field, increasing); relevance_destroy(&se->relevance); - if (nmem_total(se->nmem)) - session_log(se, YLOG_DEBUG, "NMEN operation usage %zd", nmem_total(se->nmem)); - nmem_reset(se->nmem); - se->total_records = se->total_merged = 0; - se->num_termlists = 0; - /* reset list of sorted results and clear to relevance search */ - se->sorted_results = nmem_malloc(se->nmem, sizeof(*se->sorted_results)); - se->sorted_results->field = nmem_strdup(se->nmem, sort_field); - se->sorted_results->increasing = increasing; - se->sorted_results->next = 0; - live_channels = select_targets(se, filter); if (!live_channels) { session_leave(se); return PAZPAR2_NO_TARGETS; } - se->reclist = reclist_create(se->nmem); yaz_gettimeofday(&tval); @@ -1795,8 +1812,8 @@ static int ingest_to_cluster(struct client *cl, struct record_metadata *rec_md = 0; int md_field_id = -1; int sk_field_id = -1; - int rank = 0; - xmlChar *rank_str = 0; + const char *rank; + xmlChar *xml_rank; type = xmlGetProp(n, (xmlChar *) "type"); value = xmlNodeListGetString(xdoc, n->children, 1); @@ -1811,15 +1828,6 @@ static int ingest_to_cluster(struct client *cl, ser_md = &service->metadata[md_field_id]; - rank_str = xmlGetProp(n, (xmlChar *) "rank"); - if (rank_str) - { - rank = atoi((const char *) rank_str); - xmlFree(rank_str); - } - else - rank = ser_md->rank; - if (ser_md->sortkey_offset >= 0) { sk_field_id = ser_md->sortkey_offset; @@ -1832,6 +1840,9 @@ static int ingest_to_cluster(struct client *cl, if (!rec_md) continue; + xml_rank = xmlGetProp(n, (xmlChar *) "rank"); + rank = xml_rank ? (const char *) xml_rank : ser_md->rank; + wheretoput = &cluster->metadata[md_field_id]; // and polulate with data: @@ -1916,7 +1927,6 @@ static int ingest_to_cluster(struct client *cl, } } - // ranking of _all_ fields enabled ... if (rank) { @@ -1944,6 +1954,8 @@ static int ingest_to_cluster(struct client *cl, } // cleaning up + if (xml_rank) + xmlFree(xml_rank); xmlFree(type); xmlFree(value); type = value = 0;