X-Git-Url: http://sru.miketaylor.org.uk/?a=blobdiff_plain;f=include%2Frset.h;h=23e72ecd3a5e68ebb8b1c058624bf0c5e93f0245;hb=64536ef960bf4ed8de62b8db051fa99a181fff1f;hp=172ce37d4f9907ef54dc4a104b5e1502e0e0f23a;hpb=b85319b88e7721ed86bbe4981839c6d2a1afea64;p=idzebra-moved-to-github.git diff --git a/include/rset.h b/include/rset.h index 172ce37..23e72ec 100644 --- a/include/rset.h +++ b/include/rset.h @@ -1,4 +1,4 @@ -/* $Id: rset.h,v 1.20 2004-01-16 18:04:33 heikki Exp $ +/* $Id: rset.h,v 1.30 2004-08-23 12:38:53 heikki Exp $ Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002 Index Data Aps @@ -33,7 +33,6 @@ extern "C" { typedef void *RSFD; typedef struct rset *RSET; -typedef struct rset_term *RSET_TERM; struct rset_control { @@ -43,37 +42,37 @@ struct rset_control void (*f_close)(RSFD rfd); void (*f_delete)(RSET ct); void (*f_rewind)(RSFD rfd); - int (*f_forward)(RSFD rfd, void *buf, const void *untilbuf); - int (*f_count)(RSET ct); - int (*f_read)(RSFD rfd, void *buf, int *term_index); + int (*f_forward)(RSET ct, RSFD rfd, void *buf, + int (*cmpfunc)(const void *p1, const void *p2), + const void *untilbuf); + void (*f_pos)(RSFD rfd, double *current, double *total); + /* returns -1,-1 if pos function not implemented for this type */ + int (*f_read)(RSFD rfd, void *buf); int (*f_write)(RSFD rfd, const void *buf); }; -int rset_default_forward(RSFD rfd, void *buf, const void *untilbuf); +int rset_default_forward(RSET ct, RSFD rfd, void *buf, + int (*cmpfunc)(const void *p1, const void *p2), + const void *untilbuf); +void rset_default_pos(RSFD rfd, double *current, double *total); +/* struct rset_term { char *name; - int nn; + zint nn; char *flags; - int count; + zint count; int type; }; +*/ typedef struct rset { const struct rset_control *control; - int flags; int count; void *buf; - RSET_TERM *rset_terms; - int no_rset_terms; } rset; -RSET_TERM rset_term_create (const char *name, int length, const char *flags, - int type); -void rset_term_destroy (RSET_TERM t); -RSET_TERM rset_term_dup (RSET_TERM t); - #define RSETF_READ 0 #define RSETF_WRITE 1 @@ -93,11 +92,16 @@ RSET rset_dup (RSET rs); /* void rset_rewind(RSET rs); */ #define rset_rewind(rs, rfd) (*(rs)->control->f_rewind)((rfd)) -/* int rset_count(RSET rs); */ -#define rset_count(rs) (*(rs)->control->f_count)(rs) +/* int rset_forward(RSET rs, void *buf, void *untilbuf); */ +#define rset_forward(rs, fd, buf, cmpfunc, untilbuf) \ + (*(rs)->control->f_forward)((rs), (fd), (buf), (cmpfunc), (untilbuf)) + +/* int rset_pos(RSET rs, RSFD fd, double *current, double *total); */ +#define rset_pos(rs,fd,cur,tot) \ + (*(rs)->control->f_pos)( (fd),(cur),(tot)) /* int rset_read(RSET rs, void *buf); */ -#define rset_read(rs, fd, buf, indx) (*(rs)->control->f_read)((fd), (buf), indx) +#define rset_read(rs, fd, buf) (*(rs)->control->f_read)((fd), (buf)) /* int rset_write(RSET rs, const void *buf); */ #define rset_write(rs, fd, buf) (*(rs)->control->f_write)((fd), (buf)) @@ -105,9 +109,6 @@ RSET rset_dup (RSET rs); /* int rset_type (RSET) */ #define rset_type(rs) ((rs)->control->desc) -#define RSET_FLAG_VOLATILE 1 - -#define rset_is_volatile(rs) ((rs)->flags & RSET_FLAG_VOLATILE) #ifdef __cplusplus }