X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Frecctrl.h;h=9b3165506dc167d6dbcad527ea24707d435db72c;hb=276a6af7f9d8ef0ef2ffc3f25e639be148ca2c7c;hp=bafc3e850c1f0a0772fa8b11f71430ea126bb126;hpb=9f702af8d75a4bdd837abbef43a22d0d1af5f614;p=idzebra-moved-to-github.git diff --git a/include/recctrl.h b/include/recctrl.h index bafc3e8..9b31655 100644 --- a/include/recctrl.h +++ b/include/recctrl.h @@ -4,7 +4,15 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: recctrl.h,v $ - * Revision 1.12 1996-01-17 15:01:25 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'. * @@ -57,6 +65,7 @@ typedef struct { int attrUse; enum { Word_String, + Word_Phrase, Word_Numeric } which; union { @@ -68,8 +77,11 @@ typedef struct { /* Extract record control */ struct recExtractCtrl { - void *fh; /* File handle and read function */ + 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); @@ -78,13 +90,14 @@ struct recExtractCtrl { /* Retrieve record control */ struct recRetrieveCtrl { /* Input parameters ... */ - ODR odr; /* ODR used to create response */ + ODR odr; /* ODR used to create response */ void *fh; /* File descriptor and read function */ int (*readf)(void *fh, 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 */ + 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 */ @@ -97,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);