]> git.draconx.ca Git - upkg.git/commitdiff
Implement file positioning functions for upkg exports.
authorNick Bowler <nbowler@draconx.ca>
Mon, 8 Jun 2009 19:04:56 +0000 (15:04 -0400)
committerNick Bowler <nbowler@draconx.ca>
Mon, 8 Jun 2009 19:27:56 +0000 (15:27 -0400)
src/libupkg.c
src/upkg.h

index 0dc2adeca76aab05336acddff6e655197c272044..64b00d27818db40a3d6628bb8b621059d2e57f1b 100644 (file)
@@ -415,6 +415,37 @@ void upkg_export_close(struct upkg_file *f)
        free(f);
 }
 
+long upkg_export_tell(struct upkg_file *f)
+{
+       return f->offset;
+}
+
+int upkg_export_seek(struct upkg_file *f, long offset, int whence)
+{
+       int rc = EOF;
+
+       switch (whence) {
+       case SEEK_CUR:
+               offset = f->offset + offset;
+       case SEEK_SET:
+               if (offset < 0 || offset > f->len)
+                       return EOF;
+               rc = fseek(f->pkg->priv->f, f->base + offset, SEEK_SET);
+               break;
+       case SEEK_END:
+               offset = -offset;
+               if (offset < 0 || offset > f->len)
+                       return EOF;
+               offset = f->len - offset;
+               rc = fseek(f->pkg->priv->f, f->base + offset, SEEK_SET);
+               break;
+       }
+
+       if (rc == 0)
+               f->pkg->priv->last_file = f;
+       return rc;
+}
+
 size_t upkg_export_read(struct upkg_file *f, void *buf, size_t n)
 {
        size_t want = MIN(n, f->len - f->offset);
index ab2dacbb261bf02b41908d5f1a7cfce1e0cf2240..34124453b8f986d29cfdb1d06f2a6e775caac110 100644 (file)
@@ -63,7 +63,9 @@ const char *upkg_get_name(struct upkg *pkg, unsigned long idx);
 
 struct upkg_file *upkg_export_open(struct upkg *pkg, unsigned long idx);
 size_t upkg_export_read(struct upkg_file *f, void *buf, size_t n);
-void upkg_export_close(struct upkg_file *f);
+int    upkg_export_seek(struct upkg_file *f, long offset, int whence);
+long   upkg_export_tell(struct upkg_file *f);
+void   upkg_export_close(struct upkg_file *f);
 
 size_t upkg_decode_index(long *val, unsigned char *bytes, size_t n);