X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Ftar.c;h=60cd306d7ffdbb132dd17135276d0e6a191d3360;hb=e7db56c0ef5db2000c79fc87c96d669c51c6b2e9;hp=b127109e2e71c999195dc53b574d34204bf4ef20;hpb=5dee0c13488a6d11deec296c225f9e02a618354a;p=chaz%2Ftar diff --git a/src/tar.c b/src/tar.c index b127109..60cd306 100644 --- a/src/tar.c +++ b/src/tar.c @@ -343,10 +343,10 @@ static struct argp_option options[] = { {"numeric-owner", NUMERIC_OWNER_OPTION, 0, 0, N_("always use numbers for user/group names"), 31 }, {"preserve-permissions", 'p', 0, 0, - N_("extract permissions information"), 31 }, + N_("extract information about file permissions (default for superuser)"), 31 }, {"same-permissions", 0, 0, OPTION_ALIAS, NULL, 31 }, {"no-same-permissions", NO_SAME_PERMISSIONS_OPTION, 0, 0, - N_("do not extract permissions information"), 31 }, + N_("apply the user's umask when extracting permissions from the archive (default for ordinary users)"), 31 }, {"preserve-order", 's', 0, 0, N_("sort names to extract to match archive"), 31 }, {"same-order", 0, 0, OPTION_ALIAS, NULL, 31 }, @@ -617,9 +617,9 @@ parse_opt(int key, char *arg, struct argp_state *state) switch (key) { - case 1: + case ARGP_KEY_ARG: /* File name or non-parsed option, because of ARGP_IN_ORDER */ - name_add (optarg); + name_add (arg); args->input_files++; break; @@ -1417,7 +1417,7 @@ decode_options (int argc, char **argv) else { /* UNIX98 compatibility */ - same_owner_option = 1; + same_owner_option = -1; } } @@ -1464,6 +1464,18 @@ decode_options (int argc, char **argv) _("--occurrence cannot be used in the requested operation mode"))); } + if (seekable_archive && subcommand_option == DELETE_SUBCOMMAND) + { + /* The current code in delete.c is based on the assumption that + skip_member() reads all data from the archive. So, we should + make sure it won't use seeks. On the other hand, the same code + depends on the ability to backspace a record in the archive, + so setting seekable_archive to false is technically incorrect. + However, it is tested only in skip_member(), so it's not a + problem. */ + seekable_archive = false; + } + if (archive_names == 0) { /* If no archive file name given, try TAPE from the environment, or @@ -1609,6 +1621,7 @@ main (int argc, char **argv) { set_start_time (); program_name = argv[0]; + setlocale (LC_ALL, ""); bindtextdomain (PACKAGE, LOCALEDIR); textdomain (PACKAGE);