FreeCalypso > hg > tcs211-patches
changeset 4:e33380b5bd46
tool/archive.c: preparation for making some vars global
author | Space Falcon <falcon@ivan.Harhan.ORG> |
---|---|
date | Sat, 06 Jun 2015 03:14:02 +0000 (2015-06-06) |
parents | 003df9892e57 |
children | 5ba13fd0e737 |
files | tool/archive.c |
diffstat | 1 files changed, 14 insertions(+), 13 deletions(-) [+] |
line wrap: on
line diff
--- a/tool/archive.c Fri Jun 05 21:19:08 2015 +0000 +++ b/tool/archive.c Sat Jun 06 03:14:02 2015 +0000 @@ -10,14 +10,15 @@ #include "ar.h" #include "globals.h" +struct ar_hdr ar_hdr; +char member_name[17]; +unsigned member_size; +u_char *member_body; + process_archive() { FILE *inf, *outf; - char ar_signature_buf[SARMAG]; - struct ar_hdr ar_hdr; - char member_name[17], *cp; - unsigned size; - char *buf; + char ar_signature_buf[SARMAG], *cp; inf = fopen(lib_in_filename, "r"); if (!inf) { @@ -52,21 +53,21 @@ exit(1); } *cp = '\0'; - size = strtoul(ar_hdr.ar_size, 0, 10); - buf = malloc(size); - if (!buf) { + member_size = strtoul(ar_hdr.ar_size, 0, 10); + member_body = malloc(member_size); + if (!member_body) { fprintf(stderr, "error: unable to malloc buffer for archive member \"%s\"\n", member_name); exit(1); } - if (fread(buf, 1, size, inf) != size) { + if (fread(member_body, 1, member_size, inf) != member_size) { fprintf(stderr, "error reading the body of member \"%s\" from %s\n", member_name, lib_in_filename); exit(1); } - if (size & 1 && getc(inf) != '\n') { + if (member_size & 1 && getc(inf) != '\n') { fprintf(stderr, "error parsing %s: no \\n after odd-sized member \"%s\"\n", lib_in_filename, member_name); @@ -75,9 +76,9 @@ /* the patch hook will go here */ /* write it out */ fwrite(&ar_hdr, sizeof(struct ar_hdr), 1, outf); - fwrite(buf, 1, size, outf); - free(buf); - if (size & 1) + fwrite(member_body, 1, member_size, outf); + free(member_body); + if (member_size & 1) putc('\n', outf); } fclose(inf);