]> Dogcows Code - chaz/tar/blob - src/tar.c
(LDADD): Add LIBICONV
[chaz/tar] / src / tar.c
1 /* A tar (tape archiver) program.
2
3 Copyright (C) 1988, 1992, 1993, 1994, 1995, 1996, 1997, 1999, 2000,
4 2001, 2003, 2004 Free Software Foundation, Inc.
5
6 Written by John Gilmore, starting 1985-08-25.
7
8 This program is free software; you can redistribute it and/or modify it
9 under the terms of the GNU General Public License as published by the
10 Free Software Foundation; either version 2, or (at your option) any later
11 version.
12
13 This program is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
16 Public License for more details.
17
18 You should have received a copy of the GNU General Public License along
19 with this program; if not, write to the Free Software Foundation, Inc.,
20 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
21
22 #include <system.h>
23
24 #include <fnmatch.h>
25 #include <argp.h>
26
27 #include <signal.h>
28 #if ! defined SIGCHLD && defined SIGCLD
29 # define SIGCHLD SIGCLD
30 #endif
31
32 /* The following causes "common.h" to produce definitions of all the global
33 variables, rather than just "extern" declarations of them. GNU tar does
34 depend on the system loader to preset all GLOBAL variables to neutral (or
35 zero) values; explicit initialization is usually not done. */
36 #define GLOBAL
37 #include "common.h"
38
39 #include <getdate.h>
40 #include <localedir.h>
41 #include <rmt.h>
42 #include <prepargs.h>
43 #include <quotearg.h>
44 #include <xstrtol.h>
45
46 /* Local declarations. */
47
48 #ifndef DEFAULT_ARCHIVE_FORMAT
49 # define DEFAULT_ARCHIVE_FORMAT GNU_FORMAT
50 #endif
51
52 #ifndef DEFAULT_ARCHIVE
53 # define DEFAULT_ARCHIVE "tar.out"
54 #endif
55
56 #ifndef DEFAULT_BLOCKING
57 # define DEFAULT_BLOCKING 20
58 #endif
59
60 \f
61 /* Miscellaneous. */
62
63 /* Name of option using stdin. */
64 static const char *stdin_used_by;
65
66 /* Doesn't return if stdin already requested. */
67 void
68 request_stdin (const char *option)
69 {
70 if (stdin_used_by)
71 USAGE_ERROR ((0, 0, _("Options `-%s' and `-%s' both want standard input"),
72 stdin_used_by, option));
73
74 stdin_used_by = option;
75 }
76
77 /* Returns true if and only if the user typed 'y' or 'Y'. */
78 int
79 confirm (const char *message_action, const char *message_name)
80 {
81 static FILE *confirm_file;
82 static int confirm_file_EOF;
83
84 if (!confirm_file)
85 {
86 if (archive == 0 || stdin_used_by)
87 {
88 confirm_file = fopen (TTY_NAME, "r");
89 if (! confirm_file)
90 open_fatal (TTY_NAME);
91 }
92 else
93 {
94 request_stdin ("-w");
95 confirm_file = stdin;
96 }
97 }
98
99 fprintf (stdlis, "%s %s?", message_action, quote (message_name));
100 fflush (stdlis);
101
102 {
103 int reply = confirm_file_EOF ? EOF : getc (confirm_file);
104 int character;
105
106 for (character = reply;
107 character != '\n';
108 character = getc (confirm_file))
109 if (character == EOF)
110 {
111 confirm_file_EOF = 1;
112 fputc ('\n', stdlis);
113 fflush (stdlis);
114 break;
115 }
116 return reply == 'y' || reply == 'Y';
117 }
118 }
119
120 static struct fmttab {
121 char const *name;
122 enum archive_format fmt;
123 } const fmttab[] = {
124 { "v7", V7_FORMAT },
125 { "oldgnu", OLDGNU_FORMAT },
126 { "ustar", USTAR_FORMAT },
127 { "posix", POSIX_FORMAT },
128 #if 0 /* not fully supported yet */
129 { "star", STAR_FORMAT },
130 #endif
131 { "gnu", GNU_FORMAT },
132 { "pax", POSIX_FORMAT }, /* An alias for posix */
133 { NULL, 0 }
134 };
135
136 static void
137 set_archive_format (char const *name)
138 {
139 struct fmttab const *p;
140
141 for (p = fmttab; strcmp (p->name, name) != 0; )
142 if (! (++p)->name)
143 USAGE_ERROR ((0, 0, _("%s: Invalid archive format"),
144 quotearg_colon (name)));
145
146 archive_format = p->fmt;
147 }
148
149 static const char *
150 archive_format_string (enum archive_format fmt)
151 {
152 struct fmttab const *p;
153
154 for (p = fmttab; p->name; p++)
155 if (p->fmt == fmt)
156 return p->name;
157 return "unknown?";
158 }
159
160 #define FORMAT_MASK(n) (1<<(n))
161
162 static void
163 assert_format(unsigned fmt_mask)
164 {
165 if ((FORMAT_MASK(archive_format) & fmt_mask) == 0)
166 USAGE_ERROR ((0, 0,
167 _("GNU features wanted on incompatible archive format")));
168 }
169
170
171 \f
172 /* Options. */
173
174 /* For long options that unconditionally set a single flag, we have getopt
175 do it. For the others, we share the code for the equivalent short
176 named option, the name of which is stored in the otherwise-unused `val'
177 field of the `struct option'; for long options that have no equivalent
178 short option, we use non-characters as pseudo short options,
179 starting at CHAR_MAX + 1 and going upwards. */
180
181 enum
182 {
183 ANCHORED_OPTION = CHAR_MAX + 1,
184 ATIME_PRESERVE_OPTION,
185 BACKUP_OPTION,
186 CHECKPOINT_OPTION,
187 CHECK_LINKS_OPTION,
188 DELETE_OPTION,
189 EXCLUDE_OPTION,
190 EXCLUDE_CACHES_OPTION,
191 FORCE_LOCAL_OPTION,
192 GROUP_OPTION,
193 IGNORE_CASE_OPTION,
194 IGNORE_FAILED_READ_OPTION,
195 INDEX_FILE_OPTION,
196 KEEP_NEWER_FILES_OPTION,
197 LICENSE_OPTION,
198 MODE_OPTION,
199 NEWER_MTIME_OPTION,
200 NO_ANCHORED_OPTION,
201 NO_IGNORE_CASE_OPTION,
202 NO_OVERWRITE_DIR_OPTION,
203 NO_RECURSION_OPTION,
204 NO_SAME_OWNER_OPTION,
205 NO_SAME_PERMISSIONS_OPTION,
206 NO_WILDCARDS_OPTION,
207 NO_WILDCARDS_MATCH_SLASH_OPTION,
208 NULL_OPTION,
209 NUMERIC_OWNER_OPTION,
210 OCCURRENCE_OPTION,
211 OLD_ARCHIVE_OPTION,
212 ONE_FILE_SYSTEM_OPTION,
213 OVERWRITE_OPTION,
214 OWNER_OPTION,
215 PAX_OPTION,
216 POSIX_OPTION,
217 PRESERVE_OPTION,
218 RECORD_SIZE_OPTION,
219 RECURSION_OPTION,
220 RECURSIVE_UNLINK_OPTION,
221 REMOVE_FILES_OPTION,
222 RMT_COMMAND_OPTION,
223 RSH_COMMAND_OPTION,
224 SAME_OWNER_OPTION,
225 SHOW_DEFAULTS_OPTION,
226 SHOW_OMITTED_DIRS_OPTION,
227 STRIP_COMPONENTS_OPTION,
228 SUFFIX_OPTION,
229 TOTALS_OPTION,
230 USAGE_OPTION,
231 USE_COMPRESS_PROGRAM_OPTION,
232 UTC_OPTION,
233 VERSION_OPTION,
234 VOLNO_FILE_OPTION,
235 WILDCARDS_OPTION,
236 WILDCARDS_MATCH_SLASH_OPTION
237 };
238
239 const char *argp_program_version = "tar (" PACKAGE_NAME ") " VERSION;
240 const char *argp_program_bug_address = "<" PACKAGE_BUGREPORT ">";
241 static char doc[] = N_("GNU `tar' saves many files together into a single tape or disk archive, and can restore individual files from the archive.\n\
242 \n\
243 Examples:\n\
244 tar -cf archive.tar foo bar # Create archive.tar from files foo and bar.\n\
245 tar -tvf archive.tar # List all files in archive.tar verbosely.\n\
246 tar -xf archive.tar # Extract all files from archive.tar.\n\
247 \vThe backup suffix is `~', unless set with --suffix or SIMPLE_BACKUP_SUFFIX.\n\
248 The version control may be set with --backup or VERSION_CONTROL, values are:\n\n\
249 t, numbered make numbered backups\n\
250 nil, existing numbered if numbered backups exist, simple otherwise\n\
251 never, simple always make simple backups\n");
252
253
254 /* NOTE:
255
256 Available option letters are DEIJQY and aeqy. Consider the following
257 assignments:
258
259 [For Solaris tar compatibility]
260 e exit immediately with a nonzero exit status if unexpected errors occur
261 E use extended headers (--format=posix)
262 [q alias for --occurrence=1 =/= this would better be used for quiet?]
263 [I same as T =/= will harm star compatibility]
264
265 y per-file gzip compression
266 Y per-block gzip compression */
267
268 static struct argp_option options[] = {
269 {NULL, 0, NULL, 0,
270 N_("Main operation mode:"), 0},
271
272 {"list", 't', 0, 0,
273 N_("list the contents of an archive"), 10 },
274 {"extract", 'x', 0, 0,
275 N_("extract files from an archive"), 10 },
276 {"get", 0, 0, OPTION_ALIAS, NULL, 0 },
277 {"create", 'c', 0, 0,
278 N_("create a new archive"), 10 },
279 {"diff", 'd', 0, 0,
280 N_("find differences between archive and file system"), 10 },
281 {"compare", 0, 0, OPTION_ALIAS, NULL, 10},
282 {"append", 'r', 0, 0,
283 N_("append files to the end of an archive"), 10 },
284 {"update", 'u', 0, 0,
285 N_("only append files newer than copy in archive"), 10 },
286 {"catenate", 'A', 0, 0,
287 N_("append tar files to an archive"), 10 },
288 {"concatenate", 0, 0, OPTION_ALIAS, NULL, 10},
289 {"delete", DELETE_OPTION, 0, 0,
290 N_("delete from the archive (not on mag tapes!)"), 10 },
291
292 {NULL, 0, NULL, 0,
293 N_("Operation modifiers:"), 20},
294
295 {"verify", 'W', 0, 0,
296 N_("attempt to verify the archive after writing it"), 21 },
297 {"remove-files", REMOVE_FILES_OPTION, 0, 0,
298 N_("remove files after adding them to the archive"), 21 },
299 {"keep-old-files", 'k', 0, 0,
300 N_("don't replace existing files when extracting"), 21 },
301 {"keep-newer-files", KEEP_NEWER_FILES_OPTION, 0, 0,
302 N_("don't replace existing files that are newer than their archive copies"), 21 },
303 {"no-overwrite-dir", NO_OVERWRITE_DIR_OPTION, 0, 0,
304 N_("preserve metadata of existing directories"), 21 },
305 {"overwrite", OVERWRITE_OPTION, 0, 0,
306 N_("overwrite existing files when extracting"), 21 },
307 {"unlink-first", 'U', 0, 0,
308 N_("remove each file prior to extracting over it"), 21 },
309 {"recursive-unlink", RECURSIVE_UNLINK_OPTION, 0, 0,
310 N_("empty hierarchies prior to extracting directory"), 21 },
311 {"sparse", 'S', 0, 0,
312 N_("handle sparse files efficiently"), 21 },
313 {"to-stdout", 'O', 0, 0,
314 N_("extract files to standard output"), 21 },
315 {"incremental", 'G', 0, 0,
316 N_("handle old GNU-format incremental backup"), 21 },
317 {"listed-incremental", 'g', N_("FILE"), 0,
318 N_("handle new GNU-format incremental backup"), 21 },
319 {"ignore-failed-read", IGNORE_FAILED_READ_OPTION, 0, 0,
320 N_("do not exit with nonzero on unreadable files"), 21 },
321 {"occurrence", OCCURRENCE_OPTION, N_("NUMBER"), OPTION_ARG_OPTIONAL,
322 N_("process only the NUMth occurrence of each file in the archive. This option is valid only in conjunction with one of the subcommands --delete, --diff, --extract or --list and when a list of files is given either on the command line or via -T option. NUMBER defaults to 1."), 21 },
323 {"seek", 'n', NULL, 0,
324 N_("Archive is seekable"), 21 },
325
326 {NULL, 0, NULL, 0,
327 N_("Handling of file attributes:"), 30 },
328
329 {"owner", OWNER_OPTION, N_("NAME"), 0,
330 N_("force NAME as owner for added files"), 31 },
331 {"group", GROUP_OPTION, N_("NAME"), 0,
332 N_("force NAME as group for added files"), 31 },
333 {"mode", MODE_OPTION, N_("CHANGES"), 0,
334 N_("force (symbolic) mode CHANGES for added files"), 31 },
335 {"atime-preserve", ATIME_PRESERVE_OPTION, 0, 0,
336 N_("don't change access times on dumped files"), 31 },
337 {"touch", 'm', 0, 0,
338 N_("don't extract file modified time"), 31 },
339 {"same-owner", SAME_OWNER_OPTION, 0, 0,
340 N_("try extracting files with the same ownership"), 31 },
341 {"no-same-owner", NO_SAME_OWNER_OPTION, 0, 0,
342 N_("extract files as yourself"), 31 },
343 {"numeric-owner", NUMERIC_OWNER_OPTION, 0, 0,
344 N_("always use numbers for user/group names"), 31 },
345 {"preserve-permissions", 'p', 0, 0,
346 N_("extract permissions information"), 31 },
347 {"same-permissions", 0, 0, OPTION_ALIAS, NULL, 31 },
348 {"no-same-permissions", NO_SAME_PERMISSIONS_OPTION, 0, 0,
349 N_("do not extract permissions information"), 31 },
350 {"preserve-order", 's', 0, 0,
351 N_("sort names to extract to match archive"), 31 },
352 {"same-order", 0, 0, OPTION_ALIAS, NULL, 31 },
353 {"preserve", PRESERVE_OPTION, 0, 0,
354 N_("same as both -p and -s"), 31 },
355
356 {NULL, 0, NULL, 0,
357 N_("Device selection and switching:"), 40 },
358
359 {"file", 'f', N_("ARCHIVE"), 0,
360 N_("use archive file or device ARCHIVE"), 41 },
361 {"force-local", FORCE_LOCAL_OPTION, 0, 0,
362 N_("archive file is local even if has a colon"), 41 },
363 {"rmt-command", RMT_COMMAND_OPTION, N_("COMMAND"), 0,
364 N_("use given rmt COMMAND instead of rmt"), 41 },
365 {"rsh-command", RSH_COMMAND_OPTION, N_("COMMAND"), 0,
366 N_("use remote COMMAND instead of rsh"), 41 },
367 #ifdef DEVICE_PREFIX
368 {"-[0-7][lmh]", 0, NULL, OPTION_DOC, /* It is OK, since `name' will never be
369 translated */
370 N_("specify drive and density"), 41 },
371 #endif
372 {NULL, '0', NULL, OPTION_HIDDEN, NULL, 41 },
373 {NULL, '1', NULL, OPTION_HIDDEN, NULL, 41 },
374 {NULL, '2', NULL, OPTION_HIDDEN, NULL, 41 },
375 {NULL, '3', NULL, OPTION_HIDDEN, NULL, 41 },
376 {NULL, '4', NULL, OPTION_HIDDEN, NULL, 41 },
377 {NULL, '5', NULL, OPTION_HIDDEN, NULL, 41 },
378 {NULL, '6', NULL, OPTION_HIDDEN, NULL, 41 },
379 {NULL, '7', NULL, OPTION_HIDDEN, NULL, 41 },
380 {NULL, '8', NULL, OPTION_HIDDEN, NULL, 41 },
381 {NULL, '9', NULL, OPTION_HIDDEN, NULL, 41 },
382
383 {"multi-volume", 'M', 0, 0,
384 N_("create/list/extract multi-volume archive"), 41 },
385 {"tape-length", 'L', N_("NUMBER"), 0,
386 N_("change tape after writing NUMBER x 1024 bytes"), 41 },
387 {"info-script", 'F', N_("NAME"), 0,
388 N_("run script at end of each tape (implies -M)"), 41 },
389 {"new-volume-script", 0, 0, OPTION_ALIAS, NULL, 41 },
390 {"volno-file", VOLNO_FILE_OPTION, N_("FILE"), 0,
391 N_("use/update the volume number in FILE"), 41 },
392
393 {NULL, 0, NULL, 0,
394 N_("Device blocking:"), 50 },
395
396 {"blocking-factor", 'b', N_("BLOCKS"), 0,
397 N_("BLOCKS x 512 bytes per record"), 51 },
398 {"record-size", RECORD_SIZE_OPTION, N_("NUMBER"), 0,
399 N_("SIZE bytes per record, multiple of 512"), 51 },
400 {"ignore-zeros", 'i', 0, 0,
401 N_("ignore zeroed blocks in archive (means EOF)"), 51 },
402 {"read-full-records", 'B', 0, 0,
403 N_("reblock as we read (for 4.2BSD pipes)"), 51 },
404
405 {NULL, 0, NULL, 0,
406 N_("Archive format selection:"), 60 },
407
408 {"format", 'H', N_("FORMAT"), 0,
409 N_("create archive of the given format."), 61 },
410
411 {NULL, 0, NULL, 0, N_("FORMAT is one of the following:"), 62 },
412 {" v7", 0, NULL, OPTION_DOC, N_("old V7 tar format"), 63},
413 {" oldgnu", 0, NULL, OPTION_DOC, N_("GNU format as per tar <= 1.12"), 63},
414 {" gnu", 0, NULL, OPTION_DOC, N_("GNU tar 1.13.x format"), 63},
415 {" ustar", 0, NULL, OPTION_DOC, N_("POSIX 1003.1-1988 (ustar) format"), 63 },
416 {" pax", 0, NULL, OPTION_DOC, N_("POSIX 1003.1-2001 (pax) format"), 63 },
417 {" posix", 0, NULL, OPTION_DOC, N_("Same as pax"), 63 },
418
419 {"old-archive", OLD_ARCHIVE_OPTION, 0, 0, /* FIXME */
420 N_("same as --format=v7"), 68 },
421 {"portability", 0, 0, OPTION_ALIAS, NULL, 68 },
422 {"posix", POSIX_OPTION, 0, 0,
423 N_("same as --format=posix"), 68 },
424 {"pax-option", PAX_OPTION, N_("keyword[[:]=value][,keyword[[:]=value], ...]"), 0,
425 N_("control pax keywords"), 68 },
426 {"label", 'V', N_("TEXT"), 0,
427 N_("create archive with volume name NAME. At list/extract time, use TEXT as a globbing pattern"), 68 },
428 {"bzip2", 'j', 0, 0,
429 N_("filter the archive through bzip2"), 68 },
430 {"gzip", 'z', 0, 0,
431 N_("filter the archive through gzip"), 68 },
432 {"gunzip", 0, 0, OPTION_ALIAS, NULL, 68 },
433 {"ungzip", 0, 0, OPTION_ALIAS, NULL, 68 },
434 {"compress", 'Z', 0, 0,
435 N_("filter the archive through compress"), 68 },
436 {"uncompress", 0, 0, OPTION_ALIAS, NULL, 68 },
437 {"use-compress-program", USE_COMPRESS_PROGRAM_OPTION, N_("PROG"), 0,
438 N_("filter through PROG (must accept -d)"), 68 },
439
440 {NULL, 0, NULL, 0,
441 N_("Local file selection:"), 70 },
442
443 {"directory", 'C', N_("DIR"), 0,
444 N_("change to directory DIR"), 71 },
445 {"files-from", 'T', N_("FILE-OF-NAMES"), 0,
446 N_("get names to extract or create from file NAME"), 71 },
447 {"null", NULL_OPTION, 0, 0,
448 N_("-T reads null-terminated names, disable -C"), 71 },
449 {"exclude", EXCLUDE_OPTION, N_("PATTERN"), 0,
450 N_("exclude files, given as a PATTERN"), 71 },
451 {"exclude-from", 'X', N_("FILE"), 0,
452 N_("exclude patterns listed in FILE"), 71 },
453 {"exclude-caches", EXCLUDE_CACHES_OPTION, 0, 0,
454 N_("exclude directories containing a cache tag"), 71 },
455 {"ignore-case", IGNORE_CASE_OPTION, 0, 0,
456 N_("exclusion ignores case"), 71 },
457 {"anchored", ANCHORED_OPTION, 0, 0,
458 N_("exclude patterns match file name start"), 71 },
459 {"no-anchored", NO_ANCHORED_OPTION, 0, 0,
460 N_("exclude patterns match after any / (default)"), 71 },
461 {"no-ignore-case", NO_IGNORE_CASE_OPTION, 0, 0,
462 N_("exclusion is case sensitive (default)"), 71 },
463 {"no-wildcards", NO_WILDCARDS_OPTION, 0, 0,
464 N_("exclude patterns are plain strings"), 71 },
465 {"no-wildcards-match-slash", NO_WILDCARDS_MATCH_SLASH_OPTION, 0, 0,
466 N_("exclude pattern wildcards do not match '/'"), 71 },
467 {"no-recursion", NO_RECURSION_OPTION, 0, 0,
468 N_("avoid descending automatically in directories"), 71 },
469 {"one-file-system", ONE_FILE_SYSTEM_OPTION, 0, 0,
470 N_("stay in local file system when creating archive"), 71 },
471 {NULL, 'l', 0, OPTION_HIDDEN, "", 71},
472 {"recursion", RECURSION_OPTION, 0, 0,
473 N_("recurse into directories (default)"), 71 },
474 {"absolute-names", 'P', 0, 0,
475 N_("don't strip leading `/'s from file names"), 71 },
476 {"dereference", 'h', 0, 0,
477 N_("dump instead the files symlinks point to"), 71 },
478 {"starting-file", 'K', N_("MEMBER-NAME"), 0,
479 N_("begin at member MEMBER-NAME in the archive"), 71 },
480 {"strip-components", STRIP_COMPONENTS_OPTION, N_("NUMBER"), 0,
481 N_("strip NUMBER leading components from file names"), 71 },
482 {"newer", 'N', N_("DATE-OR-FILE"), 0,
483 N_("only store files newer than DATE-OR-FILE"), 71 },
484 {"newer-mtime", NEWER_MTIME_OPTION, N_("DATE"), 0,
485 N_("compare date and time when data changed only"), 71 },
486 {"after-date", 'N', N_("DATE"), 0,
487 N_("same as -N"), 71 },
488 {"backup", BACKUP_OPTION, N_("CONTROL"), OPTION_ARG_OPTIONAL,
489 N_("backup before removal, choose version CONTROL"), 71 },
490 {"suffix", SUFFIX_OPTION, N_("STRING"), 0,
491 N_("backup before removal, override usual suffix ('~' unless overridden by environment variable SIMPLE_BACKUP_SUFFIX"), 71 },
492 {"wildcards", WILDCARDS_OPTION, 0, 0,
493 N_("exclude patterns use wildcards (default)"), 71 },
494 {"wildcards-match-slash", WILDCARDS_MATCH_SLASH_OPTION, 0, 0,
495 N_("exclude pattern wildcards match '/' (default)"), 71 },
496
497 {NULL, 0, NULL, 0,
498 N_("Informative output:"), 80 },
499
500 {"verbose", 'v', 0, 0,
501 N_("verbosely list files processed"), 81 },
502 {"checkpoint", CHECKPOINT_OPTION, 0, 0,
503 N_("display progress messages every 10th record"), 81 },
504 {"check-links", CHECK_LINKS_OPTION, 0, 0,
505 N_("print a message if not all links are dumped"), 82 },
506 {"totals", TOTALS_OPTION, 0, 0,
507 N_("print total bytes written while creating archive"), 82 },
508 {"utc", UTC_OPTION, 0, 0,
509 N_("print file modification dates in UTC"), 82 },
510 {"index-file", INDEX_FILE_OPTION, N_("FILE"), 0,
511 N_("send verbose output to FILE"), 82 },
512 {"block-number", 'R', 0, 0,
513 N_("show block number within archive with each message"), 82 },
514 {"interactive", 'w', 0, 0,
515 N_("ask for confirmation for every action"), 82 },
516 {"confirmation", 0, 0, OPTION_ALIAS, NULL, 82 },
517 {"show-defaults", SHOW_DEFAULTS_OPTION, 0, 0,
518 N_("Show tar defaults"), 82 },
519 {"show-omitted-dirs", SHOW_OMITTED_DIRS_OPTION, 0, 0,
520 N_("When listing or extracting, list each directory that does not match search criteria"), 82 },
521
522 {NULL, 0, NULL, 0,
523 N_("Compatibility options:"), 90 },
524
525 {NULL, 'o', 0, 0,
526 N_("when creating, same as --old-archive. When extracting, same as --no-same-owner"), 91 },
527
528 {NULL, 0, NULL, 0,
529 N_("Other options:"), 100 },
530
531 {"help", '?', 0, 0, N_("Give this help list"), -1},
532 {"usage", USAGE_OPTION, 0, 0, N_("Give a short usage message"), -1},
533 {"license", LICENSE_OPTION, 0, 0, N_("Print license and exit"), -1},
534 {"version", VERSION_OPTION, 0, 0, N_("Print program version"), -1},
535 /* FIXME -V (--label) conflicts with the default short option for
536 --version */
537
538 {0, 0, 0, 0, 0, 0}
539 };
540
541 struct tar_args {
542 char const *textual_date_option;
543 int exclude_options;
544 bool o_option;
545 int pax_option;
546 char const *backup_suffix_string;
547 char const *version_control_string;
548 int input_files;
549 };
550
551 static void
552 show_default_settings (FILE *stream)
553 {
554 fprintf (stream,
555 "--format=%s -f%s -b%d --rmt-command=%s",
556 archive_format_string (DEFAULT_ARCHIVE_FORMAT),
557 DEFAULT_ARCHIVE, DEFAULT_BLOCKING,
558 DEFAULT_RMT_COMMAND);
559 #ifdef REMOTE_SHELL
560 fprintf (stream, " --rsh-command=%s", REMOTE_SHELL);
561 #endif
562 fprintf (stream, "\n");
563 }
564
565 static void
566 set_subcommand_option (enum subcommand subcommand)
567 {
568 if (subcommand_option != UNKNOWN_SUBCOMMAND
569 && subcommand_option != subcommand)
570 USAGE_ERROR ((0, 0,
571 _("You may not specify more than one `-Acdtrux' option")));
572
573 subcommand_option = subcommand;
574 }
575
576 static void
577 set_use_compress_program_option (const char *string)
578 {
579 if (use_compress_program_option
580 && strcmp (use_compress_program_option, string) != 0)
581 USAGE_ERROR ((0, 0, _("Conflicting compression options")));
582
583 use_compress_program_option = string;
584 }
585
586 void
587 license ()
588 {
589 printf ("tar (%s) %s\n%s\n", PACKAGE_NAME, PACKAGE_VERSION,
590 "Copyright (C) 2004 Free Software Foundation, Inc.\n");
591 puts (_("Based on the work of John Gilmore and Jay Fenlason. See AUTHORS\n\
592 for complete list of authors.\n"));
593 printf (_(" GNU tar is free software; you can redistribute it and/or modify\n"
594 " it under the terms of the GNU General Public License as published by\n"
595 " the Free Software Foundation; either version 2 of the License, or\n"
596 " (at your option) any later version.\n"
597 "\n"
598 " GNU tar is distributed in the hope that it will be useful,\n"
599 " but WITHOUT ANY WARRANTY; without even the implied warranty of\n"
600 " MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n"
601 " GNU General Public License for more details.\n"
602 "\n"
603 " You should have received a copy of the GNU General Public License\n"
604 " along with GNU tar; if not, write to the Free Software\n"
605 " Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n\n"));
606 exit (0);
607 }
608
609 static error_t
610 parse_opt(int key, char *arg, struct argp_state *state)
611 {
612 struct tar_args *args = state->input;
613
614 switch (key)
615 {
616 case 1:
617 /* File name or non-parsed option, because of ARGP_IN_ORDER */
618 name_add (optarg);
619 args->input_files++;
620 break;
621
622 case 'A':
623 set_subcommand_option (CAT_SUBCOMMAND);
624 break;
625
626 case 'b':
627 {
628 uintmax_t u;
629 if (! (xstrtoumax (arg, 0, 10, &u, "") == LONGINT_OK
630 && u == (blocking_factor = u)
631 && 0 < blocking_factor
632 && u == (record_size = u * BLOCKSIZE) / BLOCKSIZE))
633 USAGE_ERROR ((0, 0, "%s: %s", quotearg_colon (arg),
634 _("Invalid blocking factor")));
635 }
636 break;
637
638 case 'B':
639 /* Try to reblock input records. For reading 4.2BSD pipes. */
640
641 /* It would surely make sense to exchange -B and -R, but it seems
642 that -B has been used for a long while in Sun tar and most
643 BSD-derived systems. This is a consequence of the block/record
644 terminology confusion. */
645
646 read_full_records_option = true;
647 break;
648
649 case 'c':
650 set_subcommand_option (CREATE_SUBCOMMAND);
651 break;
652
653 case 'C':
654 name_add ("-C");
655 name_add (arg);
656 break;
657
658 case 'd':
659 set_subcommand_option (DIFF_SUBCOMMAND);
660 break;
661
662 case 'f':
663 if (archive_names == allocated_archive_names)
664 {
665 allocated_archive_names *= 2;
666 archive_name_array =
667 xrealloc (archive_name_array,
668 sizeof (const char *) * allocated_archive_names);
669 }
670 archive_name_array[archive_names++] = arg;
671 break;
672
673 case 'F':
674 /* Since -F is only useful with -M, make it implied. Run this
675 script at the end of each tape. */
676
677 info_script_option = arg;
678 multi_volume_option = true;
679 break;
680
681 case 'g':
682 listed_incremental_option = arg;
683 after_date_option = true;
684 /* Fall through. */
685
686 case 'G':
687 /* We are making an incremental dump (FIXME: are we?); save
688 directories at the beginning of the archive, and include in each
689 directory its contents. */
690
691 incremental_option = true;
692 break;
693
694 case 'h':
695 /* Follow symbolic links. */
696 dereference_option = true;
697 break;
698
699 case 'i':
700 /* Ignore zero blocks (eofs). This can't be the default,
701 because Unix tar writes two blocks of zeros, then pads out
702 the record with garbage. */
703
704 ignore_zeros_option = true;
705 break;
706
707 case 'I':
708 USAGE_ERROR ((0, 0,
709 _("Warning: the -I option is not supported;"
710 " perhaps you meant -j or -T?")));
711 break;
712
713 case 'j':
714 set_use_compress_program_option ("bzip2");
715 break;
716
717 case 'k':
718 /* Don't replace existing files. */
719 old_files_option = KEEP_OLD_FILES;
720 break;
721
722 case 'K':
723 starting_file_option = true;
724 addname (arg, 0);
725 break;
726
727 case 'l':
728 /* Historically equivalent to --one-file-system. This usage is
729 incompatible with UNIX98 and POSIX specs and therefore is
730 deprecated. The semantics of -l option will be changed in
731 future versions. See TODO.
732 */
733 WARN ((0, 0,
734 _("Semantics of -l option will change in the future releases.")));
735 WARN ((0, 0,
736 _("Please use --one-file-system option instead.")));
737 /* FALL THROUGH */
738 case ONE_FILE_SYSTEM_OPTION:
739 /* When dumping directories, don't dump files/subdirectories
740 that are on other filesystems. */
741 one_file_system_option = true;
742 break;
743
744 case 'L':
745 {
746 uintmax_t u;
747 if (xstrtoumax (arg, 0, 10, &u, "") != LONGINT_OK)
748 USAGE_ERROR ((0, 0, "%s: %s", quotearg_colon (arg),
749 _("Invalid tape length")));
750 tape_length_option = 1024 * (tarlong) u;
751 multi_volume_option = true;
752 }
753 break;
754
755 case 'm':
756 touch_option = true;
757 break;
758
759 case 'M':
760 /* Make multivolume archive: when we can't write any more into
761 the archive, re-open it, and continue writing. */
762
763 multi_volume_option = true;
764 break;
765
766 case 'n':
767 seekable_archive = true;
768 break;
769
770 #if !MSDOS
771 case 'N':
772 after_date_option = true;
773 /* Fall through. */
774
775 case NEWER_MTIME_OPTION:
776 if (NEWER_OPTION_INITIALIZED (newer_mtime_option))
777 USAGE_ERROR ((0, 0, _("More than one threshold date")));
778
779 if (FILE_SYSTEM_PREFIX_LEN (arg) != 0
780 || ISSLASH (*arg)
781 || *arg == '.')
782 {
783 struct stat st;
784 if (deref_stat (dereference_option, arg, &st) != 0)
785 {
786 stat_error (arg);
787 USAGE_ERROR ((0, 0, _("Date file not found")));
788 }
789 newer_mtime_option.tv_sec = st.st_mtime;
790 newer_mtime_option.tv_nsec = TIMESPEC_NS (st.st_mtim);
791 }
792 else
793 {
794 if (! get_date (&newer_mtime_option, arg, NULL))
795 {
796 WARN ((0, 0, _("Substituting %s for unknown date format %s"),
797 tartime (newer_mtime_option.tv_sec), quote (arg)));
798 newer_mtime_option.tv_nsec = 0;
799 }
800 else
801 args->textual_date_option = arg;
802 }
803
804 break;
805 #endif /* not MSDOS */
806
807 case 'o':
808 args->o_option = true;
809 break;
810
811 case 'O':
812 to_stdout_option = true;
813 break;
814
815 case 'p':
816 same_permissions_option = true;
817 break;
818
819 case 'P':
820 absolute_names_option = true;
821 break;
822
823 case 'r':
824 set_subcommand_option (APPEND_SUBCOMMAND);
825 break;
826
827 case 'R':
828 /* Print block numbers for debugging bad tar archives. */
829
830 /* It would surely make sense to exchange -B and -R, but it seems
831 that -B has been used for a long while in Sun tar ans most
832 BSD-derived systems. This is a consequence of the block/record
833 terminology confusion. */
834
835 block_number_option = true;
836 break;
837
838 case 's':
839 /* Names to extr are sorted. */
840
841 same_order_option = true;
842 break;
843
844 case 'S':
845 sparse_option = true;
846 break;
847
848 case 't':
849 set_subcommand_option (LIST_SUBCOMMAND);
850 verbose_option++;
851 break;
852
853 case 'T':
854 files_from_option = arg;
855 break;
856
857 case 'u':
858 set_subcommand_option (UPDATE_SUBCOMMAND);
859 break;
860
861 case 'U':
862 old_files_option = UNLINK_FIRST_OLD_FILES;
863 break;
864
865 case UTC_OPTION:
866 utc_option = true;
867 break;
868
869 case 'v':
870 verbose_option++;
871 break;
872
873 case 'V':
874 volume_label_option = arg;
875 break;
876
877 case 'w':
878 interactive_option = true;
879 break;
880
881 case 'W':
882 verify_option = true;
883 break;
884
885 case 'x':
886 set_subcommand_option (EXTRACT_SUBCOMMAND);
887 break;
888
889 case 'X':
890 if (add_exclude_file (add_exclude, excluded, arg,
891 args->exclude_options | recursion_option, '\n')
892 != 0)
893 {
894 int e = errno;
895 FATAL_ERROR ((0, e, "%s", quotearg_colon (arg)));
896 }
897 break;
898
899 case 'y':
900 USAGE_ERROR ((0, 0,
901 _("Warning: the -y option is not supported;"
902 " perhaps you meant -j?")));
903 break;
904
905 case 'z':
906 set_use_compress_program_option ("gzip");
907 break;
908
909 case 'Z':
910 set_use_compress_program_option ("compress");
911 break;
912
913 case ANCHORED_OPTION:
914 args->exclude_options |= EXCLUDE_ANCHORED;
915 break;
916
917 case ATIME_PRESERVE_OPTION:
918 atime_preserve_option = true;
919 break;
920
921 case CHECKPOINT_OPTION:
922 checkpoint_option = true;
923 break;
924
925 case BACKUP_OPTION:
926 backup_option = true;
927 if (arg)
928 args->version_control_string = arg;
929 break;
930
931 case DELETE_OPTION:
932 set_subcommand_option (DELETE_SUBCOMMAND);
933 break;
934
935 case EXCLUDE_OPTION:
936 add_exclude (excluded, arg, args->exclude_options | recursion_option);
937 break;
938
939 case EXCLUDE_CACHES_OPTION:
940 exclude_caches_option = true;
941 break;
942
943 case FORCE_LOCAL_OPTION:
944 force_local_option = true;
945 break;
946
947 case 'H':
948 set_archive_format (arg);
949 break;
950
951 case INDEX_FILE_OPTION:
952 index_file_name = arg;
953 break;
954
955 case IGNORE_CASE_OPTION:
956 args->exclude_options |= FNM_CASEFOLD;
957 break;
958
959 case IGNORE_FAILED_READ_OPTION:
960 ignore_failed_read_option = true;
961 break;
962
963 case KEEP_NEWER_FILES_OPTION:
964 old_files_option = KEEP_NEWER_FILES;
965 break;
966
967 case GROUP_OPTION:
968 if (! (strlen (arg) < GNAME_FIELD_SIZE
969 && gname_to_gid (arg, &group_option)))
970 {
971 uintmax_t g;
972 if (xstrtoumax (arg, 0, 10, &g, "") == LONGINT_OK
973 && g == (gid_t) g)
974 group_option = g;
975 else
976 FATAL_ERROR ((0, 0, "%s: %s", quotearg_colon (arg),
977 _("%s: Invalid group")));
978 }
979 break;
980
981 case MODE_OPTION:
982 mode_option
983 = mode_compile (arg,
984 MODE_MASK_EQUALS | MODE_MASK_PLUS | MODE_MASK_MINUS);
985 if (mode_option == MODE_INVALID)
986 FATAL_ERROR ((0, 0, _("Invalid mode given on option")));
987 if (mode_option == MODE_MEMORY_EXHAUSTED)
988 xalloc_die ();
989 break;
990
991 case NO_ANCHORED_OPTION:
992 args->exclude_options &= ~ EXCLUDE_ANCHORED;
993 break;
994
995 case NO_IGNORE_CASE_OPTION:
996 args->exclude_options &= ~ FNM_CASEFOLD;
997 break;
998
999 case NO_OVERWRITE_DIR_OPTION:
1000 old_files_option = NO_OVERWRITE_DIR_OLD_FILES;
1001 break;
1002
1003 case NO_WILDCARDS_OPTION:
1004 args->exclude_options &= ~ EXCLUDE_WILDCARDS;
1005 break;
1006
1007 case NO_WILDCARDS_MATCH_SLASH_OPTION:
1008 args->exclude_options |= FNM_FILE_NAME;
1009 break;
1010
1011 case NULL_OPTION:
1012 filename_terminator = '\0';
1013 break;
1014
1015 case NUMERIC_OWNER_OPTION:
1016 numeric_owner_option = true;
1017 break;
1018
1019 case OCCURRENCE_OPTION:
1020 if (!arg)
1021 occurrence_option = 1;
1022 else
1023 {
1024 uintmax_t u;
1025 if (xstrtoumax (arg, 0, 10, &u, "") == LONGINT_OK)
1026 occurrence_option = u;
1027 else
1028 FATAL_ERROR ((0, 0, "%s: %s", quotearg_colon (arg),
1029 _("Invalid number")));
1030 }
1031 break;
1032
1033 case OVERWRITE_OPTION:
1034 old_files_option = OVERWRITE_OLD_FILES;
1035 break;
1036
1037 case OWNER_OPTION:
1038 if (! (strlen (arg) < UNAME_FIELD_SIZE
1039 && uname_to_uid (arg, &owner_option)))
1040 {
1041 uintmax_t u;
1042 if (xstrtoumax (arg, 0, 10, &u, "") == LONGINT_OK
1043 && u == (uid_t) u)
1044 owner_option = u;
1045 else
1046 FATAL_ERROR ((0, 0, "%s: %s", quotearg_colon (arg),
1047 _("Invalid owner")));
1048 }
1049 break;
1050
1051 case PAX_OPTION:
1052 args->pax_option++;
1053 xheader_set_option (arg);
1054 break;
1055
1056 case POSIX_OPTION:
1057 set_archive_format ("posix");
1058 break;
1059
1060 case PRESERVE_OPTION:
1061 same_permissions_option = true;
1062 same_order_option = true;
1063 break;
1064
1065 case RECORD_SIZE_OPTION:
1066 {
1067 uintmax_t u;
1068 if (! (xstrtoumax (arg, 0, 10, &u, "") == LONGINT_OK
1069 && u == (size_t) u))
1070 USAGE_ERROR ((0, 0, "%s: %s", quotearg_colon (arg),
1071 _("Invalid record size")));
1072 record_size = u;
1073 if (record_size % BLOCKSIZE != 0)
1074 USAGE_ERROR ((0, 0, _("Record size must be a multiple of %d."),
1075 BLOCKSIZE));
1076 blocking_factor = record_size / BLOCKSIZE;
1077 }
1078 break;
1079
1080 case RECURSIVE_UNLINK_OPTION:
1081 recursive_unlink_option = true;
1082 break;
1083
1084 case REMOVE_FILES_OPTION:
1085 remove_files_option = true;
1086 break;
1087
1088 case RMT_COMMAND_OPTION:
1089 rmt_command = arg;
1090 break;
1091
1092 case RSH_COMMAND_OPTION:
1093 rsh_command_option = arg;
1094 break;
1095
1096 case SHOW_DEFAULTS_OPTION:
1097 show_default_settings (stdout);
1098 exit(0);
1099
1100 case STRIP_COMPONENTS_OPTION:
1101 {
1102 uintmax_t u;
1103 if (! (xstrtoumax (arg, 0, 10, &u, "") == LONGINT_OK
1104 && u == (size_t) u))
1105 USAGE_ERROR ((0, 0, "%s: %s", quotearg_colon (arg),
1106 _("Invalid number of elements")));
1107 strip_name_components = u;
1108 }
1109 break;
1110
1111 case SHOW_OMITTED_DIRS_OPTION:
1112 show_omitted_dirs_option = true;
1113 break;
1114
1115 case SUFFIX_OPTION:
1116 backup_option = true;
1117 args->backup_suffix_string = arg;
1118 break;
1119
1120 case TOTALS_OPTION:
1121 totals_option = true;
1122 break;
1123
1124 case USE_COMPRESS_PROGRAM_OPTION:
1125 set_use_compress_program_option (arg);
1126 break;
1127
1128 case VOLNO_FILE_OPTION:
1129 volno_file_option = arg;
1130 break;
1131
1132 case WILDCARDS_OPTION:
1133 args->exclude_options |= EXCLUDE_WILDCARDS;
1134 break;
1135
1136 case WILDCARDS_MATCH_SLASH_OPTION:
1137 args->exclude_options &= ~ FNM_FILE_NAME;
1138 break;
1139
1140 case CHECK_LINKS_OPTION:
1141 check_links_option = 1;
1142 break;
1143
1144 case NO_RECURSION_OPTION:
1145 recursion_option = 0;
1146 break;
1147
1148 case NO_SAME_OWNER_OPTION:
1149 same_owner_option = -1;
1150 break;
1151
1152 case NO_SAME_PERMISSIONS_OPTION:
1153 same_permissions_option = -1;
1154 break;
1155
1156 case RECURSION_OPTION:
1157 recursion_option = FNM_LEADING_DIR;
1158 break;
1159
1160 case SAME_OWNER_OPTION:
1161 same_owner_option = 1;
1162 break;
1163
1164 case '0':
1165 case '1':
1166 case '2':
1167 case '3':
1168 case '4':
1169 case '5':
1170 case '6':
1171 case '7':
1172
1173 #ifdef DEVICE_PREFIX
1174 {
1175 int device = key - '0';
1176 int density;
1177 static char buf[sizeof DEVICE_PREFIX + 10];
1178 char *cursor;
1179
1180 if (arg[1])
1181 argp_error (state, _("Malformed density argument: '%s'"), arg);
1182
1183 strcpy (buf, DEVICE_PREFIX);
1184 cursor = buf + strlen (buf);
1185
1186 #ifdef DENSITY_LETTER
1187
1188 sprintf (cursor, "%d%c", device, arg[0]);
1189
1190 #else /* not DENSITY_LETTER */
1191
1192 switch (arg[0])
1193 {
1194 case 'l':
1195 #ifdef LOW_NUM
1196 device += LOW_NUM;
1197 #endif
1198 break;
1199
1200 case 'm':
1201 #ifdef MID_NUM
1202 device += MID_NUM;
1203 #else
1204 device += 8;
1205 #endif
1206 break;
1207
1208 case 'h':
1209 #ifdef HGH_NUM
1210 device += HGH_NUM;
1211 #else
1212 device += 16;
1213 #endif
1214 break;
1215
1216 default:
1217 argp_error (state, _("Unknown density: '%c'"), arg[0]);
1218 }
1219 sprintf (cursor, "%d", device);
1220
1221 #endif /* not DENSITY_LETTER */
1222
1223 if (archive_names == allocated_archive_names)
1224 {
1225 allocated_archive_names *= 2;
1226 archive_name_array =
1227 xrealloc (archive_name_array,
1228 sizeof (const char *) * allocated_archive_names);
1229 }
1230 archive_name_array[archive_names++] = strdup (buf);
1231 }
1232 break;
1233
1234 #else /* not DEVICE_PREFIX */
1235
1236 argp_error (state,
1237 _("Options `-[0-7][lmh]' not supported by *this* tar"));
1238
1239 #endif /* not DEVICE_PREFIX */
1240
1241 case '?':
1242 state->flags |= ARGP_NO_EXIT;
1243 argp_state_help (state, state->out_stream,
1244 ARGP_HELP_STD_HELP & ~ARGP_HELP_BUG_ADDR);
1245 fprintf (state->out_stream, _("\n*This* tar defaults to:\n"));
1246 show_default_settings (state->out_stream);
1247 fprintf (state->out_stream, "\n");
1248 fprintf (state->out_stream, _("Report bugs to %s.\n"),
1249 argp_program_bug_address);
1250 exit (0);
1251
1252 case USAGE_OPTION:
1253 argp_state_help (state, state->out_stream,
1254 ARGP_HELP_USAGE | ARGP_HELP_EXIT_OK);
1255 break;
1256
1257 case VERSION_OPTION:
1258 fprintf (state->out_stream, "%s\n", argp_program_version);
1259 exit (0);
1260
1261 case LICENSE_OPTION:
1262 license ();
1263 break;
1264
1265 default:
1266 return ARGP_ERR_UNKNOWN;
1267 }
1268 return 0;
1269 }
1270
1271 static struct argp argp = {
1272 options,
1273 parse_opt,
1274 N_("[FILE]..."),
1275 doc,
1276 NULL,
1277 NULL,
1278 NULL
1279 };
1280
1281 void
1282 usage (int status)
1283 {
1284 argp_help (&argp, stderr, ARGP_HELP_SEE, (char*) program_name);
1285 exit (status);
1286 }
1287
1288 /* Parse the options for tar. */
1289
1290 static struct argp_option *
1291 find_argp_option (struct argp_option *options, int letter)
1292 {
1293 for (;
1294 !(options->name == NULL
1295 && options->key == 0
1296 && options->arg == 0
1297 && options->flags == 0
1298 && options->doc == NULL); options++)
1299 if (options->key == letter)
1300 return options;
1301 return NULL;
1302 }
1303
1304 static void
1305 decode_options (int argc, char **argv)
1306 {
1307 int index;
1308 struct tar_args args;
1309
1310 /* Set some default option values. */
1311 args.textual_date_option = NULL;
1312 args.exclude_options = EXCLUDE_WILDCARDS;
1313 args.o_option = 0;
1314 args.pax_option = 0;
1315 args.backup_suffix_string = getenv ("SIMPLE_BACKUP_SUFFIX");
1316 args.version_control_string = 0;
1317 args.input_files = 0;
1318
1319 subcommand_option = UNKNOWN_SUBCOMMAND;
1320 archive_format = DEFAULT_FORMAT;
1321 blocking_factor = DEFAULT_BLOCKING;
1322 record_size = DEFAULT_BLOCKING * BLOCKSIZE;
1323 excluded = new_exclude ();
1324 newer_mtime_option.tv_sec = TYPE_MINIMUM (time_t);
1325 newer_mtime_option.tv_nsec = -1;
1326 recursion_option = FNM_LEADING_DIR;
1327
1328 owner_option = -1;
1329 group_option = -1;
1330
1331 /* Convert old-style tar call by exploding option element and rearranging
1332 options accordingly. */
1333
1334 if (argc > 1 && argv[1][0] != '-')
1335 {
1336 int new_argc; /* argc value for rearranged arguments */
1337 char **new_argv; /* argv value for rearranged arguments */
1338 char *const *in; /* cursor into original argv */
1339 char **out; /* cursor into rearranged argv */
1340 const char *letter; /* cursor into old option letters */
1341 char buffer[3]; /* constructed option buffer */
1342
1343 /* Initialize a constructed option. */
1344
1345 buffer[0] = '-';
1346 buffer[2] = '\0';
1347
1348 /* Allocate a new argument array, and copy program name in it. */
1349
1350 new_argc = argc - 1 + strlen (argv[1]);
1351 new_argv = xmalloc ((new_argc + 1) * sizeof (char *));
1352 in = argv;
1353 out = new_argv;
1354 *out++ = *in++;
1355
1356 /* Copy each old letter option as a separate option, and have the
1357 corresponding argument moved next to it. */
1358
1359 for (letter = *in++; *letter; letter++)
1360 {
1361 struct argp_option *opt;
1362
1363 buffer[1] = *letter;
1364 *out++ = xstrdup (buffer);
1365 opt = find_argp_option (options, *letter);
1366 if (opt && opt->arg)
1367 {
1368 if (in < argv + argc)
1369 *out++ = *in++;
1370 else
1371 USAGE_ERROR ((0, 0, _("Old option `%c' requires an argument."),
1372 *letter));
1373 }
1374 }
1375
1376 /* Copy all remaining options. */
1377
1378 while (in < argv + argc)
1379 *out++ = *in++;
1380 *out = 0;
1381
1382 /* Replace the old option list by the new one. */
1383
1384 argc = new_argc;
1385 argv = new_argv;
1386 }
1387
1388 /* Parse all options and non-options as they appear. */
1389
1390 prepend_default_options (getenv ("TAR_OPTIONS"), &argc, &argv);
1391
1392 if (argp_parse (&argp, argc, argv, ARGP_IN_ORDER|ARGP_NO_HELP,
1393 &index, &args))
1394 exit (1);
1395
1396
1397 /* Special handling for 'o' option:
1398
1399 GNU tar used to say "output old format".
1400 UNIX98 tar says don't chown files after extracting (we use
1401 "--no-same-owner" for this).
1402
1403 The old GNU tar semantics is retained when used with --create
1404 option, otherwise UNIX98 semantics is assumed */
1405
1406 if (args.o_option)
1407 {
1408 if (subcommand_option == CREATE_SUBCOMMAND)
1409 {
1410 /* GNU Tar <= 1.13 compatibility */
1411 set_archive_format ("v7");
1412 }
1413 else
1414 {
1415 /* UNIX98 compatibility */
1416 same_owner_option = 1;
1417 }
1418 }
1419
1420 /* Handle operands after any "--" argument. */
1421 for (; index < argc; index++)
1422 {
1423 name_add (argv[index]);
1424 args.input_files++;
1425 }
1426
1427 /* Derive option values and check option consistency. */
1428
1429 if (archive_format == DEFAULT_FORMAT)
1430 {
1431 if (args.pax_option)
1432 archive_format = POSIX_FORMAT;
1433 else
1434 archive_format = DEFAULT_ARCHIVE_FORMAT;
1435 }
1436
1437 if (volume_label_option && subcommand_option == CREATE_SUBCOMMAND)
1438 assert_format (FORMAT_MASK (OLDGNU_FORMAT)
1439 | FORMAT_MASK (GNU_FORMAT));
1440
1441
1442 if (incremental_option || multi_volume_option)
1443 assert_format (FORMAT_MASK (OLDGNU_FORMAT) | FORMAT_MASK (GNU_FORMAT));
1444
1445 if (sparse_option)
1446 assert_format (FORMAT_MASK (OLDGNU_FORMAT)
1447 | FORMAT_MASK (GNU_FORMAT)
1448 | FORMAT_MASK (POSIX_FORMAT));
1449
1450 if (occurrence_option)
1451 {
1452 if (!args.input_files && !files_from_option)
1453 USAGE_ERROR ((0, 0,
1454 _("--occurrence is meaningless without a file list")));
1455 if (subcommand_option != DELETE_SUBCOMMAND
1456 && subcommand_option != DIFF_SUBCOMMAND
1457 && subcommand_option != EXTRACT_SUBCOMMAND
1458 && subcommand_option != LIST_SUBCOMMAND)
1459 USAGE_ERROR ((0, 0,
1460 _("--occurrence cannot be used in the requested operation mode")));
1461 }
1462
1463 if (archive_names == 0)
1464 {
1465 /* If no archive file name given, try TAPE from the environment, or
1466 else, DEFAULT_ARCHIVE from the configuration process. */
1467
1468 archive_names = 1;
1469 archive_name_array[0] = getenv ("TAPE");
1470 if (! archive_name_array[0])
1471 archive_name_array[0] = DEFAULT_ARCHIVE;
1472 }
1473
1474 /* Allow multiple archives only with `-M'. */
1475
1476 if (archive_names > 1 && !multi_volume_option)
1477 USAGE_ERROR ((0, 0,
1478 _("Multiple archive files require `-M' option")));
1479
1480 if (listed_incremental_option
1481 && NEWER_OPTION_INITIALIZED (newer_mtime_option))
1482 USAGE_ERROR ((0, 0,
1483 _("Cannot combine --listed-incremental with --newer")));
1484
1485 if (volume_label_option)
1486 {
1487 size_t volume_label_max_len =
1488 (sizeof current_header->header.name
1489 - 1 /* for trailing '\0' */
1490 - (multi_volume_option
1491 ? (sizeof " Volume "
1492 - 1 /* for null at end of " Volume " */
1493 + INT_STRLEN_BOUND (int) /* for volume number */
1494 - 1 /* for sign, as 0 <= volno */)
1495 : 0));
1496 if (volume_label_max_len < strlen (volume_label_option))
1497 USAGE_ERROR ((0, 0,
1498 ngettext ("%s: Volume label is too long (limit is %lu byte)",
1499 "%s: Volume label is too long (limit is %lu bytes)",
1500 volume_label_max_len),
1501 quotearg_colon (volume_label_option),
1502 (unsigned long) volume_label_max_len));
1503 }
1504
1505 if (verify_option)
1506 {
1507 if (multi_volume_option)
1508 USAGE_ERROR ((0, 0, _("Cannot verify multi-volume archives")));
1509 if (use_compress_program_option)
1510 USAGE_ERROR ((0, 0, _("Cannot verify compressed archives")));
1511 }
1512
1513 if (use_compress_program_option)
1514 {
1515 if (multi_volume_option)
1516 USAGE_ERROR ((0, 0, _("Cannot use multi-volume compressed archives")));
1517 if (subcommand_option == UPDATE_SUBCOMMAND)
1518 USAGE_ERROR ((0, 0, _("Cannot update compressed archives")));
1519 }
1520
1521 /* It is no harm to use --pax-option on non-pax archives in archive
1522 reading mode. It may even be useful, since it allows to override
1523 file attributes from tar headers. Therefore I allow such usage.
1524 --gray */
1525 if (args.pax_option
1526 && archive_format != POSIX_FORMAT
1527 && (subcommand_option != EXTRACT_SUBCOMMAND
1528 || subcommand_option != DIFF_SUBCOMMAND
1529 || subcommand_option != LIST_SUBCOMMAND))
1530 USAGE_ERROR ((0, 0, _("--pax-option can be used only on POSIX archives")));
1531
1532 /* If ready to unlink hierarchies, so we are for simpler files. */
1533 if (recursive_unlink_option)
1534 old_files_option = UNLINK_FIRST_OLD_FILES;
1535
1536 if (utc_option)
1537 verbose_option = 2;
1538
1539 /* Forbid using -c with no input files whatsoever. Check that `-f -',
1540 explicit or implied, is used correctly. */
1541
1542 switch (subcommand_option)
1543 {
1544 case CREATE_SUBCOMMAND:
1545 if (args.input_files == 0 && !files_from_option)
1546 USAGE_ERROR ((0, 0,
1547 _("Cowardly refusing to create an empty archive")));
1548 break;
1549
1550 case EXTRACT_SUBCOMMAND:
1551 case LIST_SUBCOMMAND:
1552 case DIFF_SUBCOMMAND:
1553 for (archive_name_cursor = archive_name_array;
1554 archive_name_cursor < archive_name_array + archive_names;
1555 archive_name_cursor++)
1556 if (!strcmp (*archive_name_cursor, "-"))
1557 request_stdin ("-f");
1558 break;
1559
1560 case CAT_SUBCOMMAND:
1561 case UPDATE_SUBCOMMAND:
1562 case APPEND_SUBCOMMAND:
1563 for (archive_name_cursor = archive_name_array;
1564 archive_name_cursor < archive_name_array + archive_names;
1565 archive_name_cursor++)
1566 if (!strcmp (*archive_name_cursor, "-"))
1567 USAGE_ERROR ((0, 0,
1568 _("Options `-Aru' are incompatible with `-f -'")));
1569
1570 default:
1571 break;
1572 }
1573
1574 archive_name_cursor = archive_name_array;
1575
1576 /* Prepare for generating backup names. */
1577
1578 if (args.backup_suffix_string)
1579 simple_backup_suffix = xstrdup (args.backup_suffix_string);
1580
1581 if (backup_option)
1582 backup_type = xget_version ("--backup", args.version_control_string);
1583
1584 if (verbose_option && args.textual_date_option)
1585 {
1586 /* FIXME: tartime should support nanoseconds, too, so that this
1587 comparison doesn't complain about lost nanoseconds. */
1588 char const *treated_as = tartime (newer_mtime_option.tv_sec);
1589 if (strcmp (args.textual_date_option, treated_as) != 0)
1590 WARN ((0, 0,
1591 ngettext ("Treating date `%s' as %s + %ld nanosecond",
1592 "Treating date `%s' as %s + %ld nanoseconds",
1593 newer_mtime_option.tv_nsec),
1594 args.textual_date_option, treated_as,
1595 newer_mtime_option.tv_nsec));
1596 }
1597 }
1598
1599 \f
1600 /* Tar proper. */
1601
1602 /* Main routine for tar. */
1603 int
1604 main (int argc, char **argv)
1605 {
1606 set_start_time ();
1607 program_name = argv[0];
1608 setlocale (LC_ALL, "");
1609 bindtextdomain (PACKAGE, LOCALEDIR);
1610 textdomain (PACKAGE);
1611
1612 exit_status = TAREXIT_SUCCESS;
1613 filename_terminator = '\n';
1614 set_quoting_style (0, escape_quoting_style);
1615
1616 /* Pre-allocate a few structures. */
1617
1618 allocated_archive_names = 10;
1619 archive_name_array =
1620 xmalloc (sizeof (const char *) * allocated_archive_names);
1621 archive_names = 0;
1622
1623 #ifdef SIGCHLD
1624 /* System V fork+wait does not work if SIGCHLD is ignored. */
1625 signal (SIGCHLD, SIG_DFL);
1626 #endif
1627
1628 init_names ();
1629
1630 /* Decode options. */
1631
1632 decode_options (argc, argv);
1633 name_init ();
1634
1635 /* Main command execution. */
1636
1637 if (volno_file_option)
1638 init_volume_number ();
1639
1640 switch (subcommand_option)
1641 {
1642 case UNKNOWN_SUBCOMMAND:
1643 USAGE_ERROR ((0, 0,
1644 _("You must specify one of the `-Acdtrux' options")));
1645
1646 case CAT_SUBCOMMAND:
1647 case UPDATE_SUBCOMMAND:
1648 case APPEND_SUBCOMMAND:
1649 update_archive ();
1650 break;
1651
1652 case DELETE_SUBCOMMAND:
1653 delete_archive_members ();
1654 break;
1655
1656 case CREATE_SUBCOMMAND:
1657 create_archive ();
1658 name_close ();
1659
1660 if (totals_option)
1661 print_total_written ();
1662 break;
1663
1664 case EXTRACT_SUBCOMMAND:
1665 extr_init ();
1666 read_and (extract_archive);
1667
1668 /* FIXME: should extract_finish () even if an ordinary signal is
1669 received. */
1670 extract_finish ();
1671
1672 break;
1673
1674 case LIST_SUBCOMMAND:
1675 read_and (list_archive);
1676 break;
1677
1678 case DIFF_SUBCOMMAND:
1679 diff_init ();
1680 read_and (diff_archive);
1681 break;
1682 }
1683
1684 if (check_links_option)
1685 check_links ();
1686
1687 if (volno_file_option)
1688 closeout_volume_number ();
1689
1690 /* Dispose of allocated memory, and return. */
1691
1692 free (archive_name_array);
1693 name_term ();
1694
1695 if (stdlis != stderr && (ferror (stdlis) || fclose (stdlis) != 0))
1696 FATAL_ERROR ((0, 0, _("Error in writing to standard output")));
1697 if (exit_status == TAREXIT_FAILURE)
1698 error (0, 0, _("Error exit delayed from previous errors"));
1699 if (ferror (stderr) || fclose (stderr) != 0)
1700 exit_status = TAREXIT_FAILURE;
1701 return exit_status;
1702 }
1703
1704 void
1705 tar_stat_init (struct tar_stat_info *st)
1706 {
1707 memset (st, 0, sizeof (*st));
1708 }
1709
1710 void
1711 tar_stat_destroy (struct tar_stat_info *st)
1712 {
1713 free (st->orig_file_name);
1714 free (st->file_name);
1715 free (st->link_name);
1716 free (st->uname);
1717 free (st->gname);
1718 free (st->sparse_map);
1719 memset (st, 0, sizeof (*st));
1720 }
This page took 0.12224 seconds and 4 git commands to generate.