X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Fyaz%2Fbackend.h;h=1c63474b9227dfdc0ea4a757a55ad2fc11edf539;hb=bd005058ce4832b581a4f81ec5667212e995a49e;hp=27343c243b1a427e4c882adabd0ffcb3ed2636f1;hpb=4d531a1a9131d69c3b6c27fbac42837e22cff61c;p=yaz-moved-to-github.git diff --git a/include/yaz/backend.h b/include/yaz/backend.h index 27343c2..1c63474 100644 --- a/include/yaz/backend.h +++ b/include/yaz/backend.h @@ -23,7 +23,7 @@ * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE * OF THIS SOFTWARE. * - * $Id: backend.h,v 1.17 2003-01-06 08:20:27 adam Exp $ + * $Id: backend.h,v 1.22 2003-12-29 14:54:33 adam Exp $ */ #ifndef BACKEND_H @@ -95,6 +95,7 @@ typedef struct bend_fetch_rr { int errcode; /* 0==success */ char *errstring; /* system error string or NULL */ int surrogate_flag; /* surrogate diagnostic */ + char *schema; /* string record schema input/output */ } bend_fetch_rr; struct scan_entry { @@ -102,6 +103,7 @@ struct scan_entry { int occurrences; /* no of occurrences or -1 if error (see below) */ int errcode; /* Bib-1 diagnostic code; only used when occur.= -1 */ char *errstring; /* Additional string */ + char *display_term; }; typedef enum { @@ -122,6 +124,8 @@ typedef struct bend_scan_rr { int term_position; /* desired index of term in result list/returned */ int num_entries; /* number of entries requested/returned */ + /* scan term entries. The called handler does not have + to allocate this. Size of entries is num_entries (see above) */ struct scan_entry *entries; bend_scan_status status; int errcode; @@ -181,6 +185,14 @@ typedef struct bend_segment_rr { bend_association association; } bend_segment_rr; +typedef struct { + ODR stream; + ODR decode; + ODR print; + char *explain_buf; + char *database; +} bend_explain_rr; + typedef struct bend_initrequest { Z_IdAuthentication *auth; @@ -205,7 +217,7 @@ typedef struct bend_initrequest /* character set and language negotiation - see include/yaz/z-charneg.h */ Z_CharSetandLanguageNegotiation *charneg_request; Z_External *charneg_response; - + int (*bend_explain)(void *handle, bend_explain_rr *rr); } bend_initrequest; typedef struct bend_initresult @@ -259,6 +271,7 @@ typedef struct statserv_options_block char service_dependencies[128]; /* The services we are dependent on */ char service_display_name[128]; /* The service display name */ #endif /* WIN32 */ + struct bend_soap_handler *soap_handlers; } statserv_options_block; YAZ_EXPORT int statserv_main( @@ -271,6 +284,7 @@ YAZ_EXPORT statserv_options_block *statserv_getcontrol(void); YAZ_EXPORT void statserv_setcontrol(statserv_options_block *block); YAZ_EXPORT int check_ip_tcpd(void *cd, const char *addr, int len, int type); + YAZ_END_CDECL #endif