1 /* List a tar archive, with support routines for reading a tar archive.
2 Copyright 1988,92,93,94,96,97,98,1999 Free Software Foundation, Inc.
3 Written by John Gilmore, on 1985-08-26.
5 This program is free software; you can redistribute it and/or modify it
6 under the terms of the GNU General Public License as published by the
7 Free Software Foundation; either version 2, or (at your option) any later
10 This program is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
13 Public License for more details.
15 You should have received a copy of the GNU General Public License along
16 with this program; if not, write to the Free Software Foundation, Inc.,
17 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
19 /* Define to non-zero for forcing old ctime() instead of isotime(). */
29 union block
*current_header
; /* points to current archive header */
30 struct stat current_stat
; /* stat struct corresponding */
31 enum archive_format current_format
; /* recognized format */
33 static uintmax_t from_chars
PARAMS ((const char *, size_t, const char *,
34 uintmax_t, uintmax_t));
36 /* Table of base 64 digit values indexed by unsigned chars.
37 The value is 64 for unsigned chars that are not base 64 digits. */
38 static char base64_map
[1 + (unsigned char) -1];
44 memset (base64_map
, 64, sizeof base64_map
);
45 for (i
= 0; i
< 64; i
++)
46 base64_map
[(int) base_64_digits
[i
]] = i
;
49 /*-----------------------------------.
50 | Main loop for reading an archive. |
51 `-----------------------------------*/
54 read_and (void (*do_something
) ())
56 enum read_header status
= HEADER_STILL_UNREAD
;
57 enum read_header prev_status
;
62 open_archive (ACCESS_READ
);
67 status
= read_header ();
70 case HEADER_STILL_UNREAD
:
75 /* Valid header. We should decode next field (mode) first.
76 Ensure incoming names are null terminated. */
78 /* FIXME: This is a quick kludge before 1.12 goes out. */
80 = TIME_FROM_CHARS (current_header
->header
.mtime
);
82 if (!name_match (current_file_name
)
83 || current_stat
.st_mtime
< newer_mtime_option
84 || excluded_name (current_file_name
))
88 if (current_header
->header
.typeflag
== GNUTYPE_VOLHDR
89 || current_header
->header
.typeflag
== GNUTYPE_MULTIVOL
90 || current_header
->header
.typeflag
== GNUTYPE_NAMES
)
95 if (show_omitted_dirs_option
96 && current_header
->header
.typeflag
== DIRTYPE
)
97 WARN ((0, 0, _("Omitting %s"), current_file_name
));
99 /* Skip past it in the archive. */
101 if (current_header
->oldgnu_header
.isextended
)
103 save_typeflag
= current_header
->header
.typeflag
;
104 set_next_block_after (current_header
);
112 exhdr
= find_next_block ();
113 if (!exhdr
->sparse_header
.isextended
)
115 set_next_block_after (exhdr
);
119 set_next_block_after (exhdr
);
121 skip_extended_headers ();
124 /* Skip to the next header on the archive. */
126 if (save_typeflag
!= DIRTYPE
)
127 skip_file (current_stat
.st_size
);
134 case HEADER_ZERO_BLOCK
:
135 if (block_number_option
)
137 char buf
[UINTMAX_STRSIZE_BOUND
];
138 fprintf (stdlis
, _("block %s: ** Block of NULs **\n"),
139 STRINGIFY_BIGINT (current_block_ordinal (), buf
));
142 set_next_block_after (current_header
);
143 status
= prev_status
;
144 if (ignore_zeros_option
)
148 case HEADER_END_OF_FILE
:
149 if (block_number_option
)
151 char buf
[UINTMAX_STRSIZE_BOUND
];
152 fprintf (stdlis
, _("block %s: ** End of File **\n"),
153 STRINGIFY_BIGINT (current_block_ordinal (), buf
));
158 /* If the previous header was good, tell them that we are
159 skipping bad ones. */
160 set_next_block_after (current_header
);
163 case HEADER_STILL_UNREAD
:
164 WARN ((0, 0, _("Hmm, this doesn't look like a tar archive")));
167 case HEADER_ZERO_BLOCK
:
169 WARN ((0, 0, _("Skipping to next file header")));
172 case HEADER_END_OF_FILE
:
174 /* We are in the middle of a cascade of errors. */
182 apply_delayed_set_stat ();
184 names_notfound (); /* print names not found */
187 /*---------------------------------------------.
188 | Print a header block, based on tar options. |
189 `---------------------------------------------*/
194 int isextended
= 0; /* to remember if current_header is extended */
196 /* Print the header block. */
200 if (verbose_option
> 1)
201 decode_header (current_header
, ¤t_stat
, ¤t_format
, 0);
205 if (incremental_option
&& current_header
->header
.typeflag
== GNUTYPE_DUMPDIR
)
208 size_t written
, check
;
209 union block
*data_block
;
211 set_next_block_after (current_header
);
212 if (multi_volume_option
)
214 assign_string (&save_name
, current_file_name
);
215 save_totsize
= current_stat
.st_size
;
217 for (size
= current_stat
.st_size
; size
> 0; size
-= written
)
219 if (multi_volume_option
)
220 save_sizeleft
= size
;
221 data_block
= find_next_block ();
224 ERROR ((0, 0, _("EOF in archive file")));
225 break; /* FIXME: What happens, then? */
227 written
= available_space_after (data_block
);
230 errno
= 0; /* FIXME: errno should be read-only */
231 check
= fwrite (data_block
->buffer
, sizeof (char), written
, stdlis
);
232 set_next_block_after ((union block
*)
233 (data_block
->buffer
+ written
- 1));
234 if (check
!= written
)
236 ERROR ((0, errno
, _("Only wrote %lu of %lu bytes to file %s"),
237 (unsigned long) check
,
238 (unsigned long) written
, current_file_name
));
239 skip_file (size
- written
);
243 if (multi_volume_option
)
244 assign_string (&save_name
, NULL
);
245 fputc ('\n', stdlis
);
251 /* Check to see if we have an extended header to skip over also. */
253 if (current_header
->oldgnu_header
.isextended
)
256 /* Skip past the header in the archive. */
258 set_next_block_after (current_header
);
260 /* If we needed to skip any extended headers, do so now, by reading
261 extended headers and skipping past them in the archive. */
270 exhdr
= find_next_block ();
272 if (!exhdr
->sparse_header
.isextended
)
274 set_next_block_after (exhdr
);
277 set_next_block_after (exhdr
);
280 skip_extended_headers ();
283 if (multi_volume_option
)
284 assign_string (&save_name
, current_file_name
);
286 /* Skip to the next header on the archive. */
288 skip_file (current_stat
.st_size
);
290 if (multi_volume_option
)
291 assign_string (&save_name
, NULL
);
294 /*-----------------------------------------------------------------------.
295 | Read a block that's supposed to be a header block. Return its address |
296 | in "current_header", and if it is good, the file's size in |
297 | current_stat.st_size. |
299 | Return 1 for success, 0 if the checksum is bad, EOF on eof, 2 for a |
300 | block full of zeros (EOF marker). |
302 | You must always set_next_block_after(current_header) to skip past the |
303 | header which this routine reads. |
304 `-----------------------------------------------------------------------*/
306 /* The standard BSD tar sources create the checksum by adding up the
307 bytes in the header as type char. I think the type char was unsigned
308 on the PDP-11, but it's signed on the Next and Sun. It looks like the
309 sources to BSD tar were never changed to compute the checksum
310 currectly, so both the Sun and Next add the bytes of the header as
311 signed chars. This doesn't cause a problem until you get a file with
312 a name containing characters with the high bit set. So read_header
313 computes two checksums -- signed and unsigned. */
315 /* FIXME: The signed checksum computation is broken on machines where char's
316 are unsigned. It's uneasy to handle all cases correctly... */
322 long unsigned_sum
; /* the POSIX one :-) */
323 long signed_sum
; /* the Sun one :-( */
325 uintmax_t parsed_sum
;
330 union block
*data_block
;
331 size_t size
, written
;
332 static char *next_long_name
, *next_long_link
;
336 header
= find_next_block ();
337 current_header
= header
;
339 return HEADER_END_OF_FILE
;
341 parsed_sum
= from_chars (header
->header
.chksum
,
342 sizeof header
->header
.chksum
,
343 (char *) 0, (uintmax_t) 0,
344 (uintmax_t) TYPE_MAXIMUM (long));
345 if (parsed_sum
== (uintmax_t) -1)
346 return HEADER_FAILURE
;
348 recorded_sum
= parsed_sum
;
352 for (i
= sizeof (*header
); i
-- != 0;)
354 /* We can't use unsigned char here because of old compilers,
357 unsigned_sum
+= 0xFF & *p
;
361 /* Adjust checksum to count the "chksum" field as blanks. */
363 for (i
= sizeof (header
->header
.chksum
); i
-- != 0;)
365 unsigned_sum
-= 0xFF & header
->header
.chksum
[i
];
366 signed_sum
-= header
->header
.chksum
[i
];
368 unsigned_sum
+= ' ' * sizeof header
->header
.chksum
;
369 signed_sum
+= ' ' * sizeof header
->header
.chksum
;
371 if (unsigned_sum
== sizeof header
->header
.chksum
* ' ')
373 /* This is a zeroed block...whole block is 0's except for the
374 blanks we faked for the checksum field. */
376 return HEADER_ZERO_BLOCK
;
379 if (unsigned_sum
!= recorded_sum
&& signed_sum
!= recorded_sum
)
380 return HEADER_FAILURE
;
382 /* Good block. Decode file size and return. */
384 if (header
->header
.typeflag
== LNKTYPE
)
385 current_stat
.st_size
= 0; /* links 0 size on tape */
387 current_stat
.st_size
= OFF_FROM_CHARS (header
->header
.size
);
389 header
->header
.name
[NAME_FIELD_SIZE
- 1] = '\0';
390 if (header
->header
.typeflag
== GNUTYPE_LONGNAME
391 || header
->header
.typeflag
== GNUTYPE_LONGLINK
)
393 longp
= ((header
->header
.typeflag
== GNUTYPE_LONGNAME
)
397 set_next_block_after (header
);
400 size
= current_stat
.st_size
;
401 if (size
!= current_stat
.st_size
)
402 FATAL_ERROR ((0, 0, _("Memory exhausted")));
403 bp
= *longp
= (char *) xmalloc (size
);
405 for (; size
> 0; size
-= written
)
407 data_block
= find_next_block ();
408 if (data_block
== NULL
)
410 ERROR ((0, 0, _("Unexpected EOF on archive file")));
413 written
= available_space_after (data_block
);
417 memcpy (bp
, data_block
->buffer
, written
);
419 set_next_block_after ((union block
*)
420 (data_block
->buffer
+ written
- 1));
428 char *name
= next_long_name
;
429 struct posix_header
*h
= ¤t_header
->header
;
430 char namebuf
[sizeof h
->prefix
+ 1 + sizeof h
->name
+ 1];
434 /* Accept file names as specified by POSIX.1-1996
439 memcpy (np
, h
->prefix
, sizeof h
->prefix
);
440 np
[sizeof h
->prefix
] = '\0';
444 memcpy (np
, h
->name
, sizeof h
->name
);
445 np
[sizeof h
->name
] = '\0';
449 assign_string (¤t_file_name
, name
);
450 assign_string (¤t_link_name
,
451 (next_long_link
? next_long_link
452 : current_header
->header
.linkname
));
453 next_long_link
= next_long_name
= 0;
454 return HEADER_SUCCESS
;
459 /*-------------------------------------------------------------------------.
460 | Decode things from a file HEADER block into STAT_INFO, also setting |
461 | *FORMAT_POINTER depending on the header block format. If DO_USER_GROUP, |
462 | decode the user/group information (this is useful for extraction, but |
463 | waste time when merely listing). |
465 | read_header() has already decoded the checksum and length, so we don't. |
467 | This routine should *not* be called twice for the same block, since the |
468 | two calls might use different DO_USER_GROUP values and thus might end up |
469 | with different uid/gid for the two calls. If anybody wants the uid/gid |
470 | they should decode it first, and other callers should decode it without |
471 | uid/gid before calling a routine, e.g. print_header, that assumes |
473 `-------------------------------------------------------------------------*/
476 decode_header (union block
*header
, struct stat
*stat_info
,
477 enum archive_format
*format_pointer
, int do_user_group
)
479 enum archive_format format
;
481 if (strcmp (header
->header
.magic
, TMAGIC
) == 0)
482 format
= POSIX_FORMAT
;
483 else if (strcmp (header
->header
.magic
, OLDGNU_MAGIC
) == 0)
484 format
= OLDGNU_FORMAT
;
487 *format_pointer
= format
;
489 stat_info
->st_mode
= MODE_FROM_CHARS (header
->header
.mode
);
490 stat_info
->st_mtime
= TIME_FROM_CHARS (header
->header
.mtime
);
492 if (format
== OLDGNU_FORMAT
&& incremental_option
)
494 stat_info
->st_atime
= TIME_FROM_CHARS (header
->oldgnu_header
.atime
);
495 stat_info
->st_ctime
= TIME_FROM_CHARS (header
->oldgnu_header
.ctime
);
498 if (format
== V7_FORMAT
)
500 stat_info
->st_uid
= UID_FROM_CHARS (header
->header
.uid
);
501 stat_info
->st_gid
= GID_FROM_CHARS (header
->header
.gid
);
502 stat_info
->st_rdev
= 0;
508 /* FIXME: Decide if this should somewhat depend on -p. */
510 if (numeric_owner_option
511 || !*header
->header
.uname
512 || !uname_to_uid (header
->header
.uname
, &stat_info
->st_uid
))
513 stat_info
->st_uid
= UID_FROM_CHARS (header
->header
.uid
);
515 if (numeric_owner_option
516 || !*header
->header
.gname
517 || !gname_to_gid (header
->header
.gname
, &stat_info
->st_gid
))
518 stat_info
->st_gid
= GID_FROM_CHARS (header
->header
.gid
);
520 switch (header
->header
.typeflag
)
524 = makedev (MAJOR_FROM_CHARS (header
->header
.devmajor
),
525 MINOR_FROM_CHARS (header
->header
.devminor
));
530 = makedev (MAJOR_FROM_CHARS (header
->header
.devmajor
),
531 MINOR_FROM_CHARS (header
->header
.devminor
));
535 stat_info
->st_rdev
= 0;
540 /*------------------------------------------------------------------------.
541 | Convert buffer at WHERE0 of size DIGS from external format to uintmax_t.|
542 | The data is of type TYPE. The buffer must represent a value in the |
543 | range -MINUS_MINVAL through MAXVAL. |
544 `------------------------------------------------------------------------*/
547 from_chars (char const *where0
, size_t digs
, char const *type
,
548 uintmax_t minus_minval
, uintmax_t maxval
)
551 char const *where
= where0
;
552 char const *lim
= where
+ digs
;
561 _("Blanks in header where numeric %s value expected"),
565 if (!ISSPACE ((unsigned char) *where
))
571 if (ISODIGIT (*where
))
575 if (value
<< LG_8
>> LG_8
!= value
)
577 value
= (value
<< LG_8
) | (*where
++ - '0');
579 while (where
!= lim
&& ISODIGIT (*where
));
581 /* Parse the output of older tars, which output negative values
582 in two's complement octal. This method works only if the
583 type has the same number of bits as it did on the host that
584 created the tar file, but that's the best we can do. */
585 if (maxval
< value
&& value
- maxval
<= minus_minval
)
587 value
= minus_minval
- (value
- maxval
);
591 else if (*where
== '-' || *where
== '+')
594 negative
= *where
++ == '-';
596 && (dig
= base64_map
[(unsigned char) *where
]) < 64)
598 if (value
<< LG_64
>> LG_64
!= value
)
600 value
= (value
<< LG_64
) | dig
;
605 if (where
!= lim
&& *where
&& !ISSPACE ((unsigned char) *where
))
609 char buf
[1000]; /* Big enough to represent any header. */
610 static struct quoting_options
*o
;
614 o
= clone_quoting_options ((struct quoting_options
*) 0);
615 set_quoting_style (o
, c_quoting_style
);
618 while (where0
!= lim
&& ! lim
[-1])
620 quotearg_buffer (buf
, sizeof buf
, where0
, lim
- where
, o
);
622 _("Header contains `%.*s' where numeric %s value expected"),
623 (int) sizeof buf
, buf
, type
));
629 if (value
<= (negative
? minus_minval
: maxval
))
630 return negative
? -value
: value
;
634 ERROR ((0, 0, _("Numeric value `%.*s' is out of range for %s"),
635 (int) digs
, where0
, type
));
640 gid_from_chars (const char *p
, size_t s
)
642 return from_chars (p
, s
, "gid_t",
643 - (uintmax_t) TYPE_MINIMUM (gid_t
),
644 (uintmax_t) TYPE_MAXIMUM (gid_t
));
648 major_from_chars (const char *p
, size_t s
)
650 return from_chars (p
, s
, "major_t",
651 - (uintmax_t) TYPE_MINIMUM (major_t
),
652 (uintmax_t) TYPE_MAXIMUM (major_t
));
656 minor_from_chars (const char *p
, size_t s
)
658 return from_chars (p
, s
, "minor_t",
659 - (uintmax_t) TYPE_MINIMUM (minor_t
),
660 (uintmax_t) TYPE_MAXIMUM (minor_t
));
664 mode_from_chars (const char *p
, size_t s
)
666 /* Do not complain about unrecognized mode bits. */
667 unsigned u
= from_chars (p
, s
, "mode_t",
668 - (uintmax_t) TYPE_MINIMUM (mode_t
),
669 TYPE_MAXIMUM (uintmax_t));
670 return ((u
& TSUID
? S_ISUID
: 0)
671 | (u
& TSGID
? S_ISGID
: 0)
672 | (u
& TSVTX
? S_ISVTX
: 0)
673 | (u
& TUREAD
? S_IRUSR
: 0)
674 | (u
& TUWRITE
? S_IWUSR
: 0)
675 | (u
& TUEXEC
? S_IXUSR
: 0)
676 | (u
& TGREAD
? S_IRGRP
: 0)
677 | (u
& TGWRITE
? S_IWGRP
: 0)
678 | (u
& TGEXEC
? S_IXGRP
: 0)
679 | (u
& TOREAD
? S_IROTH
: 0)
680 | (u
& TOWRITE
? S_IWOTH
: 0)
681 | (u
& TOEXEC
? S_IXOTH
: 0));
685 off_from_chars (const char *p
, size_t s
)
687 return from_chars (p
, s
, "off_t",
688 - (uintmax_t) TYPE_MINIMUM (off_t
),
689 (uintmax_t) TYPE_MAXIMUM (off_t
));
693 size_from_chars (const char *p
, size_t s
)
695 return from_chars (p
, s
, "size_t", (uintmax_t) 0,
696 (uintmax_t) TYPE_MAXIMUM (size_t));
700 time_from_chars (const char *p
, size_t s
)
702 return from_chars (p
, s
, "time_t",
703 - (uintmax_t) TYPE_MINIMUM (time_t),
704 (uintmax_t) TYPE_MAXIMUM (time_t));
708 uid_from_chars (const char *p
, size_t s
)
710 return from_chars (p
, s
, "uid_t", (uintmax_t) 0,
711 (uintmax_t) TYPE_MAXIMUM (uid_t
));
715 uintmax_from_chars (const char *p
, size_t s
)
717 return from_chars (p
, s
, "uintmax_t", (uintmax_t) 0,
718 TYPE_MAXIMUM (uintmax_t));
722 /*----------------------------------------------------------------------.
723 | Format O as a null-terminated decimal string into BUF _backwards_; |
724 | return pointer to start of result. |
725 `----------------------------------------------------------------------*/
727 stringify_uintmax_t_backwards (uintmax_t o
, char *buf
)
731 *--buf
= '0' + (int) (o
% 10);
732 while ((o
/= 10) != 0);
738 /*-------------------------------------------.
739 | Return the time formatted along ISO 8601. |
740 `-------------------------------------------*/
742 /* Also, see http://www.ft.uni-erlangen.de/~mskuhn/iso-time.html. */
745 isotime (const time_t *time
)
747 static char buffer
[21];
750 tm
= localtime (time
);
751 sprintf (buffer
, "%4d-%02d-%02d %02d:%02d:%02d\n",
752 tm
->tm_year
+ 1900, tm
->tm_mon
+ 1, tm
->tm_mday
,
753 tm
->tm_hour
, tm
->tm_min
, tm
->tm_sec
);
757 #endif /* not USE_OLD_CTIME */
759 /*-------------------------------------------------------------------------.
760 | Decode MODE from its binary form in a stat structure, and encode it into |
761 | a 9 characters string STRING, terminated with a NUL. |
762 `-------------------------------------------------------------------------*/
765 decode_mode (mode_t mode
, char *string
)
767 *string
++ = mode
& S_IRUSR
? 'r' : '-';
768 *string
++ = mode
& S_IWUSR
? 'w' : '-';
769 *string
++ = (mode
& S_ISUID
770 ? (mode
& S_IXUSR
? 's' : 'S')
771 : (mode
& S_IXUSR
? 'x' : '-'));
772 *string
++ = mode
& S_IRGRP
? 'r' : '-';
773 *string
++ = mode
& S_IWGRP
? 'w' : '-';
774 *string
++ = (mode
& S_ISGID
775 ? (mode
& S_IXGRP
? 's' : 'S')
776 : (mode
& S_IXGRP
? 'x' : '-'));
777 *string
++ = mode
& S_IROTH
? 'r' : '-';
778 *string
++ = mode
& S_IWOTH
? 'w' : '-';
779 *string
++ = (mode
& S_ISVTX
780 ? (mode
& S_IXOTH
? 't' : 'T')
781 : (mode
& S_IXOTH
? 'x' : '-'));
785 /*-------------------------------------------------------------------------.
786 | Actually print it. |
788 | Plain and fancy file header block logging. Non-verbose just prints the |
789 | name, e.g. for "tar t" or "tar x". This should just contain file names, |
790 | so it can be fed back into tar with xargs or the "-T" option. The |
791 | verbose option can give a bunch of info, one line per file. I doubt |
792 | anybody tries to parse its format, or if they do, they shouldn't. Unix |
793 | tar is pretty random here anyway. |
794 `-------------------------------------------------------------------------*/
796 /* FIXME: Note that print_header uses the globals HEAD, HSTAT, and
797 HEAD_STANDARD, which must be set up in advance. Not very clean... */
799 /* UGSWIDTH starts with 18, so with user and group names <= 8 chars, the
800 columns never shift during the listing. */
802 static int ugswidth
= UGSWIDTH
; /* maximum width encountered so far */
804 /* DATEWIDTH is the number of columns taken by the date and time fields. */
806 # define DATEWIDTH 19
808 # define DATEWIDTH 18
816 /* These hold formatted ints. */
817 char uform
[UINTMAX_STRSIZE_BOUND
], gform
[UINTMAX_STRSIZE_BOUND
];
819 char size
[2 * UINTMAX_STRSIZE_BOUND
];
820 /* holds formatted size or major,minor */
821 char uintbuf
[UINTMAX_STRSIZE_BOUND
];
822 time_t longie
; /* to make ctime() call portable */
826 if (block_number_option
)
828 char buf
[UINTMAX_STRSIZE_BOUND
];
829 fprintf (stdlis
, _("block %s: "),
830 STRINGIFY_BIGINT (current_block_ordinal (), buf
));
833 if (verbose_option
<= 1)
835 /* Just the fax, mam. */
837 char *quoted_name
= quote_copy_string (current_file_name
);
841 fprintf (stdlis
, "%s\n", quoted_name
);
845 fprintf (stdlis
, "%s\n", current_file_name
);
849 /* File type and modes. */
852 switch (current_header
->header
.typeflag
)
858 case GNUTYPE_MULTIVOL
:
866 case GNUTYPE_LONGNAME
:
867 case GNUTYPE_LONGLINK
:
868 ERROR ((0, 0, _("Visible longname error")));
876 if (current_file_name
[strlen (current_file_name
) - 1] == '/')
879 case GNUTYPE_DUMPDIR
:
902 decode_mode (current_stat
.st_mode
, modes
+ 1);
906 longie
= current_stat
.st_mtime
;
908 timestamp
= ctime (&longie
);
909 timestamp
[16] = '\0';
910 timestamp
[24] = '\0';
912 timestamp
= isotime (&longie
);
913 timestamp
[16] = '\0';
916 /* User and group names. */
918 if (*current_header
->header
.uname
&& current_format
!= V7_FORMAT
919 && !numeric_owner_option
)
920 user
= current_header
->header
.uname
;
922 user
= STRINGIFY_BIGINT (UINTMAX_FROM_CHARS
923 (current_header
->header
.uid
),
926 if (*current_header
->header
.gname
&& current_format
!= V7_FORMAT
927 && !numeric_owner_option
)
928 group
= current_header
->header
.gname
;
930 group
= STRINGIFY_BIGINT (UINTMAX_FROM_CHARS
931 (current_header
->header
.gid
),
934 /* Format the file size or major/minor device numbers. */
936 switch (current_header
->header
.typeflag
)
940 sprintf (size
, "%lu,%lu",
941 (unsigned long) major (current_stat
.st_rdev
),
942 (unsigned long) minor (current_stat
.st_rdev
));
947 (UINTMAX_FROM_CHARS (current_header
->oldgnu_header
.realsize
),
951 strcpy (size
, STRINGIFY_BIGINT (current_stat
.st_size
, uintbuf
));
955 /* Figure out padding and print the whole line. */
957 pad
= strlen (user
) + strlen (group
) + strlen (size
) + 1;
962 fprintf (stdlis
, "%s %s/%s %*s%s %s %s",
963 modes
, user
, group
, ugswidth
- pad
, "",
964 size
, timestamp
+ 4, timestamp
+ 20);
966 fprintf (stdlis
, "%s %s/%s %*s%s %s",
967 modes
, user
, group
, ugswidth
- pad
, "", size
, timestamp
);
970 name
= quote_copy_string (current_file_name
);
973 fprintf (stdlis
, " %s", name
);
977 fprintf (stdlis
, " %s", current_file_name
);
979 switch (current_header
->header
.typeflag
)
982 name
= quote_copy_string (current_link_name
);
985 fprintf (stdlis
, " -> %s\n", name
);
989 fprintf (stdlis
, " -> %s\n", current_link_name
);
993 name
= quote_copy_string (current_link_name
);
996 fprintf (stdlis
, _(" link to %s\n"), name
);
1000 fprintf (stdlis
, _(" link to %s\n"), current_link_name
);
1004 fprintf (stdlis
, _(" unknown file type `%c'\n"),
1005 current_header
->header
.typeflag
);
1010 case GNUTYPE_SPARSE
:
1016 case GNUTYPE_DUMPDIR
:
1017 putc ('\n', stdlis
);
1020 case GNUTYPE_VOLHDR
:
1021 fprintf (stdlis
, _("--Volume Header--\n"));
1024 case GNUTYPE_MULTIVOL
:
1027 (UINTMAX_FROM_CHARS (current_header
->oldgnu_header
.offset
),
1029 fprintf (stdlis
, _("--Continued at byte %s--\n"), size
);
1033 fprintf (stdlis
, _("--Mangled file names--\n"));
1040 /*--------------------------------------------------------------.
1041 | Print a similar line when we make a directory automatically. |
1042 `--------------------------------------------------------------*/
1045 print_for_mkdir (char *pathname
, int length
, mode_t mode
)
1050 if (verbose_option
> 1)
1052 /* File type and modes. */
1055 decode_mode (mode
, modes
+ 1);
1057 if (block_number_option
)
1059 char buf
[UINTMAX_STRSIZE_BOUND
];
1060 fprintf (stdlis
, _("block %s: "),
1061 STRINGIFY_BIGINT (current_block_ordinal (), buf
));
1063 name
= quote_copy_string (pathname
);
1066 fprintf (stdlis
, "%s %*s %.*s\n", modes
, ugswidth
+ DATEWIDTH
,
1067 _("Creating directory:"), length
, name
);
1071 fprintf (stdlis
, "%s %*s %.*s\n", modes
, ugswidth
+ DATEWIDTH
,
1072 _("Creating directory:"), length
, pathname
);
1076 /*--------------------------------------------------------.
1077 | Skip over SIZE bytes of data in blocks in the archive. |
1078 `--------------------------------------------------------*/
1081 skip_file (off_t size
)
1085 if (multi_volume_option
)
1087 save_totsize
= size
;
1088 save_sizeleft
= size
;
1093 x
= find_next_block ();
1095 FATAL_ERROR ((0, 0, _("Unexpected EOF on archive file")));
1097 set_next_block_after (x
);
1099 if (multi_volume_option
)
1100 save_sizeleft
-= BLOCKSIZE
;
1109 skip_extended_headers (void)
1115 exhdr
= find_next_block ();
1116 if (!exhdr
->sparse_header
.isextended
)
1118 set_next_block_after (exhdr
);
1121 set_next_block_after (exhdr
);