X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Frecctrl.h;h=1b646bdd5307c3cc79abf44f22c3fb1887486d40;hb=e9b33fe049e35d06dfeedb830feea32553d26cee;hp=9000fdaf7222ce5324c81361fd509f7d6c64d725;hpb=5c693d36af8be6f6642257160b3c6441d2e2d762;p=idzebra-moved-to-github.git diff --git a/include/recctrl.h b/include/recctrl.h index 9000fda..1b646bd 100644 --- a/include/recctrl.h +++ b/include/recctrl.h @@ -1,10 +1,26 @@ /* - * Copyright (C) 1994-1997, Index Data I/S + * Copyright (C) 1994-1998, Index Data * All rights reserved. * Sebastian Hammer, Adam Dickmeiss * * $Log: recctrl.h,v $ - * Revision 1.23 1998-02-10 12:03:05 adam + * Revision 1.28 1999-03-02 16:15:42 quinn + * Added "tagsysno" and "tagrank" directives to zebra.cfg. + * + * Revision 1.27 1998/10/16 08:14:28 adam + * Updated record control system. + * + * Revision 1.26 1998/05/20 10:12:12 adam + * Implemented automatic EXPLAIN database maintenance. + * Modified Zebra to work with ASN.1 compiled version of YAZ. + * + * Revision 1.25 1998/03/11 11:19:04 adam + * Changed the way sequence numbers are generated. + * + * Revision 1.24 1998/03/05 08:38:46 adam + * New member recordSize in recRetrieveCtrl. + * + * Revision 1.23 1998/02/10 12:03:05 adam * Implemented Sort. * * Revision 1.22 1997/10/27 14:33:04 adam @@ -100,7 +116,6 @@ extern "C" { #endif - /* single word entity */ typedef struct { int attrSet; @@ -108,7 +123,7 @@ typedef struct { unsigned reg_type; char *string; int length; - int seqno; + int *seqnos; ZebraMaps zebra_maps; } RecWord; @@ -122,15 +137,18 @@ struct recExtractCtrl { off_t offset; /* start offset */ char *subType; void (*init)(struct recExtractCtrl *p, RecWord *w); - void (*add)(RecWord *p); + void (*addWord)(RecWord *p); ZebraMaps zebra_maps; int flagShowRecords; + int seqno[256]; + void (*addSchema)(struct recExtractCtrl *p, Odr_oid *oid); data1_handle dh; }; /* Retrieve record control */ struct recRetrieveCtrl { /* Input parameters ... */ + Res res; /* Resource pool */ ODR odr; /* ODR used to create response */ void *fh; /* File descriptor and read function */ int (*readf)(void *fh, char *buf, size_t count); @@ -140,6 +158,7 @@ struct recRetrieveCtrl { Z_RecordComposition *comp; /* formatting instructions */ int localno; /* local id of record */ int score; /* score 0-1000 or -1 if none */ + int recordSize; /* size of record in bytes */ char *subType; data1_handle dh; @@ -151,15 +170,27 @@ struct recRetrieveCtrl { char *message; }; -typedef struct recType +typedef struct recType *RecType; + +struct recType { - char *name; /* Name of record type */ - void (*init)(void); /* Init function - called once */ - int (*extract)(struct recExtractCtrl *ctrl); /* Extract proc */ - int (*retrieve)(struct recRetrieveCtrl *ctrl); /* Retrieve proc */ -} *RecType; + char *name; /* Name of record type */ + void (*init)(RecType recType); /* Init function - called once */ + void (*destroy)(RecType recType); /* Destroy function */ + int (*extract)(struct recExtractCtrl *ctrl); /* Extract proc */ + int (*retrieve)(struct recRetrieveCtrl *ctrl); /* Retrieve proc */ + void *clientData; /* data handle */ +}; + +typedef struct recTypes *RecTypes; + +RecTypes recTypes_init (data1_handle dh); +void recTypes_destroy (RecTypes recTypes); +void recTypes_default_handlers (RecTypes recTypes); + +RecType recType_byName (RecTypes rts, const char *name, char *subType); -RecType recType_byName (const char *name, char *subType); +int grs_extract_tree(struct recExtractCtrl *p, data1_node *n); #ifdef __cplusplus }