last_patch91 from vodz to convert tar to use bb_getopt_ulflags

This commit is contained in:
Eric Andersen 2003-06-26 09:07:59 +00:00
parent a3bb3e6e0b
commit 27cb6846d7

View File

@ -584,22 +584,42 @@ static inline int writeTarFile(const char *tarName, const int verboseFlag,
#endif /* tar_create */ #endif /* tar_create */
#ifdef CONFIG_FEATURE_TAR_EXCLUDE #ifdef CONFIG_FEATURE_TAR_EXCLUDE
static llist_t *append_file_list_to_list(const char *filename, llist_t *list) static llist_t *append_file_list_to_list(llist_t *list)
{ {
FILE *src_stream = bb_xfopen(filename, "r"); FILE *src_stream;
llist_t *cur = list;
llist_t *tmp;
char *line; char *line;
llist_t *newlist = NULL;
while(cur) {
src_stream = bb_xfopen(cur->data, "r");
tmp = cur;
cur = cur->link;
free(tmp);
while((line = bb_get_chomped_line_from_file(src_stream)) != NULL) { while((line = bb_get_chomped_line_from_file(src_stream)) != NULL) {
list = llist_add_to(list, line); newlist = llist_add_to(newlist, line);
} }
fclose(src_stream); fclose(src_stream);
}
return (list); return newlist;
} }
#endif #endif
static const char tar_options[]="ctxjT:X:C:f:Opvz";
#define CTX_CREATE 1 #define CTX_CREATE 1
#define CTX_TEST 2 #define CTX_TEST 2
#define CTX_EXTRACT 4 #define CTX_EXTRACT 4
#define TAR_OPT_BZIP2 8
#define TAR_OPT_INCLUDE 16
#define TAR_OPT_EXCLUDE 32
#define TAR_OPT_BASEDIR 64
#define TAR_OPT_ARNAME 128
#define TAR_OPT_2STDOUT 256
#define TAR_OPT_P 512
#define TAR_OPT_VERBOSE 1024
#define TAR_OPT_GZIP 2048
int tar_main(int argc, char **argv) int tar_main(int argc, char **argv)
{ {
@ -616,9 +636,9 @@ int tar_main(int argc, char **argv)
/* Prepend '-' to the first argument if required */ /* Prepend '-' to the first argument if required */
if (argv[1][0] != '-') { if (argv[1][0] != '-') {
char *tmp = xmalloc(strlen(argv[1]) + 2); char *tmp;
tmp[0] = '-';
strcpy(tmp + 1, argv[1]); bb_xasprintf(&tmp, "-%s", argv[1]);
argv[1] = tmp; argv[1] = tmp;
} }
@ -626,80 +646,56 @@ int tar_main(int argc, char **argv)
tar_handle = init_handle(); tar_handle = init_handle();
tar_handle->flags = ARCHIVE_CREATE_LEADING_DIRS | ARCHIVE_PRESERVE_DATE; tar_handle->flags = ARCHIVE_CREATE_LEADING_DIRS | ARCHIVE_PRESERVE_DATE;
while ((opt = getopt(argc, argv, "cjtxT:X:C:f:Opvz")) != -1) { bb_opt_complementaly = "c~tx:t~cx:x~ct:X*";
switch (opt) { opt = bb_getopt_ulflags(argc, argv, tar_options,
/* One and only one of these is required */ NULL, /* T: arg is ignored by default
#ifdef CONFIG_FEATURE_TAR_CREATE a list is an include list */
case 'c': &(tar_handle->reject),
ctx_flag |= CTX_CREATE; &base_dir, /* Change to dir <optarg> */
break; &tar_filename); /* archive filename */
#endif /* Check one and only one context option was given */
case 't': if(opt & 0x80000000UL)
ctx_flag |= CTX_TEST; bb_show_usage();
ctx_flag = opt & (CTX_CREATE | CTX_TEST | CTX_EXTRACT);
if(ctx_flag & CTX_TEST) {
if ((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)) {
tar_handle->action_header = header_verbose_list; tar_handle->action_header = header_verbose_list;
} else { } else {
tar_handle->action_header = header_list; tar_handle->action_header = header_list;
} }
break; }
case 'x': if(ctx_flag & CTX_EXTRACT) {
ctx_flag |= CTX_EXTRACT; if (tar_handle->action_data != data_extract_to_stdout)
if (tar_handle->action_data != data_extract_to_stdout) {
tar_handle->action_data = data_extract_all; tar_handle->action_data = data_extract_all;
} }
break; if(opt & TAR_OPT_2STDOUT) {
/* To stdout */
/* These are optional */
/* Exclude or Include files listed in <filename> */
#ifdef CONFIG_FEATURE_TAR_EXCLUDE
case 'X':
tar_handle->reject =
append_file_list_to_list(optarg, tar_handle->reject);
break;
#endif
case 'T':
/* by default a list is an include list */
break;
case 'C': /* Change to dir <optarg> */
base_dir = optarg;
break;
case 'f': /* archive filename */
tar_filename = optarg;
break;
case 'O': /* To stdout */
tar_handle->action_data = data_extract_to_stdout; tar_handle->action_data = data_extract_to_stdout;
break; }
case 'p': if(opt & TAR_OPT_VERBOSE) {
break;
case 'v':
if ((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)) {
tar_handle->action_header = header_verbose_list; tar_handle->action_header = header_verbose_list;
} else { } else {
tar_handle->action_header = header_list; tar_handle->action_header = header_list;
} }
break; }
#ifdef CONFIG_FEATURE_TAR_GZIP #ifdef CONFIG_FEATURE_TAR_GZIP
case 'z': if(opt & TAR_OPT_GZIP) {
get_header_ptr = get_header_tar_gz; get_header_ptr = get_header_tar_gz;
break; }
#endif #endif
#ifdef CONFIG_FEATURE_TAR_BZIP2 #ifdef CONFIG_FEATURE_TAR_BZIP2
case 'j': if(opt & TAR_OPT_GZIP) {
get_header_ptr = get_header_tar_bz2; get_header_ptr = get_header_tar_bz2;
break; }
#endif #endif
default: #ifdef CONFIG_FEATURE_TAR_EXCLUDE
bb_show_usage(); if(opt & TAR_OPT_EXCLUDE) {
tar_handle->reject = append_file_list_to_list(tar_handle->reject);
} }
} #endif
/* Check one and only one context option was given */
if ((ctx_flag != CTX_CREATE) && (ctx_flag != CTX_TEST) && (ctx_flag != CTX_EXTRACT)) {
bb_show_usage();
}
/* Check if we are reading from stdin */ /* Check if we are reading from stdin */
if ((argv[optind]) && (*argv[optind] == '-')) { if ((argv[optind]) && (*argv[optind] == '-')) {
/* Default is to read from stdin, so just skip to next arg */ /* Default is to read from stdin, so just skip to next arg */