Commit 986ad31b authored by Ron Minnich's avatar Ron Minnich Committed by Russ Cox

gc: use HEADER_IO macro from gopack

Use HEADER_IO macro from gopack to read archive header
The HEADER_IO macro portably reads archive headers. The
current arsize code fails in the case of archive headers produced
on plan 9 6c and read on other systems (it's not portable).
Modify lex.c to use the portable macro
Build tested (including tests) on OSX.

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/5323072
parent 2e1bb76f
...@@ -380,18 +380,30 @@ saveerrors(void) ...@@ -380,18 +380,30 @@ saveerrors(void)
nerrors = 0; nerrors = 0;
} }
/*
* macro to portably read/write archive header.
* 'cmd' is read/write/Bread/Bwrite, etc.
*/
#define HEADER_IO(cmd, f, h) cmd(f, h.name, sizeof(h.name)) != sizeof(h.name)\
|| cmd(f, h.date, sizeof(h.date)) != sizeof(h.date)\
|| cmd(f, h.uid, sizeof(h.uid)) != sizeof(h.uid)\
|| cmd(f, h.gid, sizeof(h.gid)) != sizeof(h.gid)\
|| cmd(f, h.mode, sizeof(h.mode)) != sizeof(h.mode)\
|| cmd(f, h.size, sizeof(h.size)) != sizeof(h.size)\
|| cmd(f, h.fmag, sizeof(h.fmag)) != sizeof(h.fmag)
static int static int
arsize(Biobuf *b, char *name) arsize(Biobuf *b, char *name)
{ {
struct ar_hdr *a; struct ar_hdr a;
if((a = Brdline(b, '\n')) == nil) if (HEADER_IO(Bread, b, a))
return -1; return -1;
if(Blinelen(b) != sizeof(struct ar_hdr))
return -1; if(strncmp(a.name, name, strlen(name)) != 0)
if(strncmp(a->name, name, strlen(name)) != 0)
return -1; return -1;
return atoi(a->size);
return atoi(a.size);
} }
static int static int
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment