.TH TAR 1 .UC .SH NAME tar \- tape archiver .SH SYNOPSIS .B tar [ key ] [ name ... ] .SH DESCRIPTION .PP .I Tar saves and restores multiple files on a single file (usually a magnetic tape, but it can be any file). .IR Tar 's actions are controlled by the .I key argument. The .I key is a string of characters containing at most one function letter and possibly one or more function modifiers. Other arguments to .I tar are file or directory names specifying which files to dump or restore. In all cases, appearance of a directory name refers to the files and (recursively) subdirectories of that directory. .PP The function portion of the key is specified by one of the following letters: .TP 8 .B r The named files are written on the end of the tape. The .B c function implies this. .TP 8 .B x The named files are extracted from the tape. If the named file matches a directory whose contents had been written onto the tape, this directory is (recursively) extracted. The owner, modification time, and mode are restored (if possible; but see the .B p flag below). If no file argument is given, the entire content of the tape is extracted. Note that if multiple entries specifying the same file are on the tape, the last one overwrites all earlier. .TP 8 .B t The names of the specified files are listed each time they occur on the tape. If no file argument is given, all of the names on the tape are listed. .TP 8 .B u The named files are added to the tape if either they are not already there or have been modified since last put on the tape. .TP 8 .B c Create a new tape; writing begins on the beginning of the tape instead of after the last file. This command implies .BR r . .TP 8 .B C Compare the files on the tape to the named files; do comparisons for all files on the tape if there are no arguments. .TP 8 .B X The following argument is taken to be the name of a directory whose contents are compared to the named files, or all files on the tape if there are no additional arguments. The files are extracted, compared to those in the specified directory, and if they are identical to those in the other directory, they are linked to the corresponding files there. The named directory must be on the same mounted filesystem as the current directory. .PP The following characters may be used in addition to the letter which selects the function desired. .TP 10 .B 0, ..., 7 This modifier selects an alternate drive on which the tape is mounted. The default is drive 0 at 1600 bpi, which is normally /dev/rmt1. .TP 10 .B v Normally .I tar does its work silently. The .B v (verbose) option make .I tar type the name of each file it treats preceded by the function letter. With the .B t function, the verbose option gives more information about the tape entries than just their names. .TP 10 .B w .I Tar prints the action to be taken followed by file name, then wait for user confirmation. If a word beginning with `y' is given, the action is done. Any other input means don't do it. .TP 10 .B f .I Tar uses the next argument as the name of the archive instead of /dev/rmt?. If the name of the file is `\-', tar writes to standard output or reads from standard input, whichever is appropriate. Thus, .I tar can be used as the head or tail of a filter chain. .I Tar can also be used to move hierarchies with the command .ce 1 cd fromdir; tar cf \- . | (cd todir; tar xf \-) .TP 10 .B b .I Tar uses the next argument as the blocking factor for tape records. The default is 20 (the maximum) for tape files, 2 otherwise. This option should only be used with raw magnetic tape archives (See .B f above). The block size is determined automatically when reading tapes (key letters `r', `x' and `t'). .TP 10 .B l tells .I tar to complain if it cannot resolve all of the links to the files dumped. If this is not specified, no error messages are printed. .TP 10 .B m tells .I tar not to restore the modification times. The modification time will be the time of extraction. .TP 10 .B o Tar normally places information specifying owner and modes of directories in the archive. Former versions of tar, when encountering this information will give error message of the form .br ``/: cannot create''. .br This option will suppress the directory information. .TP 10 .B p Preserve all of the mode information. Files are restored to their original modes, ignoring the present .IR umask (2). Setuid and sticky information will also be restored for the super-user. .TP 10 .B h Force .I tar to follow symbolic links as if they were normal files or directories. Normally, .I tar does not follow symbolic links. .PP When creating an archive, a .BI "\-C " directory embedded in the list of filenames instructs .I tar to perform a .IR chdir (2) to the named .I directory before continuing to the next file. This allows multiple directories not related by a close common parent to be archived using short relative path names. For example, to archive files from /usr/include and from /etc, one might use .ti +0.5i tar c \-C /usr include \-C / etc .PP Previous restrictions dealing with .IR tar 's inability to properly update blocked archives have been lifted. This is dependent on the use of system tape handlers that support tape backspace operations. Archives on disk can be updated, but the blocking factor used must agree with that used to create the archive (which is difficult to determine); such operations are therefore somewhat risky. This version of .I tar uses a blocking factor of 2 by default for both creating and updating disk archives. .PP .SH FILES /dev/rmt? .br /tmp/tar* .SH DIAGNOSTICS Complaints about bad key characters and tape read/write errors. .br Complaints if enough memory is not available to hold the link tables. .SH BUGS There is no way to ask for the .IR n -th occurrence of a file. Use the .B w option to extract the desired file. .br Tape errors are handled ungracefully. .br The .BR u , " C " and " X" options can be slow. .br The current limit on file name length is 100 characters. .br There is no way to selectively follow symbolic links.