]> git.imager.perl.org - imager.git/commitdiff
iolayer modifications:
authorTony Cook <tony@develop=help.com>
Wed, 15 Mar 2006 12:08:47 +0000 (12:08 +0000)
committerTony Cook <tony@develop=help.com>
Wed, 15 Mar 2006 12:08:47 +0000 (12:08 +0000)
- move private types and functions into iolayers.c

- make each layer "new" function do the initialization that
io_commit_types() was doing.

iolayer.c
iolayer.h

index d4eb55c32d7dce65f41f7fce272dbdde9e696659..9ddfb55bf50a4a7991c95a653b6e62dc1e1e3906 100644 (file)
--- a/iolayer.c
+++ b/iolayer.c
 
 char *io_type_names[] = { "FDSEEK", "FDNOSEEK", "BUFFER", "CBSEEK", "CBNOSEEK", "BUFCHAIN" };
 
+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;
+
+static void io_obj_setp_buffer(io_obj *io, char *p, size_t len, closebufp closecb, void *closedata);
+static void io_obj_setp_cb2     (io_obj *io, void *p, readl readcb, writel writecb, seekl seekcb, closel closecb, destroyl destroycb);
+
 
 /*
 =head1 NAME
@@ -753,8 +798,9 @@ Sets an io_object for reading from a buffer source
 =cut
 */
 
-void
-io_obj_setp_buffer(io_obj *io, char *p, size_t len, closebufp closecb, void *closedata) {
+static void
+io_obj_setp_buffer(io_obj *io, char *p, size_t len, closebufp closecb, 
+                  void *closedata) {
   io->buffer.type      = BUFFER;
   io->buffer.data      = p;
   io->buffer.len       = len;
@@ -763,23 +809,6 @@ io_obj_setp_buffer(io_obj *io, char *p, size_t len, closebufp closecb, void *clo
 }
 
 
-/*
-=item io_obj_setp_buchain(io)
-
-Sets an io_object for reading/writing from a buffer source
-
-   io  - io object that describes a source
-   p   - pointer to buffer
-   len - length of buffer
-
-=cut
-*/
-
-void
-io_obj_setp_bufchain(io_obj *io) {
-  io->type = BUFCHAIN;
-}
-
 
 /*
 =item io_obj_setp_cb2(io, p, readcb, writecb, seekcb, closecb, destroycb)
@@ -797,7 +826,7 @@ Sets an io_object for reading from a source that uses callbacks
 =cut
 */
 
-void
+static void
 io_obj_setp_cb2(io_obj *io, void *p, readl readcb, writel writecb, seekl seekcb, closel closecb, destroyl destroycb) {
   io->cb.type      = CBSEEK;
   io->cb.p         = p;
@@ -808,18 +837,10 @@ io_obj_setp_cb2(io_obj *io, void *p, readl readcb, writel writecb, seekl seekcb,
   io->cb.destroycb = destroycb;
 }
 
-void
-io_obj_setp_cb(io_obj *io, void *p, readl readcb, writel writecb, 
-               seekl seekcb) {
-  io_obj_setp_cb2(io, p, readcb, writecb, seekcb, NULL, NULL);
-}
-
 /*
 =item io_glue_commit_types(ig)
 
-Creates buffers and initializes structures to read with the chosen interface.
-
-   ig - io_glue object
+This is now effectively a no-op.
 
 =cut
 */
@@ -836,66 +857,6 @@ io_glue_commit_types(io_glue *ig) {
     return;
   }
 
-  switch (inn) {
-  case BUFCHAIN:
-    {
-      io_ex_bchain *ieb = mymalloc(sizeof(io_ex_bchain));
-      
-      ieb->offset = 0;
-      ieb->length = 0;
-      ieb->cpos   = 0;
-      ieb->gpos   = 0;
-      ieb->tfill  = 0;
-
-      ieb->head   = io_blink_new();
-      ieb->cp     = ieb->head;
-      ieb->tail   = ieb->head;
-
-      ig->exdata  = ieb;
-      ig->readcb  = bufchain_read;
-      ig->writecb = bufchain_write;
-      ig->seekcb  = bufchain_seek;
-      ig->closecb = bufchain_close;
-    }
-    break;
-  case CBSEEK:
-    {
-      io_ex_rseek *ier = mymalloc(sizeof(io_ex_rseek));
-      
-      ier->offset = 0;
-      ier->cpos   = 0;
-      
-      ig->exdata  = ier;
-      ig->readcb  = realseek_read;
-      ig->writecb = realseek_write;
-      ig->seekcb  = realseek_seek;
-      ig->closecb = realseek_close;
-    }
-    break;
-  case BUFFER:
-    {
-      io_ex_buffer *ieb = mymalloc(sizeof(io_ex_buffer));
-      ieb->offset = 0;
-      ieb->cpos   = 0;
-
-      ig->exdata  = ieb;
-      ig->readcb  = buffer_read;
-      ig->writecb = buffer_write;
-      ig->seekcb  = buffer_seek;
-      ig->closecb = buffer_close;
-    }
-    break;
-  case FDSEEK:
-    {
-      ig->exdata  = NULL;
-      ig->readcb  = fd_read;
-      ig->writecb = fd_write;
-      ig->seekcb  = fd_seek;
-      ig->closecb = fd_close;
-      ig->sizecb  = fd_size;
-      break;
-    }
-  }
   ig->flags |= 0x01; /* indicate source has been setup already */
 }
 
@@ -939,16 +900,32 @@ be written to and read from later (like a pseudo file).
 io_glue *
 io_new_bufchain() {
   io_glue *ig;
+  io_ex_bchain *ieb = mymalloc(sizeof(io_ex_bchain));
+
   mm_log((1, "io_new_bufchain()\n"));
+
   ig = mymalloc(sizeof(io_glue));
   memset(ig, 0, sizeof(*ig));
-  io_obj_setp_bufchain(&ig->source);
-  return ig;
-}
-
-
+  ig->source.type = BUFCHAIN;
 
+  ieb->offset = 0;
+  ieb->length = 0;
+  ieb->cpos   = 0;
+  ieb->gpos   = 0;
+  ieb->tfill  = 0;
+  
+  ieb->head   = io_blink_new();
+  ieb->cp     = ieb->head;
+  ieb->tail   = ieb->head;
+  
+  ig->exdata  = ieb;
+  ig->readcb  = bufchain_read;
+  ig->writecb = bufchain_write;
+  ig->seekcb  = bufchain_seek;
+  ig->closecb = bufchain_close;
 
+  return ig;
+}
 
 /*
 =item io_new_buffer(data, len)
@@ -965,11 +942,24 @@ from specified buffer.  Note that the buffer is not copied.
 io_glue *
 io_new_buffer(char *data, size_t len, closebufp closecb, void *closedata) {
   io_glue *ig;
+  io_ex_buffer *ieb = mymalloc(sizeof(io_ex_buffer));
+  
   mm_log((1, "io_new_buffer(data %p, len %d, closecb %p, closedata %p)\n", data, len, closecb, closedata));
+
   ig = mymalloc(sizeof(io_glue));
   memset(ig, 0, sizeof(*ig));
   io_obj_setp_buffer(&ig->source, data, len, closecb, closedata);
   ig->flags = 0;
+
+  ieb->offset = 0;
+  ieb->cpos   = 0;
+  
+  ig->exdata  = ieb;
+  ig->readcb  = buffer_read;
+  ig->writecb = buffer_write;
+  ig->seekcb  = buffer_seek;
+  ig->closecb = buffer_close;
+
   return ig;
 }
 
@@ -989,19 +979,22 @@ data from the io_glue callbacks hasn't been done yet.
 io_glue *
 io_new_fd(int fd) {
   io_glue *ig;
+
   mm_log((1, "io_new_fd(fd %d)\n", fd));
+
   ig = mymalloc(sizeof(io_glue));
   memset(ig, 0, sizeof(*ig));
   ig->source.type = FDSEEK;
   ig->source.fdseek.fd = fd;
   ig->flags = 0;
-#if 0
-#ifdef _MSC_VER
-  io_obj_setp_cb(&ig->source, (void*)fd, _read, _write, _lseek);
-#else
-  io_obj_setp_cb(&ig->source, (void*)fd, read, write, lseek);
-#endif
-#endif
+
+  ig->exdata  = NULL;
+  ig->readcb  = fd_read;
+  ig->writecb = fd_write;
+  ig->seekcb  = fd_seek;
+  ig->closecb = fd_close;
+  ig->sizecb  = fd_size;
+      
   mm_log((1, "(%p) <- io_new_fd\n", ig));
   return ig;
 }
@@ -1009,6 +1002,7 @@ io_new_fd(int fd) {
 io_glue *io_new_cb(void *p, readl readcb, writel writecb, seekl seekcb, 
                    closel closecb, destroyl destroycb) {
   io_glue *ig;
+  io_ex_rseek *ier = mymalloc(sizeof(io_ex_rseek));
 
   mm_log((1, "io_new_cb(p %p, readcb %p, writecb %p, seekcb %p, closecb %p, "
           "destroycb %p)\n", p, readcb, writecb, seekcb, closecb, destroycb));
@@ -1017,6 +1011,15 @@ io_glue *io_new_cb(void *p, readl readcb, writel writecb, seekl seekcb,
   io_obj_setp_cb2(&ig->source, p, readcb, writecb, seekcb, closecb, destroycb);
   mm_log((1, "(%p) <- io_new_cb\n", ig));
 
+  ier->offset = 0;
+  ier->cpos   = 0;
+  
+  ig->exdata  = ier;
+  ig->readcb  = realseek_read;
+  ig->writecb = realseek_write;
+  ig->seekcb  = realseek_seek;
+  ig->closecb = realseek_close;
+
   return ig;
 }
 
index ac49727d40639bed77bc02865e7359427574d4ec..2d815fd7d4ee847f69373929decdd2849713f359 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_ */