(xheader_decode): Store the header as well (for eventual delete).
This commit is contained in:
@@ -107,7 +107,7 @@ decode_record (char **p, struct tar_stat_info *st)
|
||||
void
|
||||
xheader_decode (struct tar_stat_info *st)
|
||||
{
|
||||
char *p = extended_header.buffer;
|
||||
char *p = extended_header.buffer + BLOCKSIZE;
|
||||
char *endp = &extended_header.buffer[extended_header.size-1];
|
||||
|
||||
while (p < endp)
|
||||
@@ -136,29 +136,31 @@ xheader_store (char const *keyword, struct tar_stat_info const *st)
|
||||
void
|
||||
xheader_read (union block *p, size_t size)
|
||||
{
|
||||
size_t i, j;
|
||||
size_t j = 0;
|
||||
size_t nblocks;
|
||||
|
||||
free (extended_header.buffer);
|
||||
size += BLOCKSIZE;
|
||||
extended_header.size = size;
|
||||
nblocks = (size + BLOCKSIZE - 1) / BLOCKSIZE;
|
||||
extended_header.buffer = xmalloc (size + 1);
|
||||
|
||||
set_next_block_after (p);
|
||||
for (i = j = 0; i < nblocks; i++)
|
||||
do
|
||||
{
|
||||
size_t len;
|
||||
size_t len = size;
|
||||
|
||||
p = find_next_block ();
|
||||
len = size;
|
||||
if (len > BLOCKSIZE)
|
||||
len = BLOCKSIZE;
|
||||
|
||||
memcpy (&extended_header.buffer[j], p->buffer, len);
|
||||
set_next_block_after (p);
|
||||
|
||||
p = find_next_block ();
|
||||
|
||||
j += len;
|
||||
size -= len;
|
||||
}
|
||||
while (size > 0);
|
||||
}
|
||||
|
||||
static size_t
|
||||
|
||||
Reference in New Issue
Block a user