X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=include%2Frecctrl.h;h=9b3165506dc167d6dbcad527ea24707d435db72c;hb=172e2b480354c7e44a50c654f09b8ab35f245f45;hp=45ae761999f2c24a051937269eaf7c77d9258bcc;hpb=6a2a73ff2c6ccc7d1ed83423d0ad7a95ea9e35b7;p=idzebra-moved-to-github.git diff --git a/include/recctrl.h b/include/recctrl.h index 45ae761..9b31655 100644 --- a/include/recctrl.h +++ b/include/recctrl.h @@ -4,7 +4,19 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: recctrl.h,v $ - * Revision 1.11 1995-12-04 14:20:54 adam + * 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 @@ -53,6 +65,7 @@ typedef struct { int attrUse; enum { Word_String, + Word_Phrase, Word_Numeric } which; union { @@ -64,8 +77,11 @@ typedef struct { /* Extract record control */ struct recExtractCtrl { - int fd; /* File descriptor and read function */ - int (*readf)(int fd, char *buf, size_t count); + 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); @@ -74,13 +90,14 @@ struct recExtractCtrl { /* 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 */ - Z_RecordComposition *comp; /* formatting instructions */ - int localno; /* local id of record */ - int score; /* score 0-1000 or -1 if none */ + 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; /* response */ @@ -93,10 +110,10 @@ struct recRetrieveCtrl { 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, char *subType);