Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/amachronic/microtar.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAidan MacDonald <amachronic@protonmail.com>2021-11-04 18:56:27 +0300
committerAidan MacDonald <amachronic@protonmail.com>2021-11-04 19:03:37 +0300
commit2a6bf50265c94138b7144243b5ba0e57a9afcbf4 (patch)
tree6ff38287ec5abbcca933f9c5aa6858c5076f1059
parent637e5f5ecbfdce9e5707297bfd900e9ca924aec4 (diff)
Restyle the source code
This is frivolous, but I really don't like the current style.
-rw-r--r--src/microtar-stdio.c86
-rw-r--r--src/microtar.c606
-rw-r--r--src/microtar.h144
3 files changed, 429 insertions, 407 deletions
diff --git a/src/microtar-stdio.c b/src/microtar-stdio.c
index 493f34b..87ae4f7 100644
--- a/src/microtar-stdio.c
+++ b/src/microtar-stdio.c
@@ -21,61 +21,65 @@
* IN THE SOFTWARE.
*/
+#include "microtar.h"
#include <stdio.h>
#include <string.h>
-#include "microtar.h"
-
-static int file_write(mtar_t *tar, const void *data, unsigned size) {
- unsigned res = fwrite(data, 1, size, tar->stream);
- return (res == size) ? MTAR_ESUCCESS : MTAR_EWRITEFAIL;
+static int file_write(mtar_t* tar, const void* data, unsigned size)
+{
+ unsigned res = fwrite(data, 1, size, tar->stream);
+ return (res == size) ? MTAR_ESUCCESS : MTAR_EWRITEFAIL;
}
-static int file_read(mtar_t *tar, void *data, unsigned size) {
- unsigned res = fread(data, 1, size, tar->stream);
- return (res == size) ? MTAR_ESUCCESS : MTAR_EREADFAIL;
+static int file_read(mtar_t* tar, void* data, unsigned size)
+{
+ unsigned res = fread(data, 1, size, tar->stream);
+ return (res == size) ? MTAR_ESUCCESS : MTAR_EREADFAIL;
}
-static int file_seek(mtar_t *tar, unsigned offset) {
- int res = fseek(tar->stream, offset, SEEK_SET);
- return (res == 0) ? MTAR_ESUCCESS : MTAR_ESEEKFAIL;
+static int file_seek(mtar_t* tar, unsigned offset)
+{
+ int res = fseek(tar->stream, offset, SEEK_SET);
+ return (res == 0) ? MTAR_ESUCCESS : MTAR_ESEEKFAIL;
}
-static int file_close(mtar_t *tar) {
- fclose(tar->stream);
- return MTAR_ESUCCESS;
+static int file_close(mtar_t* tar)
+{
+ fclose(tar->stream);
+ return MTAR_ESUCCESS;
}
+int mtar_open(mtar_t* tar, const char* filename, const char* mode)
+{
+ int err;
+ mtar_header_t h;
+
+ /* Init tar struct and functions */
+ memset(tar, 0, sizeof(*tar));
+ tar->write = file_write;
+ tar->read = file_read;
+ tar->seek = file_seek;
+ tar->close = file_close;
-int mtar_open(mtar_t *tar, const char *filename, const char *mode) {
- int err;
- mtar_header_t h;
+ /* Assure mode is always binary */
+ if(strchr(mode, 'r')) mode = "rb";
+ if(strchr(mode, 'w')) mode = "wb";
+ if(strchr(mode, 'a')) mode = "ab";
- /* Init tar struct and functions */
- memset(tar, 0, sizeof(*tar));
- tar->write = file_write;
- tar->read = file_read;
- tar->seek = file_seek;
- tar->close = file_close;
+ /* Open file */
+ tar->stream = fopen(filename, mode);
+ if(!tar->stream)
+ return MTAR_EOPENFAIL;
- /* Assure mode is always binary */
- if ( strchr(mode, 'r') ) mode = "rb";
- if ( strchr(mode, 'w') ) mode = "wb";
- if ( strchr(mode, 'a') ) mode = "ab";
- /* Open file */
- tar->stream = fopen(filename, mode);
- if (!tar->stream) {
- return MTAR_EOPENFAIL;
- }
- /* Read first header to check it is valid if mode is `r` */
- if (*mode == 'r') {
- err = mtar_read_header(tar, &h);
- if (err != MTAR_ESUCCESS) {
- mtar_close(tar);
- return err;
+ /* Read first header to check it is valid if mode is `r` */
+ if(*mode == 'r') {
+ err = mtar_read_header(tar, &h);
+ if(err != MTAR_ESUCCESS) {
+ mtar_close(tar);
+ return err;
+ }
}
- }
- /* Return ok */
- return MTAR_ESUCCESS;
+ /* Return ok */
+ return MTAR_ESUCCESS;
}
diff --git a/src/microtar.c b/src/microtar.c
index 10a623c..81e1031 100644
--- a/src/microtar.c
+++ b/src/microtar.c
@@ -21,369 +21,391 @@
* IN THE SOFTWARE.
*/
+#include "microtar.h"
#include <stdlib.h>
#include <stddef.h>
#include <limits.h>
#include <string.h>
-#include "microtar.h"
+static int parse_octal(const char* str, size_t len, unsigned* ret)
+{
+ unsigned n = 0;
+ while(len-- > 0 && *str != 0) {
+ if(*str < '0' || *str > '9')
+ return MTAR_EOVERFLOW;
-static int parse_octal(const char* str, size_t len, unsigned* ret) {
- unsigned n = 0;
- while(len-- > 0 && *str != 0) {
- if(*str < '0' || *str > '9')
- return MTAR_EOVERFLOW;
+ if(n > UINT_MAX/8)
+ return MTAR_EOVERFLOW;
+ else
+ n *= 8;
- if(n > UINT_MAX/8)
- return MTAR_EOVERFLOW;
- else
- n *= 8;
+ char r = *str++ - '0';
- char r = *str++ - '0';
- if(n > UINT_MAX - r)
- return MTAR_EOVERFLOW;
- else
- n += r;
- }
+ if(n > UINT_MAX - r)
+ return MTAR_EOVERFLOW;
+ else
+ n += r;
+ }
- *ret = n;
- return MTAR_ESUCCESS;
+ *ret = n;
+ return MTAR_ESUCCESS;
}
+static int print_octal(char* str, size_t len, unsigned value)
+{
+ /* move backwards over the output string */
+ char* ptr = str + len - 1;
+ *ptr = 0;
-static int print_octal(char* str, size_t len, unsigned value) {
- /* move backwards over the output string */
- char* ptr = str + len - 1;
- *ptr = 0;
+ /* output the significant digits */
+ while(value > 0) {
+ if(ptr == str)
+ return MTAR_EOVERFLOW;
- /* output the significant digits */
- while(value > 0) {
- if(ptr == str)
- return MTAR_EOVERFLOW;
+ --ptr;
+ *ptr = '0' + (value % 8);
+ value /= 8;
+ }
- --ptr;
- *ptr = '0' + (value % 8);
- value /= 8;
- }
+ /* pad the remainder of the field with zeros */
+ while(ptr != str) {
+ --ptr;
+ *ptr = '0';
+ }
- /* pad the remainder of the field with zeros */
- while(ptr != str) {
- --ptr;
- *ptr = '0';
- }
+ return MTAR_ESUCCESS;
+}
- return MTAR_ESUCCESS;
+static unsigned round_up(unsigned n, unsigned incr)
+{
+ return n + (incr - n % incr) % incr;
}
+static unsigned checksum(const mtar_raw_header_t* rh)
+{
+ unsigned i;
+ unsigned char* p = (unsigned char*) rh;
+ unsigned res = 256;
-static unsigned round_up(unsigned n, unsigned incr) {
- return n + (incr - n % incr) % incr;
-}
+ for(i = 0; i < offsetof(mtar_raw_header_t, checksum); i++)
+ res += p[i];
+ for(i = offsetof(mtar_raw_header_t, type); i < sizeof(*rh); i++)
+ res += p[i];
-static unsigned checksum(const mtar_raw_header_t* rh) {
- unsigned i;
- unsigned char *p = (unsigned char*) rh;
- unsigned res = 256;
- for (i = 0; i < offsetof(mtar_raw_header_t, checksum); i++) {
- res += p[i];
- }
- for (i = offsetof(mtar_raw_header_t, type); i < sizeof(*rh); i++) {
- res += p[i];
- }
- return res;
+ return res;
}
-
-static int tread(mtar_t *tar, void *data, unsigned size) {
- int err = tar->read(tar, data, size);
- tar->pos += size;
- return err;
+static int tread(mtar_t* tar, void* data, unsigned size)
+{
+ int err = tar->read(tar, data, size);
+ tar->pos += size;
+ return err;
}
-static int twrite(mtar_t *tar, const void *data, unsigned size) {
- int err = tar->write(tar, data, size);
- tar->pos += size;
- return err;
+static int twrite(mtar_t* tar, const void* data, unsigned size)
+{
+ int err = tar->write(tar, data, size);
+ tar->pos += size;
+ return err;
}
+static int write_null_bytes(mtar_t* tar, int n)
+{
+ int i, err;
+ char nul = '\0';
+
+ for(i = 0; i < n; i++) {
+ err = twrite(tar, &nul, 1);
-static int write_null_bytes(mtar_t *tar, int n) {
- int i, err;
- char nul = '\0';
- for (i = 0; i < n; i++) {
- err = twrite(tar, &nul, 1);
- if (err) {
- return err;
+ if(err)
+ return err;
}
- }
- return MTAR_ESUCCESS;
+
+ return MTAR_ESUCCESS;
}
+static int raw_to_header(mtar_header_t* h, const mtar_raw_header_t* rh)
+{
+ unsigned chksum1, chksum2;
+ int rc;
+
+ /* If the checksum starts with a null byte we assume the record is NULL */
+ if(*rh->checksum == '\0')
+ return MTAR_ENULLRECORD;
+
+ /* Build and compare checksum */
+ chksum1 = checksum(rh);
+ if((rc = parse_octal(rh->checksum, sizeof(rh->checksum), &chksum2)))
+ return rc;
+ if(chksum1 != chksum2)
+ return MTAR_EBADCHKSUM;
+
+ /* Load raw header into header */
+ if((rc = parse_octal(rh->mode, sizeof(rh->mode), &h->mode)))
+ return rc;
+ if((rc = parse_octal(rh->owner, sizeof(rh->owner), &h->owner)))
+ return rc;
+ if((rc = parse_octal(rh->group, sizeof(rh->group), &h->group)))
+ return rc;
+ if((rc = parse_octal(rh->size, sizeof(rh->size), &h->size)))
+ return rc;
+ if((rc = parse_octal(rh->mtime, sizeof(rh->mtime), &h->mtime)))
+ return rc;
+
+ h->type = rh->type;
+
+ memcpy(h->name, rh->name, sizeof(rh->name));
+ h->name[sizeof(h->name) - 1] = 0;
+
+ memcpy(h->linkname, rh->linkname, sizeof(rh->linkname));
+ h->linkname[sizeof(h->linkname) - 1] = 0;
+
+ return MTAR_ESUCCESS;
+}
-static int raw_to_header(mtar_header_t *h, const mtar_raw_header_t *rh) {
- unsigned chksum1, chksum2;
- int rc;
-
- /* If the checksum starts with a null byte we assume the record is NULL */
- if (*rh->checksum == '\0') {
- return MTAR_ENULLRECORD;
- }
-
- /* Build and compare checksum */
- chksum1 = checksum(rh);
- if((rc = parse_octal(rh->checksum, sizeof(rh->checksum), &chksum2)))
- return rc;
- if (chksum1 != chksum2) {
- return MTAR_EBADCHKSUM;
- }
-
- /* Load raw header into header */
- if((rc = parse_octal(rh->mode, sizeof(rh->mode), &h->mode)))
- return rc;
- if((rc = parse_octal(rh->owner, sizeof(rh->owner), &h->owner)))
- return rc;
- if((rc = parse_octal(rh->group, sizeof(rh->group), &h->group)))
- return rc;
- if((rc = parse_octal(rh->size, sizeof(rh->size), &h->size)))
- return rc;
- if((rc = parse_octal(rh->mtime, sizeof(rh->mtime), &h->mtime)))
- return rc;
-
- h->type = rh->type;
-
- memcpy(h->name, rh->name, sizeof(rh->name));
- h->name[sizeof(h->name) - 1] = 0;
-
- memcpy(h->linkname, rh->linkname, sizeof(rh->linkname));
- h->linkname[sizeof(h->linkname) - 1] = 0;
-
- return MTAR_ESUCCESS;
+static int header_to_raw(mtar_raw_header_t* rh, const mtar_header_t* h)
+{
+ unsigned chksum;
+ int rc;
+
+ /* Load header into raw header */
+ memset(rh, 0, sizeof(*rh));
+
+ if((rc = print_octal(rh->mode, sizeof(rh->mode), h->mode)))
+ return rc;
+ if((rc = print_octal(rh->owner, sizeof(rh->owner), h->owner)))
+ return rc;
+ if((rc = print_octal(rh->group, sizeof(rh->group), h->group)))
+ return rc;
+ if((rc = print_octal(rh->size, sizeof(rh->size), h->size)))
+ return rc;
+ if((rc = print_octal(rh->mtime, sizeof(rh->mtime), h->mtime)))
+ return rc;
+
+ rh->type = h->type ? h->type : MTAR_TREG;
+ strncpy(rh->name, h->name, sizeof(rh->name));
+ strncpy(rh->linkname, h->linkname, sizeof(rh->linkname));
+
+ /* Calculate and write checksum */
+ chksum = checksum(rh);
+ if((rc = print_octal(rh->checksum, 7, chksum)))
+ return rc;
+
+ rh->checksum[7] = ' ';
+
+ return MTAR_ESUCCESS;
}
+const char* mtar_strerror(int err)
+{
+ switch(err) {
+ case MTAR_ESUCCESS: return "success";
+ case MTAR_EFAILURE: return "failure";
+ case MTAR_EOPENFAIL: return "could not open";
+ case MTAR_EREADFAIL: return "could not read";
+ case MTAR_EWRITEFAIL: return "could not write";
+ case MTAR_ESEEKFAIL: return "could not seek";
+ case MTAR_EBADCHKSUM: return "bad checksum";
+ case MTAR_ENULLRECORD: return "null record";
+ case MTAR_ENOTFOUND: return "file not found";
+ case MTAR_EOVERFLOW: return "overflow";
+ default: return "unknown error";
+ }
+}
-static int header_to_raw(mtar_raw_header_t *rh, const mtar_header_t *h) {
- unsigned chksum;
- int rc;
-
- /* Load header into raw header */
- memset(rh, 0, sizeof(*rh));
- if((rc = print_octal(rh->mode, sizeof(rh->mode), h->mode)))
- return rc;
- if((rc = print_octal(rh->owner, sizeof(rh->owner), h->owner)))
- return rc;
- if((rc = print_octal(rh->group, sizeof(rh->group), h->group)))
- return rc;
- if((rc = print_octal(rh->size, sizeof(rh->size), h->size)))
- return rc;
- if((rc = print_octal(rh->mtime, sizeof(rh->mtime), h->mtime)))
- return rc;
- rh->type = h->type ? h->type : MTAR_TREG;
- strncpy(rh->name, h->name, sizeof(rh->name));
- strncpy(rh->linkname, h->linkname, sizeof(rh->linkname));
-
- /* Calculate and write checksum */
- chksum = checksum(rh);
- if((rc = print_octal(rh->checksum, 7, chksum)))
- return rc;
- rh->checksum[7] = ' ';
-
- return MTAR_ESUCCESS;
+int mtar_close(mtar_t* tar)
+{
+ return tar->close(tar);
}
+int mtar_seek(mtar_t* tar, unsigned pos)
+{
+ int err = tar->seek(tar, pos);
+ tar->pos = pos;
+ return err;
+}
-const char* mtar_strerror(int err) {
- switch (err) {
- case MTAR_ESUCCESS : return "success";
- case MTAR_EFAILURE : return "failure";
- case MTAR_EOPENFAIL : return "could not open";
- case MTAR_EREADFAIL : return "could not read";
- case MTAR_EWRITEFAIL : return "could not write";
- case MTAR_ESEEKFAIL : return "could not seek";
- case MTAR_EBADCHKSUM : return "bad checksum";
- case MTAR_ENULLRECORD : return "null record";
- case MTAR_ENOTFOUND : return "file not found";
- case MTAR_EOVERFLOW : return "overflow";
- }
- return "unknown error";
+int mtar_rewind(mtar_t* tar)
+{
+ tar->remaining_data = 0;
+ tar->last_header = 0;
+ return mtar_seek(tar, 0);
}
+int mtar_next(mtar_t* tar)
+{
+ int err, n;
-int mtar_close(mtar_t *tar) {
- return tar->close(tar);
+ /* Load header */
+ err = mtar_read_header(tar, &tar->header);
+ if(err)
+ return err;
+
+ /* Seek to next record */
+ n = round_up(tar->header.size, 512) + sizeof(mtar_raw_header_t);
+ return mtar_seek(tar, tar->pos + n);
}
+int mtar_find(mtar_t* tar, const char* name, mtar_header_t* h)
+{
+ int err;
+
+ /* Start at beginning */
+ err = mtar_rewind(tar);
+ if(err)
+ return err;
+
+ /* Iterate all files until we hit an error or find the file */
+ while((err = mtar_read_header(tar, &tar->header)) == MTAR_ESUCCESS) {
+ if(!strcmp(tar->header.name, name)) {
+ if(h)
+ *h = tar->header;
+ return MTAR_ESUCCESS;
+ }
+
+ err = mtar_next(tar);
+ if(err)
+ return err;
+ }
+
+ /* Return error */
+ if(err == MTAR_ENULLRECORD)
+ err = MTAR_ENOTFOUND;
-int mtar_seek(mtar_t *tar, unsigned pos) {
- int err = tar->seek(tar, pos);
- tar->pos = pos;
- return err;
+ return err;
}
+int mtar_read_header(mtar_t* tar, mtar_header_t* h)
+{
+ int err;
-int mtar_rewind(mtar_t *tar) {
- tar->remaining_data = 0;
- tar->last_header = 0;
- return mtar_seek(tar, 0);
-}
+ /* Save header position */
+ tar->last_header = tar->pos;
+ /* Read raw header */
+ err = tread(tar, &tar->raw_header, sizeof(tar->raw_header));
+ if(err)
+ return err;
-int mtar_next(mtar_t *tar) {
- int err, n;
- /* Load header */
- err = mtar_read_header(tar, &tar->header);
- if (err) {
- return err;
- }
- /* Seek to next record */
- n = round_up(tar->header.size, 512) + sizeof(mtar_raw_header_t);
- return mtar_seek(tar, tar->pos + n);
-}
+ /* Seek back to start of header */
+ err = mtar_seek(tar, tar->last_header);
+ if(err)
+ return err;
+ /* Load raw header into header struct and return */
+ return raw_to_header(h, &tar->raw_header);
+}
-int mtar_find(mtar_t *tar, const char *name, mtar_header_t *h) {
- int err;
- /* Start at beginning */
- err = mtar_rewind(tar);
- if (err) {
- return err;
- }
- /* Iterate all files until we hit an error or find the file */
- while ( (err = mtar_read_header(tar, &tar->header)) == MTAR_ESUCCESS ) {
- if ( !strcmp(tar->header.name, name) ) {
- if (h) {
- *h = tar->header;
- }
- return MTAR_ESUCCESS;
- }
- err = mtar_next(tar);
- if (err) {
- return err;
+int mtar_read_data(mtar_t* tar, void* ptr, unsigned size)
+{
+ int err;
+
+ /* If we have no remaining data then this is the first read,
+ * we get the size, set the remaining data and seek to the
+ * beginning of the data */
+ if(tar->remaining_data == 0) {
+ /* Read header */
+ err = mtar_read_header(tar, &tar->header);
+ if(err)
+ return err;
+
+ /* Seek past header and init remaining data */
+ err = mtar_seek(tar, tar->pos + sizeof(mtar_raw_header_t));
+ if(err)
+ return err;
+
+ tar->remaining_data = tar->header.size;
}
- }
- /* Return error */
- if (err == MTAR_ENULLRECORD) {
- err = MTAR_ENOTFOUND;
- }
- return err;
-}
+ /* Ensure caller does not read too much */
+ if(size > tar->remaining_data)
+ return MTAR_EOVERFLOW;
-int mtar_read_header(mtar_t *tar, mtar_header_t *h) {
- int err;
- /* Save header position */
- tar->last_header = tar->pos;
- /* Read raw header */
- err = tread(tar, &tar->raw_header, sizeof(tar->raw_header));
- if (err) {
- return err;
- }
- /* Seek back to start of header */
- err = mtar_seek(tar, tar->last_header);
- if (err) {
- return err;
- }
- /* Load raw header into header struct and return */
- return raw_to_header(h, &tar->raw_header);
-}
+ /* Read data */
+ err = tread(tar, ptr, size);
+ if(err)
+ return err;
+ tar->remaining_data -= size;
-int mtar_read_data(mtar_t *tar, void *ptr, unsigned size) {
- int err;
- /* If we have no remaining data then this is the first read, we get the size,
- * set the remaining data and seek to the beginning of the data */
- if (tar->remaining_data == 0) {
- /* Read header */
- err = mtar_read_header(tar, &tar->header);
- if (err) {
- return err;
- }
- /* Seek past header and init remaining data */
- err = mtar_seek(tar, tar->pos + sizeof(mtar_raw_header_t));
- if (err) {
- return err;
- }
- tar->remaining_data = tar->header.size;
- }
- /* Ensure caller does not read too much */
- if(size > tar->remaining_data)
- return MTAR_EOVERFLOW;
- /* Read data */
- err = tread(tar, ptr, size);
- if (err) {
- return err;
- }
- tar->remaining_data -= size;
- /* If there is no remaining data we've finished reading and seek back to the
- * header */
- if (tar->remaining_data == 0) {
- return mtar_seek(tar, tar->last_header);
- }
- return MTAR_ESUCCESS;
-}
+ /* If there is no remaining data we've finished reading and
+ * seek back to the header */
+ if(tar->remaining_data == 0)
+ return mtar_seek(tar, tar->last_header);
+ return MTAR_ESUCCESS;
+}
-int mtar_write_header(mtar_t *tar, const mtar_header_t *h) {
- /* Build raw header and write */
- header_to_raw(&tar->raw_header, h);
- tar->remaining_data = h->size;
- return twrite(tar, &tar->raw_header, sizeof(tar->raw_header));
+int mtar_write_header(mtar_t* tar, const mtar_header_t* h)
+{
+ /* Build raw header and write */
+ header_to_raw(&tar->raw_header, h);
+ tar->remaining_data = h->size;
+ return twrite(tar, &tar->raw_header, sizeof(tar->raw_header));
}
+int mtar_write_file_header(mtar_t* tar, const char* name, unsigned size)
+{
+ /* Build header */
+ memset(&tar->header, 0, sizeof(tar->header));
-int mtar_write_file_header(mtar_t *tar, const char *name, unsigned size) {
- /* Build header */
- memset(&tar->header, 0, sizeof(tar->header));
- /* Ensure name fits within header */
- if(strlen(name) > sizeof(tar->header.name))
- return MTAR_EOVERFLOW;
- strncpy(tar->header.name, name, sizeof(tar->header.name));
- tar->header.size = size;
- tar->header.type = MTAR_TREG;
- tar->header.mode = 0664;
- /* Write header */
- return mtar_write_header(tar, &tar->header);
-}
+ /* Ensure name fits within header */
+ if(strlen(name) > sizeof(tar->header.name))
+ return MTAR_EOVERFLOW;
+ strncpy(tar->header.name, name, sizeof(tar->header.name));
+ tar->header.size = size;
+ tar->header.type = MTAR_TREG;
+ tar->header.mode = 0664;
-int mtar_write_dir_header(mtar_t *tar, const char *name) {
- /* Build header */
- memset(&tar->header, 0, sizeof(tar->header));
- /* Ensure name fits within header */
- if(strlen(name) > sizeof(tar->header.name))
- return MTAR_EOVERFLOW;
- strncpy(tar->header.name, name, sizeof(tar->header.name));
- tar->header.type = MTAR_TDIR;
- tar->header.mode = 0775;
- /* Write header */
- return mtar_write_header(tar, &tar->header);
+ /* Write header */
+ return mtar_write_header(tar, &tar->header);
}
+int mtar_write_dir_header(mtar_t* tar, const char* name)
+{
+ /* Build header */
+ memset(&tar->header, 0, sizeof(tar->header));
-int mtar_write_data(mtar_t *tar, const void *data, unsigned size) {
- int err;
+ /* Ensure name fits within header */
+ if(strlen(name) > sizeof(tar->header.name))
+ return MTAR_EOVERFLOW;
- /* Ensure we are writing the correct amount of data */
- if(size > tar->remaining_data)
- return MTAR_EOVERFLOW;
+ strncpy(tar->header.name, name, sizeof(tar->header.name));
+ tar->header.type = MTAR_TDIR;
+ tar->header.mode = 0775;
- /* Write data */
- err = twrite(tar, data, size);
- if (err) {
- return err;
- }
- tar->remaining_data -= size;
- /* Write padding if we've written all the data for this file */
- if (tar->remaining_data == 0) {
- return write_null_bytes(tar, round_up(tar->pos, 512) - tar->pos);
- }
- return MTAR_ESUCCESS;
+ /* Write header */
+ return mtar_write_header(tar, &tar->header);
}
+int mtar_write_data(mtar_t* tar, const void* data, unsigned size)
+{
+ int err;
+
+ /* Ensure we are writing the correct amount of data */
+ if(size > tar->remaining_data)
+ return MTAR_EOVERFLOW;
+
+ /* Write data */
+ err = twrite(tar, data, size);
+ if(err)
+ return err;
+
+ tar->remaining_data -= size;
+
+ /* Write padding if we've written all the data for this file */
+ if(tar->remaining_data == 0)
+ return write_null_bytes(tar, round_up(tar->pos, 512) - tar->pos);
+
+ return MTAR_ESUCCESS;
+}
-int mtar_finalize(mtar_t *tar) {
- /* Write two NULL records */
- return write_null_bytes(tar, sizeof(mtar_raw_header_t) * 2);
+int mtar_finalize(mtar_t* tar)
+{
+ /* Write two NULL records */
+ return write_null_bytes(tar, sizeof(mtar_raw_header_t) * 2);
}
diff --git a/src/microtar.h b/src/microtar.h
index 29f4591..d17129c 100644
--- a/src/microtar.h
+++ b/src/microtar.h
@@ -25,97 +25,93 @@
#define MICROTAR_H
#ifdef __cplusplus
-extern "C"
-{
+extern "C" {
#endif
#include <stdio.h>
#include <stdlib.h>
-#define MTAR_VERSION "0.1.0"
-
enum {
- MTAR_ESUCCESS = 0,
- MTAR_EFAILURE = -1,
- MTAR_EOPENFAIL = -2,
- MTAR_EREADFAIL = -3,
- MTAR_EWRITEFAIL = -4,
- MTAR_ESEEKFAIL = -5,
- MTAR_EBADCHKSUM = -6,
- MTAR_ENULLRECORD = -7,
- MTAR_ENOTFOUND = -8,
- MTAR_EOVERFLOW = -9,
+ MTAR_ESUCCESS = 0,
+ MTAR_EFAILURE = -1,
+ MTAR_EOPENFAIL = -2,
+ MTAR_EREADFAIL = -3,
+ MTAR_EWRITEFAIL = -4,
+ MTAR_ESEEKFAIL = -5,
+ MTAR_EBADCHKSUM = -6,
+ MTAR_ENULLRECORD = -7,
+ MTAR_ENOTFOUND = -8,
+ MTAR_EOVERFLOW = -9,
};
enum {
- MTAR_TREG = '0',
- MTAR_TLNK = '1',
- MTAR_TSYM = '2',
- MTAR_TCHR = '3',
- MTAR_TBLK = '4',
- MTAR_TDIR = '5',
- MTAR_TFIFO = '6'
+ MTAR_TREG = '0',
+ MTAR_TLNK = '1',
+ MTAR_TSYM = '2',
+ MTAR_TCHR = '3',
+ MTAR_TBLK = '4',
+ MTAR_TDIR = '5',
+ MTAR_TFIFO = '6',
};
-typedef struct {
- unsigned mode;
- unsigned owner;
- unsigned group;
- unsigned size;
- unsigned mtime;
- unsigned type;
- char name[101]; /* +1 byte in order to ensure null termination */
- char linkname[101];
-} mtar_header_t;
-
-
-typedef struct {
- char name[100];
- char mode[8];
- char owner[8];
- char group[8];
- char size[12];
- char mtime[12];
- char checksum[8];
- char type;
- char linkname[100];
- char _padding[255];
-} mtar_raw_header_t;
-
-
-typedef struct mtar_t mtar_t;
+typedef struct mtar_header mtar_header_t;
+typedef struct mtar_raw_header mtar_raw_header_t;
+typedef struct mtar mtar_t;
+
+struct mtar_header {
+ unsigned mode;
+ unsigned owner;
+ unsigned group;
+ unsigned size;
+ unsigned mtime;
+ unsigned type;
+ char name[101]; /* +1 byte in order to ensure null termination */
+ char linkname[101];
+};
-struct mtar_t {
- int (*read)(mtar_t *tar, void *data, unsigned size);
- int (*write)(mtar_t *tar, const void *data, unsigned size);
- int (*seek)(mtar_t *tar, unsigned pos);
- int (*close)(mtar_t *tar);
- void *stream;
- unsigned pos;
- unsigned remaining_data;
- unsigned last_header;
- mtar_header_t header;
- mtar_raw_header_t raw_header;
+struct mtar_raw_header {
+ char name[100];
+ char mode[8];
+ char owner[8];
+ char group[8];
+ char size[12];
+ char mtime[12];
+ char checksum[8];
+ char type;
+ char linkname[100];
+ char _padding[255];
};
+struct mtar {
+ int (*read)(mtar_t* tar, void* data, unsigned size);
+ int (*write)(mtar_t* tar, const void* data, unsigned size);
+ int (*seek)(mtar_t* tar, unsigned pos);
+ int (*close)(mtar_t* tar);
+ void* stream;
+ unsigned pos;
+ unsigned remaining_data;
+ unsigned last_header;
+ mtar_header_t header;
+ mtar_raw_header_t raw_header;
+};
const char* mtar_strerror(int err);
-int mtar_open(mtar_t *tar, const char *filename, const char *mode);
-int mtar_close(mtar_t *tar);
-
-int mtar_seek(mtar_t *tar, unsigned pos);
-int mtar_rewind(mtar_t *tar);
-int mtar_next(mtar_t *tar);
-int mtar_find(mtar_t *tar, const char *name, mtar_header_t *h);
-int mtar_read_header(mtar_t *tar, mtar_header_t *h);
-int mtar_read_data(mtar_t *tar, void *ptr, unsigned size);
-
-int mtar_write_header(mtar_t *tar, const mtar_header_t *h);
-int mtar_write_file_header(mtar_t *tar, const char *name, unsigned size);
-int mtar_write_dir_header(mtar_t *tar, const char *name);
-int mtar_write_data(mtar_t *tar, const void *data, unsigned size);
-int mtar_finalize(mtar_t *tar);
+int mtar_open(mtar_t* tar, const char* filename, const char* mode);
+int mtar_close(mtar_t* tar);
+
+int mtar_seek(mtar_t* tar, unsigned pos);
+int mtar_rewind(mtar_t* tar);
+int mtar_next(mtar_t* tar);
+int mtar_find(mtar_t* tar, const char* name, mtar_header_t* h);
+int mtar_read_header(mtar_t* tar, mtar_header_t* h);
+int mtar_read_data(mtar_t* tar, void* ptr, unsigned size);
+
+int mtar_write_header(mtar_t* tar, const mtar_header_t* h);
+int mtar_write_file_header(mtar_t* tar, const char* name, unsigned size);
+int mtar_write_dir_header(mtar_t* tar, const char* name);
+int mtar_write_data(mtar_t* tar, const void* data, unsigned size);
+int mtar_finalize(mtar_t* tar);
#ifdef __cplusplus
}