X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fzoom-p.h;h=d533084a6a98d4bf1028e69f793d49b309865531;hp=27b1c8547f14759da20c5381b6edd9b7c99ef0cf;hb=e2b8bf88befb43e4a189ce3e659c595e5b3af7dc;hpb=aaff6cb1913acdc1cff06d5290e5fecb6a2d53c3 diff --git a/src/zoom-p.h b/src/zoom-p.h index 27b1c85..d533084 100644 --- a/src/zoom-p.h +++ b/src/zoom-p.h @@ -36,9 +36,12 @@ #include #include #include -#if HAVE_LIBMEMCACHED_MEMCACHED_H +#if HAVE_LIBMEMCACHED #include #endif +#if HAVE_HIREDIS +#include +#endif #define SHPTR 1 @@ -107,13 +110,17 @@ struct ZOOM_connection_p { zoom_sru_mode sru_mode; int no_redirects; /* 0 for no redirects. >0 for number of redirects */ yaz_cookies_t cookies; + char *location; int log_details; int log_api; WRBUF saveAPDU_wrbuf; -#if HAVE_LIBMEMCACHED_MEMCACHED_H +#if HAVE_LIBMEMCACHED memcached_st *mc_st; #endif +#if HAVE_HIREDIS + redisContext *redis_c; +#endif }; typedef struct ZOOM_record_cache_p *ZOOM_record_cache; @@ -139,9 +146,10 @@ struct ZOOM_resultset_p { struct WRBUF_shptr *record_wrbuf; #endif ZOOM_resultset next; - ZOOM_facet_field *facets; - int num_facets; - char **facets_names; + char *req_facets; + ZOOM_facet_field *res_facets; + int num_res_facets; + char **facets_names; /* redundant. For ZOOM_resultset_facets_names only */ WRBUF mc_key; int live_set; /* 0=no hit count, 1=cached hit, 2=hits + real set */ }; @@ -276,7 +284,8 @@ int ZOOM_memcached_configure(ZOOM_connection c); void ZOOM_memcached_destroy(ZOOM_connection c); void ZOOM_memcached_resultset(ZOOM_resultset r, ZOOM_query q); void ZOOM_memcached_search(ZOOM_connection c, ZOOM_resultset r); -void ZOOM_memcached_hitcount(ZOOM_connection c, ZOOM_resultset result); +void ZOOM_memcached_hitcount(ZOOM_connection c, ZOOM_resultset result, + Z_OtherInformation *oi, const char *precision); void ZOOM_memcached_add(ZOOM_resultset r, Z_NamePlusRecord *npr, int pos, const char *syntax, const char *elementSetName, @@ -286,6 +295,14 @@ Z_NamePlusRecord *ZOOM_memcached_lookup(ZOOM_resultset r, int pos, const char *syntax, const char *elementSetName, const char *schema); +ZOOM_record ZOOM_record_cache_lookup_i(ZOOM_resultset r, int pos, + const char *syntax, + const char *elementSetName, + const char *schema); +void ZOOM_handle_facet_result(ZOOM_connection c, ZOOM_resultset r, + Z_OtherInformation *o); +void ZOOM_handle_search_result(ZOOM_connection c, ZOOM_resultset resultset, + Z_OtherInformation *o); /* * Local variables: