{
unsigned skip_amount = (boundary - (archive_handle->offset % boundary)) % boundary;
- archive_handle->seek(archive_handle, skip_amount);
+ archive_handle->seek(archive_handle->src_fd, skip_amount);
archive_handle->offset += skip_amount;
}
void FAST_FUNC data_skip(archive_handle_t *archive_handle)
{
- archive_handle->seek(archive_handle, archive_handle->file_header->size);
+ archive_handle->seek(archive_handle->src_fd, archive_handle->file_header->size);
}
#include "libbb.h"
#include "unarchive.h"
-void FAST_FUNC seek_by_jump(const archive_handle_t *archive_handle, unsigned amount)
+void FAST_FUNC seek_by_jump(int fd, off_t amount)
{
if (amount
- && lseek(archive_handle->src_fd, (off_t) amount, SEEK_CUR) == (off_t) -1
+ && lseek(fd, amount, SEEK_CUR) == (off_t) -1
) {
if (errno == ESPIPE)
- seek_by_read(archive_handle, amount);
+ seek_by_read(fd, amount);
else
bb_perror_msg_and_die("seek failure");
}
/* If we are reading through a pipe, or from stdin then we can't lseek,
* we must read and discard the data to skip over it.
*/
-void FAST_FUNC seek_by_read(const archive_handle_t *archive_handle, unsigned jump_size)
+void FAST_FUNC seek_by_read(int fd, off_t amount)
{
- if (jump_size)
- bb_copyfd_exact_size(archive_handle->src_fd, -1, jump_size);
+ if (amount)
+ bb_copyfd_exact_size(fd, -1, amount);
}
uint32_t size; /* Size of store (4 bytes) */
};
-static off_t skip_header(int rpm_fd)
+static unsigned skip_header(int rpm_fd)
{
struct rpm_header header;
+ unsigned len;
xread(rpm_fd, &header, sizeof(header));
// if (strncmp((char *) &header.magic, RPM_HEADER_MAGIC_STR, 3) != 0) {
bb_error_msg_and_die("invalid RPM header magic or unsupported version");
// ": %x != %x", header.magic_and_ver, htonl(RPM_HEADER_VERnMAGIC));
}
- /* Seek past index entries */
- lseek(rpm_fd, 16 * ntohl(header.entries), SEEK_CUR);
- /* Seek past store */
- return lseek(rpm_fd, ntohl(header.size), SEEK_CUR);
+
+ /* Seek past index entries, and past store */
+ len = 16 * ntohl(header.entries) + ntohl(header.size);
+ seek_by_jump(rpm_fd, len);
+
+ return sizeof(header) + len;
}
/* No getopt required */
{
struct rpm_lead lead;
int rpm_fd;
- off_t pos;
+ unsigned pos;
unsigned char magic[2];
IF_DESKTOP(long long) int FAST_FUNC (*unpack)(int src_fd, int dst_fd);
/* Skip the signature header, align to 8 bytes */
pos = skip_header(rpm_fd);
- lseek(rpm_fd, (8 - (unsigned)pos) & 7, SEEK_CUR);
+ seek_by_jump(rpm_fd, (8 - pos) & 7);
/* Skip the main header */
skip_header(rpm_fd);
/* Count the number of bytes processed */
off_t offset;
- /* Function that skips data: read_by_char or read_by_skip */
- void FAST_FUNC (*seek)(const struct archive_handle_t *archive_handle, const unsigned amount);
+ /* Function that skips data */
+ void FAST_FUNC (*seek)(int fd, off_t amount);
/* Temporary storage */
char *buffer;
extern char get_header_tar_bz2(archive_handle_t *archive_handle) FAST_FUNC;
extern char get_header_tar_lzma(archive_handle_t *archive_handle) FAST_FUNC;
-extern void seek_by_jump(const archive_handle_t *archive_handle, unsigned amount) FAST_FUNC;
-extern void seek_by_read(const archive_handle_t *archive_handle, unsigned amount) FAST_FUNC;
+extern void seek_by_jump(int fd, off_t amount) FAST_FUNC;
+extern void seek_by_read(int fd, off_t amount) FAST_FUNC;
extern void data_align(archive_handle_t *archive_handle, unsigned boundary) FAST_FUNC;
extern const llist_t *find_list_entry(const llist_t *list, const char *filename) FAST_FUNC;