Bernhard Reutner-Fischer | 9457e70 | 2006-04-02 20:12:31 +0000 | [diff] [blame] | 1 | /* vi: set sw=4 ts=4: */ |
Denis Vlasenko | f81e8db | 2009-04-09 12:35:13 +0000 | [diff] [blame] | 2 | #ifndef UNARCHIVE_H |
| 3 | #define UNARCHIVE_H 1 |
Glenn L McGrath | e9fc781 | 2001-10-25 14:57:14 +0000 | [diff] [blame] | 4 | |
Denis Vlasenko | f81e8db | 2009-04-09 12:35:13 +0000 | [diff] [blame] | 5 | PUSH_AND_SET_FUNCTION_VISIBILITY_TO_HIDDEN |
Denis Vlasenko | 98636eb | 2008-05-09 17:59:34 +0000 | [diff] [blame] | 6 | |
Denis Vlasenko | 7510384 | 2007-06-20 14:49:47 +0000 | [diff] [blame] | 7 | typedef struct file_header_t { |
Glenn L McGrath | e9fc781 | 2001-10-25 14:57:14 +0000 | [diff] [blame] | 8 | char *name; |
Denis Vlasenko | 7510384 | 2007-06-20 14:49:47 +0000 | [diff] [blame] | 9 | char *link_target; |
Denis Vlasenko | e00e502 | 2008-02-14 20:37:54 +0000 | [diff] [blame] | 10 | #if ENABLE_FEATURE_TAR_UNAME_GNAME |
Denys Vlasenko | aa4977d | 2010-01-06 10:53:17 +0100 | [diff] [blame] | 11 | char *tar__uname; |
| 12 | char *tar__gname; |
Denis Vlasenko | e00e502 | 2008-02-14 20:37:54 +0000 | [diff] [blame] | 13 | #endif |
Glenn L McGrath | e9fc781 | 2001-10-25 14:57:14 +0000 | [diff] [blame] | 14 | off_t size; |
| 15 | uid_t uid; |
| 16 | gid_t gid; |
| 17 | mode_t mode; |
| 18 | time_t mtime; |
| 19 | dev_t device; |
| 20 | } file_header_t; |
| 21 | |
Denys Vlasenko | aa4977d | 2010-01-06 10:53:17 +0100 | [diff] [blame] | 22 | struct hardlinks_t; |
| 23 | |
Denis Vlasenko | 7510384 | 2007-06-20 14:49:47 +0000 | [diff] [blame] | 24 | typedef struct archive_handle_t { |
Denys Vlasenko | aa4977d | 2010-01-06 10:53:17 +0100 | [diff] [blame] | 25 | /* Flags. 1st since it is most used member */ |
| 26 | unsigned ah_flags; |
| 27 | |
| 28 | /* The raw stream as read from disk or stdin */ |
| 29 | int src_fd; |
| 30 | |
Denis Vlasenko | a60936d | 2008-06-28 05:04:09 +0000 | [diff] [blame] | 31 | /* Define if the header and data component should be processed */ |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 32 | char FAST_FUNC (*filter)(struct archive_handle_t *); |
Denys Vlasenko | aa4977d | 2010-01-06 10:53:17 +0100 | [diff] [blame] | 33 | /* List of files that have been accepted */ |
Glenn L McGrath | 66125c8 | 2002-12-08 00:54:33 +0000 | [diff] [blame] | 34 | llist_t *accept; |
Bernhard Reutner-Fischer | 9457e70 | 2006-04-02 20:12:31 +0000 | [diff] [blame] | 35 | /* List of files that have been rejected */ |
Glenn L McGrath | 66125c8 | 2002-12-08 00:54:33 +0000 | [diff] [blame] | 36 | llist_t *reject; |
Bernhard Reutner-Fischer | 9457e70 | 2006-04-02 20:12:31 +0000 | [diff] [blame] | 37 | /* List of files that have successfully been worked on */ |
| 38 | llist_t *passed; |
Glenn L McGrath | e9fc781 | 2001-10-25 14:57:14 +0000 | [diff] [blame] | 39 | |
Denys Vlasenko | aa4977d | 2010-01-06 10:53:17 +0100 | [diff] [blame] | 40 | /* Currently processed file's header */ |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 41 | file_header_t *file_header; |
Glenn L McGrath | e9fc781 | 2001-10-25 14:57:14 +0000 | [diff] [blame] | 42 | |
Denis Vlasenko | a60936d | 2008-06-28 05:04:09 +0000 | [diff] [blame] | 43 | /* Process the header component, e.g. tar -t */ |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 44 | void FAST_FUNC (*action_header)(const file_header_t *); |
Glenn L McGrath | e9fc781 | 2001-10-25 14:57:14 +0000 | [diff] [blame] | 45 | |
Denis Vlasenko | a60936d | 2008-06-28 05:04:09 +0000 | [diff] [blame] | 46 | /* Process the data component, e.g. extract to filesystem */ |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 47 | void FAST_FUNC (*action_data)(struct archive_handle_t *); |
Eric Andersen | c7bda1c | 2004-03-15 08:29:22 +0000 | [diff] [blame] | 48 | |
Denys Vlasenko | 0a130d5 | 2009-08-28 21:09:51 +0200 | [diff] [blame] | 49 | /* Function that skips data */ |
| 50 | void FAST_FUNC (*seek)(int fd, off_t amount); |
Glenn L McGrath | 237ae42 | 2002-11-03 14:05:15 +0000 | [diff] [blame] | 51 | |
Denys Vlasenko | aa4977d | 2010-01-06 10:53:17 +0100 | [diff] [blame] | 52 | /* Count processed bytes */ |
| 53 | off_t offset; |
| 54 | |
| 55 | /* Archiver specific. Can make it a union if it ever gets big */ |
| 56 | #if ENABLE_TAR |
| 57 | smallint tar__end; |
| 58 | # if ENABLE_FEATURE_TAR_GNU_EXTENSIONS |
| 59 | char* tar__longname; |
| 60 | char* tar__linkname; |
| 61 | # endif |
| 62 | #endif |
| 63 | #if ENABLE_CPIO |
| 64 | uoff_t cpio__blocks; |
| 65 | struct hardlinks_t *cpio__hardlinks_to_create; |
| 66 | struct hardlinks_t *cpio__created_hardlinks; |
| 67 | #endif |
| 68 | #if ENABLE_DPKG || ENABLE_DPKG_DEB |
Glenn L McGrath | f235d05 | 2003-10-29 03:37:54 +0000 | [diff] [blame] | 69 | /* Temporary storage */ |
Denys Vlasenko | aa4977d | 2010-01-06 10:53:17 +0100 | [diff] [blame] | 70 | char *dpkg__buffer; |
| 71 | /* How to process any sub archive, e.g. get_header_tar_gz */ |
| 72 | char FAST_FUNC (*dpkg__action_data_subarchive)(struct archive_handle_t *); |
| 73 | /* Contains the handle to a sub archive */ |
| 74 | struct archive_handle_t *dpkg__sub_archive; |
| 75 | #endif |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 76 | } archive_handle_t; |
Denys Vlasenko | 425ad9c | 2009-12-16 22:46:01 +0100 | [diff] [blame] | 77 | /* bits in ah_flags */ |
| 78 | #define ARCHIVE_RESTORE_DATE (1 << 0) |
| 79 | #define ARCHIVE_CREATE_LEADING_DIRS (1 << 1) |
| 80 | #define ARCHIVE_UNLINK_OLD (1 << 2) |
| 81 | #define ARCHIVE_EXTRACT_QUIET (1 << 3) |
| 82 | #define ARCHIVE_EXTRACT_NEWER (1 << 4) |
| 83 | #define ARCHIVE_DONT_RESTORE_OWNER (1 << 5) |
| 84 | #define ARCHIVE_DONT_RESTORE_PERM (1 << 6) |
| 85 | #define ARCHIVE_NUMERIC_OWNER (1 << 7) |
Denys Vlasenko | 8a936cf | 2009-12-16 23:18:59 +0100 | [diff] [blame] | 86 | #define ARCHIVE_O_TRUNC (1 << 8) |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 87 | |
Denis Vlasenko | bb3d0fa | 2007-01-03 01:57:25 +0000 | [diff] [blame] | 88 | |
Denis Vlasenko | 1a9e9bd | 2008-11-01 12:54:56 +0000 | [diff] [blame] | 89 | /* Info struct unpackers can fill out to inform users of thing like |
| 90 | * timestamps of unpacked files */ |
| 91 | typedef struct unpack_info_t { |
| 92 | time_t mtime; |
| 93 | } unpack_info_t; |
| 94 | |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 95 | extern archive_handle_t *init_handle(void) FAST_FUNC; |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 96 | |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 97 | extern char filter_accept_all(archive_handle_t *archive_handle) FAST_FUNC; |
| 98 | extern char filter_accept_list(archive_handle_t *archive_handle) FAST_FUNC; |
| 99 | extern char filter_accept_list_reassign(archive_handle_t *archive_handle) FAST_FUNC; |
| 100 | extern char filter_accept_reject_list(archive_handle_t *archive_handle) FAST_FUNC; |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 101 | |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 102 | extern void unpack_ar_archive(archive_handle_t *ar_archive) FAST_FUNC; |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 103 | |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 104 | extern void data_skip(archive_handle_t *archive_handle) FAST_FUNC; |
| 105 | extern void data_extract_all(archive_handle_t *archive_handle) FAST_FUNC; |
| 106 | extern void data_extract_to_stdout(archive_handle_t *archive_handle) FAST_FUNC; |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 107 | |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 108 | extern void header_skip(const file_header_t *file_header) FAST_FUNC; |
| 109 | extern void header_list(const file_header_t *file_header) FAST_FUNC; |
| 110 | extern void header_verbose_list(const file_header_t *file_header) FAST_FUNC; |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 111 | |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 112 | extern char get_header_ar(archive_handle_t *archive_handle) FAST_FUNC; |
| 113 | extern char get_header_cpio(archive_handle_t *archive_handle) FAST_FUNC; |
| 114 | extern char get_header_tar(archive_handle_t *archive_handle) FAST_FUNC; |
Denis Vlasenko | e9ad84d | 2008-08-05 13:10:34 +0000 | [diff] [blame] | 115 | extern char get_header_tar_gz(archive_handle_t *archive_handle) FAST_FUNC; |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 116 | extern char get_header_tar_bz2(archive_handle_t *archive_handle) FAST_FUNC; |
| 117 | extern char get_header_tar_lzma(archive_handle_t *archive_handle) FAST_FUNC; |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 118 | |
Denys Vlasenko | 0a130d5 | 2009-08-28 21:09:51 +0200 | [diff] [blame] | 119 | extern void seek_by_jump(int fd, off_t amount) FAST_FUNC; |
| 120 | extern void seek_by_read(int fd, off_t amount) FAST_FUNC; |
Glenn L McGrath | 60bce49 | 2002-11-03 07:28:38 +0000 | [diff] [blame] | 121 | |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 122 | extern void data_align(archive_handle_t *archive_handle, unsigned boundary) FAST_FUNC; |
| 123 | extern const llist_t *find_list_entry(const llist_t *list, const char *filename) FAST_FUNC; |
| 124 | extern const llist_t *find_list_entry2(const llist_t *list, const char *filename) FAST_FUNC; |
Glenn L McGrath | 237ae42 | 2002-11-03 14:05:15 +0000 | [diff] [blame] | 125 | |
Denis Vlasenko | c6758a0 | 2007-04-10 21:40:19 +0000 | [diff] [blame] | 126 | /* A bit of bunzip2 internals are exposed for compressed help support: */ |
| 127 | typedef struct bunzip_data bunzip_data; |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 128 | int start_bunzip(bunzip_data **bdp, int in_fd, const unsigned char *inbuf, int len) FAST_FUNC; |
| 129 | int read_bunzip(bunzip_data *bd, char *outbuf, int len) FAST_FUNC; |
| 130 | void dealloc_bunzip(bunzip_data *bd) FAST_FUNC; |
Denis Vlasenko | cd42cb8 | 2007-01-05 23:56:53 +0000 | [diff] [blame] | 131 | |
| 132 | typedef struct inflate_unzip_result { |
| 133 | off_t bytes_out; |
| 134 | uint32_t crc; |
| 135 | } inflate_unzip_result; |
| 136 | |
Denis Vlasenko | 5e34ff2 | 2009-04-21 11:09:40 +0000 | [diff] [blame] | 137 | IF_DESKTOP(long long) int inflate_unzip(inflate_unzip_result *res, off_t compr_size, int src_fd, int dst_fd) FAST_FUNC; |
Denis Vlasenko | e9ad84d | 2008-08-05 13:10:34 +0000 | [diff] [blame] | 138 | /* lzma unpacker takes .lzma stream from offset 0 */ |
Denis Vlasenko | 5e34ff2 | 2009-04-21 11:09:40 +0000 | [diff] [blame] | 139 | IF_DESKTOP(long long) int unpack_lzma_stream(int src_fd, int dst_fd) FAST_FUNC; |
Denis Vlasenko | e9ad84d | 2008-08-05 13:10:34 +0000 | [diff] [blame] | 140 | /* the rest wants 2 first bytes already skipped by the caller */ |
Denis Vlasenko | 5e34ff2 | 2009-04-21 11:09:40 +0000 | [diff] [blame] | 141 | IF_DESKTOP(long long) int unpack_bz2_stream(int src_fd, int dst_fd) FAST_FUNC; |
| 142 | IF_DESKTOP(long long) int unpack_gz_stream(int src_fd, int dst_fd) FAST_FUNC; |
| 143 | IF_DESKTOP(long long) int unpack_gz_stream_with_info(int src_fd, int dst_fd, unpack_info_t *info) FAST_FUNC; |
| 144 | IF_DESKTOP(long long) int unpack_Z_stream(int fd_in, int fd_out) FAST_FUNC; |
Denis Vlasenko | e9ad84d | 2008-08-05 13:10:34 +0000 | [diff] [blame] | 145 | /* wrapper which checks first two bytes to be "BZ" */ |
Denis Vlasenko | 5e34ff2 | 2009-04-21 11:09:40 +0000 | [diff] [blame] | 146 | IF_DESKTOP(long long) int unpack_bz2_stream_prime(int src_fd, int dst_fd) FAST_FUNC; |
Glenn L McGrath | 237ae42 | 2002-11-03 14:05:15 +0000 | [diff] [blame] | 147 | |
Denis Vlasenko | 1a9e9bd | 2008-11-01 12:54:56 +0000 | [diff] [blame] | 148 | int bbunpack(char **argv, |
| 149 | char* (*make_new_name)(char *filename), |
Denis Vlasenko | 5e34ff2 | 2009-04-21 11:09:40 +0000 | [diff] [blame] | 150 | IF_DESKTOP(long long) int (*unpacker)(unpack_info_t *info)) FAST_FUNC; |
Denis Vlasenko | 1a9e9bd | 2008-11-01 12:54:56 +0000 | [diff] [blame] | 151 | |
Denis Vlasenko | 211f7f8 | 2007-09-05 11:48:32 +0000 | [diff] [blame] | 152 | #if BB_MMU |
Denis Vlasenko | e9ad84d | 2008-08-05 13:10:34 +0000 | [diff] [blame] | 153 | void open_transformer(int fd, |
Denis Vlasenko | 5e34ff2 | 2009-04-21 11:09:40 +0000 | [diff] [blame] | 154 | IF_DESKTOP(long long) int FAST_FUNC (*transformer)(int src_fd, int dst_fd)) FAST_FUNC; |
Denis Vlasenko | b605272 | 2008-07-10 17:43:01 +0000 | [diff] [blame] | 155 | #define open_transformer(fd, transformer, transform_prog) open_transformer(fd, transformer) |
Denis Vlasenko | 211f7f8 | 2007-09-05 11:48:32 +0000 | [diff] [blame] | 156 | #else |
Denis Vlasenko | e9ad84d | 2008-08-05 13:10:34 +0000 | [diff] [blame] | 157 | void open_transformer(int src_fd, const char *transform_prog) FAST_FUNC; |
Denis Vlasenko | b605272 | 2008-07-10 17:43:01 +0000 | [diff] [blame] | 158 | #define open_transformer(fd, transformer, transform_prog) open_transformer(fd, transform_prog) |
Denis Vlasenko | 211f7f8 | 2007-09-05 11:48:32 +0000 | [diff] [blame] | 159 | #endif |
Glenn L McGrath | 5699b85 | 2003-11-15 23:19:05 +0000 | [diff] [blame] | 160 | |
Denis Vlasenko | f81e8db | 2009-04-09 12:35:13 +0000 | [diff] [blame] | 161 | POP_SAVED_FUNCTION_VISIBILITY |
Denis Vlasenko | 98636eb | 2008-05-09 17:59:34 +0000 | [diff] [blame] | 162 | |
Glenn L McGrath | 7ca04f3 | 2002-09-25 02:47:48 +0000 | [diff] [blame] | 163 | #endif |