From 2b1effdbbccf8f16ae3fed93d3178759a44d33d9 Mon Sep 17 00:00:00 2001 From: Matt Kraai Date: Thu, 20 Dec 2001 22:09:31 +0000 Subject: [PATCH] Write files when extracting an archive from standard input. --- archival/tar.c | 24 +++++++------------ .../tar/tar-extracts-from-standard-input | 5 ++++ 2 files changed, 13 insertions(+), 16 deletions(-) create mode 100644 testsuite/tar/tar-extracts-from-standard-input diff --git a/archival/tar.c b/archival/tar.c index 9792f6b9d..8720144b2 100644 --- a/archival/tar.c +++ b/archival/tar.c @@ -459,7 +459,7 @@ static int writeTarFile(const char* tarName, int verboseFlag, char **argv, error_msg_and_die("Cowardly refusing to create an empty archive"); /* Open the tar file for writing. */ - if (tarName == NULL || !strcmp(tarName, "-")) + if (tarName == NULL) tbInfo.tarFd = fileno(stdout); else tbInfo.tarFd = open (tarName, O_WRONLY | O_CREAT | O_TRUNC, 0644); @@ -573,14 +573,12 @@ char **list_and_not_list(char **include_list, char **exclude_list) int tar_main(int argc, char **argv) { enum untar_funct_e { - /* These are optional */ - untar_from_file = 1, - untar_from_stdin = 2, - untar_unzip = 4, + /* This is optional */ + untar_unzip = 1, /* Require one and only one of these */ - untar_list = 8, - untar_create = 16, - untar_extract = 32 + untar_list = 2, + untar_create = 4, + untar_extract = 8 }; FILE *src_stream = NULL; @@ -649,10 +647,8 @@ int tar_main(int argc, char **argv) break; case 'f': // archive filename if (strcmp(optarg, "-") == 0) { - // Untar from stdin to stdout - untar_funct |= untar_from_stdin; + src_filename = NULL; } else { - untar_funct |= untar_from_file; src_filename = xstrdup(optarg); } break; @@ -694,17 +690,13 @@ int tar_main(int argc, char **argv) optind++; } - if (src_filename == NULL) { - extract_function |= extract_to_stdout; - } - if (extract_function & (extract_list | extract_all_to_fs)) { if (dst_prefix == NULL) { dst_prefix = xstrdup("./"); } /* Setup the source of the tar data */ - if (untar_funct & untar_from_file) { + if (src_filename != NULL) { src_stream = xfopen(src_filename, "r"); } else { src_stream = stdin; diff --git a/testsuite/tar/tar-extracts-from-standard-input b/testsuite/tar/tar-extracts-from-standard-input new file mode 100644 index 000000000..a30e9f0b9 --- /dev/null +++ b/testsuite/tar/tar-extracts-from-standard-input @@ -0,0 +1,5 @@ +touch foo +tar cf foo.tar foo +rm foo +cat foo.tar | busybox tar x +test -f foo -- 2.25.1