iolayer modifications:
[imager.git] / iolayer.h
index ac49727..2d815fd 100644 (file)
--- a/iolayer.h
+++ b/iolayer.h
 #define IO_TEMP_SEEK 1<<1L
 
 
-typedef union { int i; void *p; } iorp;
-
 typedef enum { FDSEEK, FDNOSEEK, BUFFER, CBSEEK, CBNOSEEK, BUFCHAIN } io_type;
 
 #ifdef _MSC_VER
 typedef int ssize_t;
 #endif
 
-struct io_glue;
+typedef struct i_io_glue_t i_io_glue_t;
+
+/* compatibility for now */
+typedef i_io_glue_t io_glue;
 
 /* Callbacks we give out */
 
-typedef ssize_t(*readp) (struct io_glue *ig, void *buf, size_t count);
-typedef ssize_t(*writep)(struct io_glue *ig, const void *buf, size_t count);
-typedef off_t  (*seekp) (struct io_glue *ig, off_t offset, int whence);
-typedef void   (*closep)(struct io_glue *ig);
-typedef ssize_t(*sizep) (struct io_glue *ig);
+typedef ssize_t(*readp) (io_glue *ig, void *buf, size_t count);
+typedef ssize_t(*writep)(io_glue *ig, const void *buf, size_t count);
+typedef off_t  (*seekp) (io_glue *ig, off_t offset, int whence);
+typedef void   (*closep)(io_glue *ig);
+typedef ssize_t(*sizep) (io_glue *ig);
 
 typedef void   (*closebufp)(void *p);
 
@@ -57,49 +58,6 @@ typedef ssize_t(*sizel) (void *p);
 extern char *io_type_names[];
 
 
-typedef struct io_blink {
-  char buf[BBSIZ];
-  /* size_t cnt; */
-  size_t len;                  /* How large is this buffer = BBZIS for now */
-  struct io_blink *next;
-  struct io_blink *prev;
-} io_blink;
-
-
-/* Structures that describe callback interfaces */
-
-typedef struct {
-  off_t offset;
-  off_t cpos;
-} io_ex_rseek;
-
-
-typedef struct {
-  off_t offset;
-  off_t cpos;
-  io_blink *head;
-  io_blink *tail;
-  io_blink *cp;
-} io_ex_fseek;
-
-
-typedef struct {
-  off_t offset;                        /* Offset of the source - not used */
-  off_t length;                        /* Total length of chain in bytes */
-  io_blink *head;              /* Start of chain */
-  io_blink *tail;              /* End of chain */
-  off_t tfill;                 /* End of stream in last link */
-  io_blink *cp;                        /* Current element of list */
-  off_t cpos;                  /* Offset within the current */
-  off_t gpos;                  /* Global position in stream */
-} io_ex_bchain;
-
-typedef struct {
-  off_t offset;                        /* Offset of the source - not used */
-  off_t cpos;                  /* Offset within the current */
-} io_ex_buffer;
-
-
 
 /* Structures to describe data sources */
 
@@ -135,7 +93,7 @@ typedef union {
   io_cb                cb;
 } io_obj;
 
-typedef struct io_glue {
+struct i_io_glue_t {
   io_obj       source;
   int          flags;          /* Flags */
   void         *exdata;        /* Pair specific data */
@@ -144,11 +102,8 @@ typedef struct io_glue {
   seekp                seekcb;
   closep       closecb;
   sizep                sizecb;
-} io_glue;
+};
 
-void io_obj_setp_buffer(io_obj *io, char *p, size_t len, closebufp closecb, void *closedata);
-void io_obj_setp_cb      (io_obj *io, void *p, readl readcb, writel writecb, seekl seekcb);
-void io_obj_setp_cb2     (io_obj *io, void *p, readl readcb, writel writecb, seekl seekcb, closel closecb, destroyl destroycb);
 void io_glue_commit_types(io_glue *ig);
 void io_glue_gettypes    (io_glue *ig, int reqmeth);
 
@@ -161,4 +116,6 @@ io_glue *io_new_cb(void *p, readl readcb, writel writecb, seekl seekcb, closel c
 size_t   io_slurp(io_glue *ig, unsigned char **c);
 void     io_glue_DESTROY(io_glue *ig);
 
+#define i_io_type(ig) ((ig)->source.ig_type)
+
 #endif /* _IOLAYER_H_ */