X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Frecctrl.h;h=9b3165506dc167d6dbcad527ea24707d435db72c;hb=7ed12b6cc4a492d6062dd56bb1ebc49c9bc75b4a;hp=717a61df9776bcaeb61a598d40f8f456d11a17e6;hpb=a91b23986dd5ad1cbbc05522297b5db770b11c5d;p=idzebra-moved-to-github.git diff --git a/include/recctrl.h b/include/recctrl.h index 717a61d..9b31655 100644 --- a/include/recctrl.h +++ b/include/recctrl.h @@ -4,7 +4,38 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: recctrl.h,v $ - * Revision 1.5 1995-10-02 14:55:52 quinn + * Revision 1.14 1996-05-09 07:28:49 quinn + * Work towards phrases and multiple registers + * + * Revision 1.13 1996/05/01 13:44:05 adam + * Added seek function to the recExtractCtrl and recRetrieveCtrl control + * structures. Added end-of-file indicator function and start offset to + * recExtractCtrl. + * + * Revision 1.12 1996/01/17 15:01:25 adam + * Prototype changed for reader functions in extract/retrieve. File + * is identified by 'void *' instead of 'int'. + * + * Revision 1.11 1995/12/04 14:20:54 adam + * Extra arg to recType_byName. + * + * Revision 1.10 1995/10/16 14:03:06 quinn + * Changes to support element set names and espec1 + * + * Revision 1.9 1995/10/06 14:37:53 adam + * New result set method: r_score. + * Local no (sysno) and score is transferred to retrieveCtrl. + * + * Revision 1.8 1995/10/02 15:43:35 adam + * Extract uses file descriptors instead of FILE pointers. + * + * Revision 1.7 1995/10/02 15:18:09 adam + * Minor changes. + * + * Revision 1.6 1995/10/02 15:05:26 quinn + * Added a few fields. + * + * Revision 1.5 1995/10/02 14:55:52 quinn * *** empty log message *** * * Revision 1.4 1995/09/27 16:17:29 adam @@ -24,6 +55,7 @@ #ifndef RECCTRL_H #define RECCTRL_H +#include #include #include @@ -33,6 +65,7 @@ typedef struct { int attrUse; enum { Word_String, + Word_Phrase, Word_Numeric } which; union { @@ -44,61 +77,45 @@ typedef struct { /* Extract record control */ struct recExtractCtrl { -<<<<<<< recctrl.h - int inf; - char *subType; - void (*init)(RecWord *p); - void (*add)(const RecWord *p); -||||||| 1.4 - FILE *inf; - char *subType; - void (*init)(RecWord *p); - void (*add)(const RecWord *p); -======= - /* input parameters ... */ - FILE *inf; /* Extract from this file */ - char *subType; /* Sub type - may be NULL */ - void (*init)(RecWord *p); /* Init of word spec */ - void (*add)(const RecWord *p); /* Addition of a single word */ ->>>>>>> /tmp/T4a00136 + void *fh; /* File handle and read function */ + int (*readf)(void *fh, char *buf, size_t count); + off_t (*seekf)(void *fh, off_t offset); /* seek function */ + void (*endf)(void *fh, off_t offset); /* end of record position */ + off_t offset; /* start offset */ + char *subType; + void (*init)(RecWord *p); + void (*add)(const RecWord *p); }; /* Retrieve record control */ struct recRetrieveCtrl { /* Input parameters ... */ - ODR odr; /* ODR used to create response */ - int fd; /* File descriptor and read function */ - int (*readf)(int fd, char *buf, size_t count); - oid_value input_format; /* Preferred record syntax */ + ODR odr; /* ODR used to create response */ + void *fh; /* File descriptor and read function */ + int (*readf)(void *fh, char *buf, size_t count); + off_t (*seekf)(void *fh, off_t offset); + oid_value input_format; /* Preferred record syntax */ + Z_RecordComposition *comp; /* formatting instructions */ + int localno; /* local id of record */ + int score; /* score 0-1000 or -1 if none */ + char *subType; -<<<<<<< recctrl.h /* response */ oid_value output_format; void *rec_buf; size_t rec_len; - int diagnostic; + int diagnostic; char *message; -||||||| 1.4 - /* response */ - oid_value output_format; - void *rec_buf; - size_t rec_len; -======= - /* output parameters ... */ - oid_value output_format; /* Record syntax of returned record */ - void *rec_buf; /* Record buffer */ - size_t rec_len; /* Length of record */ ->>>>>>> /tmp/T4a00136 }; typedef 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 */ + 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; -RecType recType_byName (const char *name); +RecType recType_byName (const char *name, char *subType); #endif