X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fsession.h;h=f106c4833859d6a73c2bec67574538535317589e;hb=37482a306afb1c7952bdf304530498b6d068db92;hp=76786f4042d22ad00c2b770199c73ac90b13d124;hpb=efe1343048be89213f3a9933e6b9fbbd481f3d61;p=pazpar2-moved-to-github.git diff --git a/src/session.h b/src/session.h index 76786f4..f106c48 100644 --- a/src/session.h +++ b/src/session.h @@ -71,14 +71,13 @@ struct session_database #define SESSION_WATCH_BYTARGET 4 #define SESSION_WATCH_MAX 4 -#define SESSION_MAX_TERMLISTS 10 - typedef void (*session_watchfun)(void *data); struct named_termlist { char *name; struct termlist *termlist; + struct named_termlist *next; }; struct session_watchentry { @@ -97,8 +96,7 @@ struct session { struct client_list *clients_cached; // Clients in cache NMEM session_nmem; // Nmem for session-permanent storage NMEM nmem; // Nmem for each operation (i.e. search, result set, etc) - int num_termlists; - struct named_termlist termlists[SESSION_MAX_TERMLISTS]; + struct named_termlist *termlists; struct relevance *relevance; struct reclist *reclist; char *mergekey; @@ -186,6 +184,7 @@ int session_is_preferred_clients_ready(struct session *s); void session_apply_setting(struct session *se, const char *dbname, const char *setting, const char *value); const char *session_setting_oneval(struct session_database *db, int offset); +void session_stop(struct session *se); int ingest_record(struct client *cl, const char *rec, int record_no, NMEM nmem); int ingest_xml_record(struct client *cl, xmlDoc *xdoc,