2009-01-16 13:24:00 +01:00
|
|
|
|
|
|
|
/* Find how deeply inside an .RPM the real data is */
|
|
|
|
/* kept, and report the offset in bytes */
|
|
|
|
|
|
|
|
/* Wouldn't it be a lot more sane if we could just untar these things? */
|
|
|
|
|
2011-11-20 19:33:05 +01:00
|
|
|
#include <stdlib.h>
|
2009-01-16 13:24:00 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
|
2011-11-20 19:33:05 +01:00
|
|
|
/* These offsets keep getting bigger, so we're going to just bite a 2MB */
|
|
|
|
/* chunk of RAM right away so that we have enough. Yeah, horrible */
|
|
|
|
/* quick and dirty implementation, but hey -- it gets the job done. */
|
2011-10-28 12:47:55 +02:00
|
|
|
|
2011-11-20 19:33:05 +01:00
|
|
|
#define RPMBUFSIZ 3145728
|
2011-10-28 12:47:55 +02:00
|
|
|
|
2011-11-20 19:33:05 +01:00
|
|
|
main()
|
2011-10-28 12:47:55 +02:00
|
|
|
{
|
2011-11-20 19:33:05 +01:00
|
|
|
char *buff = malloc(RPMBUFSIZ),*eb,*p;
|
|
|
|
for (p = buff, eb = buff + read(0,buff,RPMBUFSIZ); p < eb; p++)
|
|
|
|
{
|
|
|
|
|
|
|
|
/* gzip format */
|
|
|
|
if (*p == '\037' && p[1] == '\213' && p[2] == '\010')
|
|
|
|
{
|
|
|
|
printf("%ld\n",p - buff);
|
|
|
|
exit(0);
|
2009-01-16 13:24:00 +01:00
|
|
|
}
|
|
|
|
|
2011-11-20 19:33:05 +01:00
|
|
|
/* bzip2 format */
|
|
|
|
else if (*p == 'B' && p[1] == 'Z' && p[2] == 'h' )
|
|
|
|
{
|
|
|
|
printf("%ld\n",p - buff);
|
|
|
|
exit(0);
|
2009-01-16 13:24:00 +01:00
|
|
|
}
|
|
|
|
|
2011-11-20 19:33:05 +01:00
|
|
|
/* LZMA files; both LZMA_Alone and LZMA utils formats. The LZMA_Alone
|
|
|
|
* format is used by the LZMA_Alone tool from LZMA SDK. The LZMA utils
|
|
|
|
* format is the default format of LZMA utils 4.32.1 and later. */
|
|
|
|
|
|
|
|
/* LZMA utils format */
|
|
|
|
else if (*p == '\377' && p[1] == 'L' &&
|
|
|
|
p[2] == 'Z' && p[3] == 'M' &&
|
|
|
|
p[4] == 'A' && p[5] == '\000')
|
|
|
|
{
|
|
|
|
printf("%ld\n",p - buff);
|
|
|
|
exit(0);
|
|
|
|
}
|
2011-10-28 12:47:55 +02:00
|
|
|
|
2011-11-20 19:33:05 +01:00
|
|
|
/* The LZMA_Alone format has no magic bytes, thus we
|
|
|
|
* need to play a wizard. This can give false positives,
|
|
|
|
* thus the detection below should be removed when
|
|
|
|
* the newer LZMA utils format has got popular. */
|
|
|
|
// else if (*p == 0x5D && p[1] == 0x00 &&
|
|
|
|
else if (*p == '\135' &&
|
|
|
|
p[5] == '\377' && p[6] == '\377' &&
|
|
|
|
p[7] == '\377' && p[8] == '\377' &&
|
|
|
|
p[9] == '\377' && p[10] == '\377' &&
|
|
|
|
p[11] == '\377' && p[12] == '\377')
|
|
|
|
|
|
|
|
/* ((p[10] == 0x00 && p[11] == 0x00 &&
|
|
|
|
p[12] == 0x00) ||
|
|
|
|
(p[5] == 0xFF && p[6] == 0xFF &&
|
|
|
|
p[7] == 0xFF && p[8] == 0xFF &&
|
|
|
|
p[9] == 0xFF && p[10] == 0xFF &&
|
|
|
|
p[11] == 0xFF && p[12] == 0xFF)))
|
|
|
|
*/ {
|
|
|
|
printf("%ld\n",p - buff);
|
|
|
|
exit(0);
|
2009-01-16 13:24:00 +01:00
|
|
|
}
|
|
|
|
}
|
2011-11-20 19:33:05 +01:00
|
|
|
exit(1);
|
2009-01-16 13:24:00 +01:00
|
|
|
}
|