Made to work if BYTES_REVERSED and/or WORDS_REVERSED are not defined
This commit is contained in:
parent
36e47ad79b
commit
8322e2d5d3
4 changed files with 49 additions and 64 deletions
|
@ -13,6 +13,14 @@
|
||||||
#define Xchar(ch) ((ch) & 0377)
|
#define Xchar(ch) ((ch) & 0377)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if ! defined(BYTES_REVERSED)
|
||||||
|
#define BYTES_REVERSED 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if ! defined(WORDS_REVERSED)
|
||||||
|
#define WORDS_REVERSED 1
|
||||||
|
#endif
|
||||||
|
|
||||||
#if BYTES_REVERSED
|
#if BYTES_REVERSED
|
||||||
#define uget2(c) (Xchar((c)[0]) | ((unsigned) Xchar((c)[1]) << 8))
|
#define uget2(c) (Xchar((c)[0]) | ((unsigned) Xchar((c)[1]) << 8))
|
||||||
#define Xput2(i, c) (((c)[0] = (i)), ((c)[1] = (i) >> 8))
|
#define Xput2(i, c) (((c)[0] = (i)), ((c)[1] = (i) >> 8))
|
||||||
|
|
|
@ -155,23 +155,21 @@ rd_sect(sect, cnt)
|
||||||
while (cnt--) {
|
while (cnt--) {
|
||||||
sect--;
|
sect--;
|
||||||
#if ! (BYTES_REVERSED || WORDS_REVERSED)
|
#if ! (BYTES_REVERSED || WORDS_REVERSED)
|
||||||
if (sizeof(struct outsect) != SZ_SECT) {
|
if (sizeof(struct outsect) != SZ_SECT)
|
||||||
#endif
|
#endif
|
||||||
|
{
|
||||||
c -= 4; sect->os_lign = get4(c);
|
c -= 4; sect->os_lign = get4(c);
|
||||||
c -= 4; sect->os_flen = get4(c);
|
c -= 4; sect->os_flen = get4(c);
|
||||||
c -= 4; sect->os_foff = get4(c);
|
c -= 4; sect->os_foff = get4(c);
|
||||||
#if ! (BYTES_REVERSED || WORDS_REVERSED)
|
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
offset[--offcnt] = sect->os_foff + rd_base;
|
offset[--offcnt] = sect->os_foff + rd_base;
|
||||||
#if ! (BYTES_REVERSED || WORDS_REVERSED)
|
#if ! (BYTES_REVERSED || WORDS_REVERSED)
|
||||||
if (sizeof(struct outsect) != SZ_SECT) {
|
if (sizeof(struct outsect) != SZ_SECT)
|
||||||
#endif
|
#endif
|
||||||
|
{
|
||||||
c -= 4; sect->os_size = get4(c);
|
c -= 4; sect->os_size = get4(c);
|
||||||
c -= 4; sect->os_base = get4(c);
|
c -= 4; sect->os_base = get4(c);
|
||||||
#if ! (BYTES_REVERSED || WORDS_REVERSED)
|
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,10 +10,6 @@ int
|
||||||
rd_arhdr(fd, arhdr)
|
rd_arhdr(fd, arhdr)
|
||||||
register struct ar_hdr *arhdr;
|
register struct ar_hdr *arhdr;
|
||||||
{
|
{
|
||||||
#if WORDS_REVERSED && ! BYTES_REVERSED
|
|
||||||
if (sizeof (struct ar_hdr) != AR_TOTAL)
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
char buf[AR_TOTAL];
|
char buf[AR_TOTAL];
|
||||||
register char *c = buf;
|
register char *c = buf;
|
||||||
register char *p = arhdr->ar_name;
|
register char *p = arhdr->ar_name;
|
||||||
|
@ -35,14 +31,5 @@ rd_arhdr(fd, arhdr)
|
||||||
arhdr->ar_mode = get2(c); c += 2;
|
arhdr->ar_mode = get2(c); c += 2;
|
||||||
arhdr->ar_size = (long) get2(c) << 16; c += 2;
|
arhdr->ar_size = (long) get2(c) << 16; c += 2;
|
||||||
arhdr->ar_size |= (long) get2(c) & 0xffff;
|
arhdr->ar_size |= (long) get2(c) & 0xffff;
|
||||||
}
|
|
||||||
#if WORDS_REVERSED && !BYTES_REVERSED
|
|
||||||
else {
|
|
||||||
register int i;
|
|
||||||
i = read(fd, (char *) arhdr, AR_TOTAL);
|
|
||||||
if (i == 0) return 0;
|
|
||||||
if (i != AR_TOTAL) rd_fatal();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,10 +9,6 @@
|
||||||
wr_arhdr(fd, arhdr)
|
wr_arhdr(fd, arhdr)
|
||||||
register struct ar_hdr *arhdr;
|
register struct ar_hdr *arhdr;
|
||||||
{
|
{
|
||||||
#if WORDS_REVERSED && !BYTES_REVERSED
|
|
||||||
if (sizeof (struct ar_hdr) != AR_TOTAL)
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
char buf[AR_TOTAL];
|
char buf[AR_TOTAL];
|
||||||
register char *c = buf;
|
register char *c = buf;
|
||||||
register char *p = arhdr->ar_name;
|
register char *p = arhdr->ar_name;
|
||||||
|
@ -29,8 +25,4 @@ wr_arhdr(fd, arhdr)
|
||||||
put2((int)(arhdr->ar_size>>16),c); c += 2;
|
put2((int)(arhdr->ar_size>>16),c); c += 2;
|
||||||
put2((int)(arhdr->ar_size),c);
|
put2((int)(arhdr->ar_size),c);
|
||||||
wr_bytes(fd, buf, (long) AR_TOTAL);
|
wr_bytes(fd, buf, (long) AR_TOTAL);
|
||||||
}
|
|
||||||
#if WORDS_REVERSED && !BYTES_REVERSED
|
|
||||||
else wr_bytes(fd, (char *) arhdr, (long) AR_TOTAL);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue