X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fsession.h;h=af73f03d2104523e5eaaded1a75d417f056c7107;hb=2fe342540fa6a4e674a7e86d7b11651557cfbcc9;hp=45fdbb3a1631b6d89668b316da61f4e3730a1753;hpb=d2db0f728572c6abdcd7c3d5ff3d9f59705af208;p=pazpar2-moved-to-github.git diff --git a/src/session.h b/src/session.h index 45fdbb3..af73f03 100644 --- a/src/session.h +++ b/src/session.h @@ -1,5 +1,5 @@ /* This file is part of Pazpar2. - Copyright (C) 2006-2012 Index Data + Copyright (C) 2006-2013 Index Data Pazpar2 is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free @@ -25,6 +25,7 @@ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA #include #include +#include "facet_limit.h" #include "termlists.h" #include "reclists.h" #include "http.h" @@ -110,6 +111,7 @@ struct session { struct named_termlist termlists[SESSION_MAX_TERMLISTS]; struct relevance *relevance; struct reclist *reclist; + char *mergekey; struct session_watchentry watchlist[SESSION_WATCH_MAX + 1]; int total_records; int total_merged; @@ -119,7 +121,8 @@ struct session { YAZ_MUTEX session_mutex; unsigned session_id; int settings_modified; - struct session_sorted_results *sorted_results; + facet_limits_t facet_limits; + struct reclist_sortparms *sorted_results; }; struct statistics { @@ -140,6 +143,7 @@ struct hitsbytarget { Odr_int hits; Odr_int approximation; int diagnostic; + const char *message; const char *addinfo; int records; int filtered; @@ -156,7 +160,8 @@ void session_destroy(struct session *s); void session_init_databases(struct session *s); void statistics(struct session *s, struct statistics *stat); -void session_sort(struct session *se, const char *field, int increasing, int clear_set); +void session_sort(struct session *se, struct reclist_sortparms *sp, + const char *mergekey); enum pazpar2_error_code session_search(struct session *s, const char *query, const char *startrecs, @@ -167,7 +172,12 @@ enum pazpar2_error_code session_search(struct session *s, const char *query, struct record_cluster **show_range_start(struct session *s, struct reclist_sortparms *sp, int start, - int *num, int *total, Odr_int *sumhits, Odr_int *approximation); + int *num, int *total, + Odr_int *sumhits, + Odr_int *approximation, + void (*ready)(void *data), + struct http_channel *chan); +int session_fetch_more(struct session *s); void show_range_stop(struct session *s, struct record_cluster **recs); struct record_cluster *show_single_start(struct session *s, const char *id, @@ -184,6 +194,7 @@ int ingest_record(struct client *cl, const char *rec, int record_no, NMEM nmem); void session_alert_watch(struct session *s, int what); void add_facet(struct session *s, const char *type, const char *value, int count); +int session_check_cluster_limit(struct session *se, struct record_cluster *rec); void perform_termlist(struct http_channel *c, struct session *se, const char *name, int num, int version); void session_log(struct session *s, int level, const char *fmt, ...) @@ -193,13 +204,6 @@ void session_log(struct session *s, int level, const char *fmt, ...) ; #endif -struct session_sorted_results { - const char *field; - int increasing; - int position; - struct session_sorted_results *next; -}; - /* * Local variables: * c-basic-offset: 4