#include "termlists.h"
#include "relevance.h"
+#include "reclists.h"
#include "eventl.h"
#include "config.h"
struct client;
+union data_types {
+ char *text;
+ struct {
+ int min;
+ int max;
+ } number;
+};
+
+struct record_metadata {
+ union data_types data;
+ struct record_metadata *next; // next item of this name
+};
+
struct record {
struct client *client;
- int target_offset;
+ struct record_metadata **metadata; // Array mirrors list of metadata fields in config
+ union data_types **sortkeys; // Array mirrors list of sortkey fields in config
+ struct record *next; // Next in cluster of merged records
+};
+
+struct record_cluster
+{
+ struct record_metadata **metadata; // Array mirrors list of metadata fields in config
+ union data_types **sortkeys;
char *merge_key;
- char *title;
int relevance;
int *term_frequency_vec;
- struct record *next_cluster;
+ int recid; // Set-specific ID for this record
+ struct record *records;
};
struct connection;
struct database {
struct host *host;
char *url;
+ char *name;
char **databases;
int errors;
- struct conf_queryprofile *qprofile;
+ struct zr_explain *explain;
struct conf_retrievalprofile *rprofile;
+ struct setting **settings;
struct database *next;
+ CCL_bibset ccl_map;
};
+struct database_criterion_value {
+ char *value;
+ struct database_criterion_value *next;
+};
+
+struct database_criterion {
+ char *name;
+ struct database_criterion_value *values;
+ struct database_criterion *next;
+};
// Represents a physical, reusable connection to a remote Z39.50 host
struct connection {
int expected_maxrecs;
int total_hits;
int total_records;
+ int total_merged;
};
struct statistics {
};
struct hitsbytarget {
- char id[256];
+ char *id;
+ char *name;
int hits;
int diagnostic;
int records;
};
struct parameters {
+ char proxy_override[128];
+ char listener_override[128];
+ char zproxy_override[128];
+ char settings_path_override[128];
+ struct conf_server *server;
int dump_records;
int timeout; /* operations timeout, in seconds */
char implementationId[128];
int session_timeout;
int toget;
int chunk;
- CCL_bibset ccl_filter;
yaz_marc_t yaz_marc;
ODR odr_out;
ODR odr_in;
};
struct hitsbytarget *hitsbytarget(struct session *s, int *count);
-int select_targets(struct session *se);
+int select_targets(struct session *se, struct database_criterion *crit);
struct session *new_session();
void destroy_session(struct session *s);
int load_targets(struct session *s, const char *fn);
void statistics(struct session *s, struct statistics *stat);
-char *search(struct session *s, char *query);
-struct record **show(struct session *s, int start, int *num, int *total, int *sumhits, NMEM nmem_show);
+char *search(struct session *s, char *query, char *filter);
+struct record_cluster **show(struct session *s, struct reclist_sortparms *sp, int start,
+ int *num, int *total, int *sumhits, NMEM nmem_show);
+struct record_cluster *show_single(struct session *s, int id);
struct termlist_score **termlist(struct session *s, const char *name, int *num);
void session_set_watch(struct session *s, int what, session_watchfun fun, void *data);
+int session_active_clients(struct session *s);
#endif