X-Git-Url: http://sru.miketaylor.org.uk/?a=blobdiff_plain;f=include%2Frecctrl.h;h=1b646bdd5307c3cc79abf44f22c3fb1887486d40;hb=e9b33fe049e35d06dfeedb830feea32553d26cee;hp=9fe90e74a55e3007b80209e0c890863113bfcc2a;hpb=50cca4dc248badf5fc15bfd0e24efc02476e5697;p=idzebra-moved-to-github.git diff --git a/include/recctrl.h b/include/recctrl.h index 9fe90e7..1b646bd 100644 --- a/include/recctrl.h +++ b/include/recctrl.h @@ -1,10 +1,23 @@ /* - * Copyright (C) 1994-1998, Index Data I/S + * Copyright (C) 1994-1998, Index Data * All rights reserved. * Sebastian Hammer, Adam Dickmeiss * * $Log: recctrl.h,v $ - * Revision 1.24 1998-03-05 08:38:46 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 @@ -110,7 +123,7 @@ typedef struct { unsigned reg_type; char *string; int length; - int seqno; + int *seqnos; ZebraMaps zebra_maps; } RecWord; @@ -124,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); @@ -154,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 }