aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGlenn L McGrath <bug1@ihug.co.nz>2004-07-23 01:20:57 +0000
committerGlenn L McGrath <bug1@ihug.co.nz>2004-07-23 01:20:57 +0000
commitb8756317545a959d86186e390314810041f95482 (patch)
treedeaec8d82be9db1947f94099dc00db74acbc96e1
parent4d405bbc05f79ac31d979ec26a180d3ee9236a82 (diff)
downloadbusybox-w32-b8756317545a959d86186e390314810041f95482.tar.gz
busybox-w32-b8756317545a959d86186e390314810041f95482.tar.bz2
busybox-w32-b8756317545a959d86186e390314810041f95482.zip
Patch from Adam Slattery to add bzip2 support to rpm2cpio
-rw-r--r--patches/rpm2cpio_bzip2.patch63
1 files changed, 63 insertions, 0 deletions
diff --git a/patches/rpm2cpio_bzip2.patch b/patches/rpm2cpio_bzip2.patch
new file mode 100644
index 000000000..151dd9fb4
--- /dev/null
+++ b/patches/rpm2cpio_bzip2.patch
@@ -0,0 +1,63 @@
1diff -ur busybox/archival/Config.in busybox/archival/Config.in
2--- busybox/archival/Config.in Sun May 23 09:15:37 2004
3+++ busybox/archival/Config.in Sun May 23 09:15:58 2004
4@@ -127,6 +127,14 @@
5 help
6 Converts an RPM file into a CPIO archive.
7
8+config CONFIG_FEATURE_RPM2CPIO_BZIP2
9+ bool " Support bzip2 decompression"
10+ default n
11+ depends on CONFIG_RPM2CPIO
12+ help
13+ If you enable this option you'll be able to extract
14+ rpms compressed with bzip2.
15+
16 config CONFIG_RPM
17 bool "rpm"
18 default n
19diff -ur busybox/archival/libunarchive/Makefile.in busybox/archival/libunarchive/Makefile.in
20--- busybox/archival/libunarchive/Makefile.in Sun May 23 09:15:04 2004
21+++ busybox/archival/libunarchive/Makefile.in Sun May 23 09:16:42 2004
22@@ -65,6 +65,7 @@
23 LIBUNARCHIVE-$(CONFIG_GUNZIP) += $(GUNZIP_FILES)
24 LIBUNARCHIVE-$(CONFIG_FEATURE_GUNZIP_UNCOMPRESS) += decompress_uncompress.o
25 LIBUNARCHIVE-$(CONFIG_RPM2CPIO) += $(GUNZIP_FILES) get_header_cpio.o
26+LIBUNARCHIVE-$(CONFIG_FEATURE_RPM2CPIO_BZIP2) += decompress_bunzip2.o
27 LIBUNARCHIVE-$(CONFIG_RPM) += $(GUNZIP_FILES) get_header_cpio.o
28 LIBUNARCHIVE-$(CONFIG_TAR) += get_header_tar.o
29 LIBUNARCHIVE-$(CONFIG_FEATURE_TAR_BZIP2) += decompress_bunzip2.o get_header_tar_bz2.o
30diff -ur busybox/archival/rpm2cpio.c busybox/archival/rpm2cpio.c
31--- busybox/archival/rpm2cpio.c Sun May 23 09:15:04 2004
32+++ busybox/archival/rpm2cpio.c Sun May 23 09:19:03 2004
33@@ -91,14 +91,26 @@
34 skip_header(rpm_fd);
35
36 bb_xread_all(rpm_fd, &magic, 2);
37- if ((magic[0] != 0x1f) || (magic[1] != 0x8b)) {
38- bb_error_msg_and_die("Invalid gzip magic");
39+ if ((magic[0] == 0x1f) || (magic[1] == 0x8b)) {
40+ check_header_gzip(rpm_fd);
41+ if (inflate_gunzip(rpm_fd, fileno(stdout)) != 0)
42+ bb_error_msg("Error inflating (gzip)");
43 }
44
45- check_header_gzip(rpm_fd);
46- if (inflate_gunzip(rpm_fd, STDOUT_FILENO) != 0) {
47- bb_error_msg("Error inflating");
48+ if ((magic[0] == 'B') && (magic[1] == 'Z')) {
49+#ifdef CONFIG_FEATURE_RPM2CPIO_BZIP2
50+ /* return to position before magic (eek..!) */
51+ lseek(rpm_fd, -2, SEEK_CUR);
52+ if(uncompressStream(rpm_fd, fileno(stdout)) != 0)
53+ bb_error_msg("Error inflating (bzip2)");
54+#else
55+ bb_error_msg_and_die("bzip2 not supported");
56+#endif
57 }
58+
59+ else
60+ bb_error_msg_and_die("not gzip or bzip2 compressed");
61+
62
63 close(rpm_fd);