X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Fidzebra%2Frecctrl.h;h=36002458a141aa785b583474064a859b3782c6b6;hb=4358b098c7cb6adc62f6ada9f513555cee2f921c;hp=0a39e703e53277666eff5e0034f7b669398b8136;hpb=0f3b8bcc6fe2e3beeec7c834d9a64dca48a4f1b7;p=idzebra-moved-to-github.git diff --git a/include/idzebra/recctrl.h b/include/idzebra/recctrl.h index 0a39e70..3600245 100644 --- a/include/idzebra/recctrl.h +++ b/include/idzebra/recctrl.h @@ -1,5 +1,5 @@ -/* $Id: recctrl.h,v 1.10 2005-04-28 08:20:39 adam Exp $ - Copyright (C) 1995-2005 +/* $Id: recctrl.h,v 1.18 2006-05-05 09:12:21 adam Exp $ + Copyright (C) 1995-2006 Index Data ApS This file is part of the Zebra server. @@ -20,8 +20,8 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ -#ifndef RECCTRL_H -#define RECCTRL_H +#ifndef IDZEBRA_RECCTRL_H +#define IDZEBRA_RECCTRL_H #include #include @@ -29,17 +29,28 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA #include #include #include +#include #include YAZ_BEGIN_CDECL +#if NATTR +#define ZEBRA_XPATH_ELM_BEGIN "_XPATH_BEGIN" +#define ZEBRA_XPATH_ELM_END "_XPATH_END" +#define ZEBRA_XPATH_CDATA "_XPATH_CDATA" +#define ZEBRA_XPATH_ATTR "_XPATH_ATTR" +#endif + /* single word entity */ typedef struct { +#if NATTR +#else int attrSet; int attrUse; - unsigned reg_type; - char *attrStr; - char *term_buf; +#endif + unsigned index_type; + const char *index_name; + const char *term_buf; int term_len; zint seqno; zint record_id; @@ -65,6 +76,7 @@ struct recExtractCtrl { int flagShowRecords; int seqno[256]; char match_criteria[256]; + int staticrank; void (*schemaAdd)(struct recExtractCtrl *p, Odr_oid *oid); data1_handle dh; void *handle; @@ -84,9 +96,12 @@ struct recRetrieveCtrl { char *encoding; /* preferred character encoding */ zint localno; /* local id of record */ int score; /* score 0-1000 or -1 if none */ + int staticrank; /* static rank >= 0, 0 if none */ int recordSize; /* size of record in bytes */ char *fname; /* name of file (or NULL if internal) */ data1_handle dh; + zebra_snippets *hit_snippet; + zebra_snippets *doc_snippet; /* response */ oid_value output_format; @@ -103,7 +118,7 @@ struct recType int version; char *name; /* Name of record type */ void *(*init)(Res res, RecType recType); /* Init function - called once */ - void (*config)(void *clientData, Res res, const char *args); /* Config */ + ZEBRA_RES (*config)(void *clientData, Res res, const char *args); /* Config */ void (*destroy)(void *clientData); /* Destroy function */ int (*extract)(void *clientData, struct recExtractCtrl *ctrl); /* Extract proc */ @@ -123,6 +138,14 @@ YAZ_EXPORT RecTypeClass recTypeClass_create (Res res, NMEM nmem); YAZ_EXPORT +void recTypeClass_load_modules(RecTypeClass *rts, NMEM nmem, + const char *module_path); + +YAZ_EXPORT +RecTypeClass recTypeClass_add_modules(Res res, NMEM nmem, + const char *module_path); + +YAZ_EXPORT void recTypeClass_destroy(RecTypeClass rtc); YAZ_EXPORT