X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fzoom-p.h;h=79f2f445882c40c394d017fd51d8f519300bb96c;hp=f443594d9b307c09001954e054f6b705b61531aa;hb=4d1450cc691292cef5bcfdd41cefc030e4dabbf6;hpb=dd016baf50d8cd02a1a32d1fd10b5544cae6ff96 diff --git a/src/zoom-p.h b/src/zoom-p.h index f443594..79f2f44 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 @@ -80,6 +83,7 @@ struct ZOOM_connection_p { int len_out; char *proxy; char *tproxy; + int proxy_mode; char *charset; char *lang; char *cookie_out; @@ -107,13 +111,19 @@ 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 + int expire_search; + int expire_record; }; typedef struct ZOOM_record_cache_p *ZOOM_record_cache; @@ -139,9 +149,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 */ }; @@ -236,6 +247,7 @@ zoom_ret ZOOM_connection_Z3950_send_init(ZOOM_connection c); ZOOM_task ZOOM_connection_add_task(ZOOM_connection c, int which); void ZOOM_connection_remove_task(ZOOM_connection c); +void ZOOM_connection_remove_tasks(ZOOM_connection c); int ZOOM_test_reconnect(ZOOM_connection c); ZOOM_record ZOOM_record_cache_lookup(ZOOM_resultset r, int pos, @@ -252,6 +264,7 @@ Z_Query *ZOOM_query_get_Z_Query(ZOOM_query s); Z_SortKeySpecList *ZOOM_query_get_sortspec(ZOOM_query s); const char *ZOOM_query_get_query_string(ZOOM_query s); const char *ZOOM_query_get_sru11(ZOOM_query s); +void ZOOM_query_get_hash(ZOOM_query s, WRBUF w); int ZOOM_uri_to_code(const char *uri); @@ -275,7 +288,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, @@ -285,6 +299,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: