diff options
author | Glenn L McGrath | 2001-04-16 04:52:19 +0000 |
---|---|---|
committer | Glenn L McGrath | 2001-04-16 04:52:19 +0000 |
commit | 33431ebb9ace3fba76138198596f8155c2e14354 (patch) | |
tree | 514459eccbc4927b00c0493badb7f12575c9147d /libbb/deb_extract.c | |
parent | 3136904ff69b3f67096dbaf2afd9ac77256c4bae (diff) | |
download | busybox-33431ebb9ace3fba76138198596f8155c2e14354.zip busybox-33431ebb9ace3fba76138198596f8155c2e14354.tar.gz |
dpkg improvements, use full package struct, avoid extracting to tmp dir, rename variable.
deb_extract, untar and dpkg_deb modified to make the above possible
Diffstat (limited to 'libbb/deb_extract.c')
-rw-r--r-- | libbb/deb_extract.c | 33 |
1 files changed, 15 insertions, 18 deletions
diff --git a/libbb/deb_extract.c b/libbb/deb_extract.c index b95dfa4..36cebfa 100644 --- a/libbb/deb_extract.c +++ b/libbb/deb_extract.c @@ -34,12 +34,13 @@ * The contents of argument depend on the value of function. * It is either a dir name or a control file or field name(see dpkg_deb.c) */ -extern int deb_extract(const char *package_filename, int function, char *argument) +extern char *deb_extract(const char *package_filename, const int function, const char *argument, const char *argument2) { FILE *deb_file, *uncompressed_file; ar_headers_t *headers = NULL; char *ared_file = NULL; + char *output_buffer = NULL; int gunzip_pid; switch (function) { @@ -61,7 +62,7 @@ extern int deb_extract(const char *package_filename, int function, char *argumen /* get a linked list of all ar entries */ if ((headers = get_ar_headers(deb_file)) == NULL) { error_msg("Couldnt get ar headers\n"); - return(EXIT_FAILURE); + return(NULL); } /* seek to the start of the .tar.gz file within the ar file*/ @@ -75,27 +76,23 @@ extern int deb_extract(const char *package_filename, int function, char *argumen if (function & extract_fsys_tarfile) { copy_file_chunk(uncompressed_file, stdout, -1); } else { - char *output_buffer = NULL; - output_buffer = untar(uncompressed_file, stdout, function, argument); - if (function & extract_field) { - char *field = NULL; - int field_length = 0; - int field_start = 0; - while ((field = read_package_field(&output_buffer[field_start])) != NULL) { - field_length = strlen(field); - field_start += (field_length + 1); - if (strstr(field, argument) == field) { - printf("%s\n", field + strlen(argument) + 2); - } - free(field); - } + FILE *output; + + if (function & extract_contents_to_file) { + output = wfopen(argument, "w"); + } else { + output = stdout; } - } + output_buffer = untar(uncompressed_file, output, function, argument, argument2); + if (output != stdout) { + fclose(output); + } + } gz_close(gunzip_pid); fclose(deb_file); fclose(uncompressed_file); free(ared_file); - return(EXIT_SUCCESS); + return(output_buffer); }
\ No newline at end of file |