X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=archival%2Ftar.c;h=4e763a404476118ab884f87971e2df5ecc81dcc4;hb=56f16b42c93af18fbb984e8d6384c03e5405e3ae;hp=bee24d84ba2bcdf30f5d703c289c0c50df491f9c;hpb=eba86e2adbd562c8cb25f7f1377aa9180db2b614;p=oweals%2Fbusybox.git diff --git a/archival/tar.c b/archival/tar.c index bee24d84b..4e763a404 100644 --- a/archival/tar.c +++ b/archival/tar.c @@ -594,8 +594,27 @@ static llist_t *append_file_list_to_list(llist_t *list) } #endif +#ifdef CONFIG_FEATURE_TAR_COMPRESS +static char get_header_tar_Z(archive_handle_t *archive_handle) +{ + /* Cant lseek over pipe's */ + archive_handle->seek = seek_by_char; + + /* do the decompression, and cleanup */ + if ((bb_xread_char(archive_handle->src_fd) != 0x1f) || (bb_xread_char(archive_handle->src_fd) != 0x9d)) { + bb_error_msg_and_die("Invalid magic"); + } + + archive_handle->src_fd = open_transformer(archive_handle->src_fd, uncompress); + archive_handle->offset = 0; + while (get_header_tar(archive_handle) == EXIT_SUCCESS); + + /* Can only do one file at a time */ + return(EXIT_FAILURE); +} +#endif -static const char tar_options[]="ctxjT:X:C:f:Opvz"; +static const char tar_options[]="ctxjT:X:C:f:OpvzkZ"; #define CTX_CREATE 1 #define CTX_TEST 2 @@ -609,6 +628,8 @@ static const char tar_options[]="ctxjT:X:C:f:Opvz"; #define TAR_OPT_P 512 #define TAR_OPT_VERBOSE 1024 #define TAR_OPT_GZIP 2048 +#define TAR_OPT_KEEP_OLD 4096 +#define TAR_OPT_UNCOMPRESS 8192 int tar_main(int argc, char **argv) { @@ -633,7 +654,7 @@ int tar_main(int argc, char **argv) /* Initialise default values */ tar_handle = init_handle(); - tar_handle->flags = ARCHIVE_CREATE_LEADING_DIRS | ARCHIVE_PRESERVE_DATE; + tar_handle->flags = ARCHIVE_CREATE_LEADING_DIRS | ARCHIVE_PRESERVE_DATE | ARCHIVE_EXTRACT_UNCONDITIONAL; bb_opt_complementaly = "c~tx:t~cx:x~ct:X*"; opt = bb_getopt_ulflags(argc, argv, tar_options, @@ -647,29 +668,32 @@ int tar_main(int argc, char **argv) bb_show_usage(); ctx_flag = opt & (CTX_CREATE | CTX_TEST | CTX_EXTRACT); if(ctx_flag & CTX_TEST) { - if ((tar_handle->action_header == header_list) || - (tar_handle->action_header == header_verbose_list)) { - tar_handle->action_header = header_verbose_list; - } else { - tar_handle->action_header = header_list; - } + if ((tar_handle->action_header == header_list) || + (tar_handle->action_header == header_verbose_list)) { + tar_handle->action_header = header_verbose_list; + } else { + tar_handle->action_header = header_list; + } } if(ctx_flag & CTX_EXTRACT) { if (tar_handle->action_data != data_extract_to_stdout) - tar_handle->action_data = data_extract_all; - } + tar_handle->action_data = data_extract_all; + } if(opt & TAR_OPT_2STDOUT) { /* To stdout */ - tar_handle->action_data = data_extract_to_stdout; + tar_handle->action_data = data_extract_to_stdout; } if(opt & TAR_OPT_VERBOSE) { - if ((tar_handle->action_header == header_list) || - (tar_handle->action_header == header_verbose_list)) - { - tar_handle->action_header = header_verbose_list; - } else { - tar_handle->action_header = header_list; - } + if ((tar_handle->action_header == header_list) || + (tar_handle->action_header == header_verbose_list)) + { + tar_handle->action_header = header_verbose_list; + } else { + tar_handle->action_header = header_list; + } + } + if (opt & TAR_OPT_KEEP_OLD) { + tar_handle->flags &= ~ARCHIVE_EXTRACT_UNCONDITIONAL; } if(opt & TAR_OPT_GZIP) { @@ -681,7 +705,14 @@ int tar_main(int argc, char **argv) } if(opt & TAR_OPT_BZIP2) { #ifdef CONFIG_FEATURE_TAR_BZIP2 - get_header_ptr = get_header_tar_bz2; + get_header_ptr = get_header_tar_bz2; +#else + bb_show_usage(); +#endif + } + if(opt & TAR_OPT_UNCOMPRESS) { +#ifdef CONFIG_FEATURE_TAR_COMPRESS + get_header_ptr = get_header_tar_Z; #else bb_show_usage(); #endif