{
type = Metadata_sortkey_relevance;
}
+ else if (!strcmp(parm, "relevance_h"))
+ {
+ type = Metadata_sortkey_relevance_h;
+ }
else if (!strcmp(parm, "position"))
{
type = Metadata_sortkey_position;
case Metadata_sortkey_relevance:
res = r2->relevance_score - r1->relevance_score;
break;
+ case Metadata_sortkey_relevance_h:
+ res = r2->relevance_score - r1->relevance_score;
+ break;
case Metadata_sortkey_string:
s1 = ut1 ? ut1->text.sort : "";
s2 = ut2 ? ut2->text.sort : "";
// We found a matching record. Merge them
if (!strcmp(merge_key, (*p)->record->merge_key))
{
- struct record_cluster *existing = (*p)->record;
- struct record *re = existing->records;
+ struct record **re;
- for (; re; re = re->next)
+ cluster = (*p)->record;
+ for (re = &cluster->records; *re; re = &(*re)->next)
{
- if (re->client == record->client &&
- record_compare(record, re, service))
+ if ((*re)->client == record->client &&
+ record_compare(record, *re, service))
{
yaz_mutex_leave(l->mutex);
return 0;
}
}
- record->next = existing->records;
- existing->records = record;
- cluster = existing;
+ *re = record;
+ record->next = 0;
break;
}
}
/* attach to hash list */
*p = new;
l->num_records++;
+ l->sorted_list = l->sorted_ptr = 0;
}
yaz_mutex_leave(l->mutex);
return cluster;