X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fzoom-p.h;h=51125b513e42a0adfc72a9d69b7843bf07475637;hp=f227f134feff69fe071cb0460e03c7077a5a7e41;hb=7c0b1d48b8192d2fa79f942d37c29d30a99c2fb6;hpb=ad4b64e5b3ab9ebc4b2e8184a3782b10962f7d3d diff --git a/src/zoom-p.h b/src/zoom-p.h index f227f13..51125b5 100644 --- a/src/zoom-p.h +++ b/src/zoom-p.h @@ -35,6 +35,10 @@ #include #include #include +#include + +#define SHPTR 1 +#define ZOOM_RESULT_LISTS 0 typedef struct ZOOM_Event_p *ZOOM_Event; @@ -60,6 +64,10 @@ typedef struct ZOOM_task_p *ZOOM_task; #define STATE_CONNECTING 1 #define STATE_ESTABLISHED 2 +#if ZOOM_RESULT_LISTS +typedef struct ZOOM_resultsets_p *ZOOM_resultsets; +#endif + struct ZOOM_connection_p { enum oid_proto proto; COMSTACK cs; @@ -99,13 +107,24 @@ struct ZOOM_connection_p { ZOOM_task tasks; ZOOM_options options; +#if ZOOM_RESULT_LISTS + ZOOM_resultsets resultsets; +#else ZOOM_resultset resultsets; +#endif ZOOM_Event m_queue_front; ZOOM_Event m_queue_back; zoom_sru_mode sru_mode; int no_redirects; /* 0 for no redirects. >0 for number of redirects */ }; +#if ZOOM_RESULT_LISTS +struct ZOOM_resultsets_p { + ZOOM_resultset resultset; + ZOOM_resultsets next; +}; +#endif + struct ZOOM_options_entry { char *name; char *value; @@ -140,28 +159,50 @@ struct ZOOM_resultset_p { ZOOM_record_cache record_hash[RECORD_HASH_SIZE]; ZOOM_options options; ZOOM_connection connection; - ZOOM_resultset next; char **databaseNames; int num_databaseNames; + YAZ_MUTEX mutex; +#if SHPTR + struct WRBUF_shptr *record_wrbuf; +#endif +#if ZOOM_RESULT_LISTS +#else + ZOOM_resultset next; +#endif + ZOOM_facet_field *facets; + int num_facets; + char **facets_names; }; struct ZOOM_record_p { ODR odr; +#if SHPTR + struct WRBUF_shptr *record_wrbuf; +#else WRBUF wrbuf; +#endif + Z_NamePlusRecord *npr; const char *schema; -#if YAZ_HAVE_XML2 - xmlChar *xml_mem; - int xml_size; -#endif - const char *diag_uri; const char *diag_message; const char *diag_details; const char *diag_set; }; +struct facet_term_p { + char *term; + int frequency; +}; + +struct ZOOM_facet_field_p { + char *facet_name; + int num_terms; + struct facet_term_p *facet_terms; +}; + + struct ZOOM_record_cache_p { struct ZOOM_record_p rec; char *elementSetName;