X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fsession.c;h=3fb79b9c9f084ad68886220187b174841defb5a7;hb=512a11133b1ccc4a44d6e971c8a446865136bb15;hp=18c9aeecadbbd13183b241cecdbbb40c3a4922ca;hpb=102d64b6e147d9bca7298abf857febdb41106ee8;p=pazpar2-moved-to-github.git
diff --git a/src/session.c b/src/session.c
index 18c9aee..3fb79b9 100644
--- a/src/session.c
+++ b/src/session.c
@@ -821,8 +821,7 @@ void session_init_databases(struct session *se)
static struct session_database *load_session_database(struct session *se,
char *id)
{
- struct database *db = new_database(id, se->session_nmem);
-
+ struct database *db = new_database_inherit_settings(id, se->session_nmem, se->service->settings);
session_init_databases_fun((void*) se, db);
// New sdb is head of se->databases list
@@ -1015,6 +1014,14 @@ static int cmp_ht(const void *p1, const void *p2)
return h2->hits - h1->hits;
}
+// Compares two hitsbytarget nodes by hitcount
+static int cmp_ht_approx(const void *p1, const void *p2)
+{
+ const struct hitsbytarget *h1 = p1;
+ const struct hitsbytarget *h2 = p2;
+ return h2->approximation - h1->approximation;
+}
+
static int targets_termlist_nb(WRBUF wrbuf, struct session *se, int num,
NMEM nmem, int version)
{
@@ -1022,7 +1029,10 @@ static int targets_termlist_nb(WRBUF wrbuf, struct session *se, int num,
int count, i;
ht = hitsbytarget_nb(se, &count, nmem);
- qsort(ht, count, sizeof(struct hitsbytarget), cmp_ht);
+ if (version >= 2)
+ qsort(ht, count, sizeof(struct hitsbytarget), cmp_ht_approx);
+ else
+ qsort(ht, count, sizeof(struct hitsbytarget), cmp_ht);
for (i = 0; i < count && i < num && ht[i].hits > 0; i++)
{
@@ -1047,7 +1057,7 @@ static int targets_termlist_nb(WRBUF wrbuf, struct session *se, int num,
if (version >= 2) {
// Should not print if we know it isn't a approximation.
wrbuf_printf(wrbuf, "" ODR_INT_PRINTF "\n", ht[i].approximation);
- wrbuf_printf(wrbuf, "%d\n", ht[i].records);
+ wrbuf_printf(wrbuf, "%d\n", ht[i].records - ht[i].filtered);
wrbuf_printf(wrbuf, "%d\n", ht[i].filtered);
}
@@ -1203,7 +1213,8 @@ struct record_cluster **show_range_start(struct session *se,
{
*num = 0;
*total = 0;
- *sumhits = 0;
+ *sumhits = 0;
+ *approx_hits = 0;
recs = 0;
}
else
@@ -1222,6 +1233,7 @@ struct record_cluster **show_range_start(struct session *se,
*total = reclist_get_num_records(se->reclist);
*sumhits = 0;
+ *approx_hits = 0;
for (l = se->clients_active; l; l = l->next) {
*sumhits += client_get_hits(l->client);
*approx_hits += client_get_approximation(l->client);
@@ -1574,6 +1586,7 @@ int ingest_record(struct client *cl, const char *rec,
return ret;
}
+// Skip record on non-zero
static int check_limit_local(struct client *cl,
struct record *record,
int record_no)
@@ -1592,9 +1605,7 @@ static int check_limit_local(struct client *cl,
char **values = 0;
int i, num_v = 0;
- const char *name =
- client_get_facet_limit_local(cl, sdb, &l, nmem_tmp, &num_v,
- &values);
+ const char *name = client_get_facet_limit_local(cl, sdb, &l, nmem_tmp, &num_v, &values);
if (!name)
break;
@@ -1621,10 +1632,10 @@ static int check_limit_local(struct client *cl,
}
else
{
- yaz_log(YLOG_LOG, "cmp: '%s' '%s'",
- rec_md->data.text.disp, values[i]);
+ yaz_log(YLOG_LOG, "cmp: '%s' '%s'", rec_md->data.text.disp, values[i]);
if (!strcmp(rec_md->data.text.disp, values[i]))
{
+ // Value equals, should not be filtered.
break;
}
}
@@ -1636,6 +1647,7 @@ static int check_limit_local(struct client *cl,
i++;
}
}
+ // At end , not match
if (i == num_v)
{
skip_record = 1;