diff options
author | Aidan MacDonald <amachronic@protonmail.com> | 2021-11-04 18:56:27 +0300 |
---|---|---|
committer | Aidan MacDonald <amachronic@protonmail.com> | 2021-11-04 19:03:37 +0300 |
commit | 2a6bf50265c94138b7144243b5ba0e57a9afcbf4 (patch) | |
tree | 6ff38287ec5abbcca933f9c5aa6858c5076f1059 | |
parent | 637e5f5ecbfdce9e5707297bfd900e9ca924aec4 (diff) |
Restyle the source code
This is frivolous, but I really don't like the current style.
-rw-r--r-- | src/microtar-stdio.c | 86 | ||||
-rw-r--r-- | src/microtar.c | 606 | ||||
-rw-r--r-- | src/microtar.h | 144 |
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 } |