X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Fyaz%2Fsrw.h;h=df27631da4f5460693c3826a65b947a13c8ca7e0;hb=f64aa61c61bf8bf851d7b66a5fc137669dc77452;hp=99dfd5960ab812aa540dbcff09ce7d8a661feb23;hpb=a834d92665e792c011e86d5603968ab31237575a;p=yaz-moved-to-github.git diff --git a/include/yaz/srw.h b/include/yaz/srw.h index 99dfd59..df27631 100644 --- a/include/yaz/srw.h +++ b/include/yaz/srw.h @@ -1,14 +1,21 @@ /* - * Copyright (c) 2002-2003, Index Data. + * Copyright (c) 2002-2004, Index Data. * See the file LICENSE for details. * - * $Id: srw.h,v 1.7 2003-03-23 20:27:16 adam Exp $ + * $Id: srw.h,v 1.18 2005-01-08 01:20:18 adam Exp $ + */ +/** + * \file srw.h + * \brief Header for SRW/SRU */ #ifndef YAZ_SRW_H #define YAZ_SRW_H #include +#include + +YAZ_BEGIN_CDECL typedef struct { char *recordSchema; @@ -21,8 +28,9 @@ typedef struct { } Z_SRW_record; typedef struct { - int *code; + char *uri; char *details; + char *message; } Z_SRW_diagnostic; typedef struct { @@ -47,10 +55,13 @@ typedef struct { char *xSortKeys; } sort; int *startRecord; - int *maximumRecords; + int *maximumRecords; char *recordSchema; char *recordPacking; + char *recordXPath; char *database; + char *stylesheet; + int *resultSetTTL; } Z_SRW_searchRetrieveRequest; typedef struct { @@ -67,19 +78,49 @@ typedef struct { } Z_SRW_searchRetrieveResponse; typedef struct { - int dummy; + char *recordPacking; + char *database; + char *stylesheet; } Z_SRW_explainRequest; typedef struct { - int explainPacking; - char *explainData_buf; - int explainData_len; + Z_SRW_record record; + Z_SRW_diagnostic *diagnostics; + int num_diagnostics; } Z_SRW_explainResponse; +typedef struct { + int query_type; + union { + char *cql; + char *xcql; + char *pqf; + } scanClause; + int *responsePosition; + int *maximumTerms; + char *stylesheet; + char *database; +} Z_SRW_scanRequest; + +typedef struct { + char *value; + int *numberOfRecords; + char *displayTerm; +} Z_SRW_scanTerm; + +typedef struct { + Z_SRW_scanTerm *terms; + int num_terms; + Z_SRW_diagnostic *diagnostics; + int num_diagnostics; +} Z_SRW_scanResponse; + #define Z_SRW_searchRetrieve_request 1 #define Z_SRW_searchRetrieve_response 2 #define Z_SRW_explain_request 3 #define Z_SRW_explain_response 4 +#define Z_SRW_scan_request 5 +#define Z_SRW_scan_response 6 typedef struct { int which; @@ -88,7 +129,10 @@ typedef struct { Z_SRW_searchRetrieveResponse *response; Z_SRW_explainRequest *explain_request; Z_SRW_explainResponse *explain_response; + Z_SRW_scanRequest *scan_request; + Z_SRW_scanResponse *scan_response; } u; + char *srw_version; } Z_SRW_PDU; YAZ_EXPORT int yaz_srw_codec(ODR o, void * pptr, @@ -102,5 +146,22 @@ YAZ_EXPORT int yaz_diag_bib1_to_srw (int bib1_code); YAZ_EXPORT int yaz_diag_srw_to_bib1(int srw_code); +YAZ_EXPORT char *yaz_uri_val(const char *path, const char *name, ODR o); +YAZ_EXPORT void yaz_uri_val_int(const char *path, const char *name, + ODR o, int **intp); +YAZ_EXPORT int yaz_srw_decode(Z_HTTP_Request *hreq, Z_SRW_PDU **srw_pdu, + Z_SOAP **soap_package, ODR decode, char **charset); +YAZ_EXPORT int yaz_sru_decode(Z_HTTP_Request *hreq, Z_SRW_PDU **srw_pdu, + Z_SOAP **soap_package, ODR decode, + char **charset, + Z_SRW_diagnostic **, int *num_diagnostic); + +YAZ_EXPORT void yaz_add_srw_diagnostic(ODR o, Z_SRW_diagnostic **d, + int *num, int code, + const char *addinfo); + +YAZ_EXPORT void yaz_mk_std_diagnostic(ODR o, Z_SRW_diagnostic *d, + int code, const char *details); +YAZ_END_CDECL #endif