summaryrefslogtreecommitdiff
path: root/libbb/deb_extract.c
diff options
context:
space:
mode:
authorGlenn L McGrath2001-04-16 04:52:19 +0000
committerGlenn L McGrath2001-04-16 04:52:19 +0000
commit33431ebb9ace3fba76138198596f8155c2e14354 (patch)
tree514459eccbc4927b00c0493badb7f12575c9147d /libbb/deb_extract.c
parent3136904ff69b3f67096dbaf2afd9ac77256c4bae (diff)
downloadbusybox-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.c33
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