If no files are specified, the list of input files is read from standard input. Standard input must not be a terminal.
Allow positional parameter options. The compression method and encoding method options may be intermixed with file names. Files named after these options will be processed in the specified way.
The gzip, bzip2 and compress compactor commands may be specified by the program name as the option name, e.g. --gzip. Those options, however, are being deprecated. There is also the xz compactor now. Specify xz with -C xz or --compactor=xz.
Specifying the compactor "none" will disable file
compression.
Compressed files are never processed as plain text. They are always uuencoded
and the recipient must have uudecode to unpack them.
Specifying the compactor compress is deprecated.
in the range 1 through 9The default level for this option is: 9
Some compression programs allow for a level of compression. The default is 9, but this option allows you to specify something else. This value is used by gzip, bzip2 and xz, but not compress.
bzip2 compress and uuencode all files prior to packing. The recipient must have uudecode bzip2 in order to unpack.
NOTE: THIS OPTION IS DEPRECATED
gzip compress and uuencode all files prior to packing. The recipient must have uudecode and gzip in order to unpack.
NOTE: THIS OPTION IS DEPRECATED
compress and uuencode all files prior to packing. The recipient must have uudecode and compress in order to unpack.
NOTE: THIS OPTION IS DEPRECATED
NOTE: THIS OPTION IS DEPRECATED
This is the compression factor used by the compress program.
NOTE: THIS OPTION IS DEPRECATED
Automatically determine if the files are text or binary and archive correctly. Files found to be binary are uuencoded prior to packing. This is the default behavior for shar.
For a file to be considered a text file instead of a binary file, all the following should be true:
The file does not contain any ASCII control character besides BS (backspace), HT (horizontal tab), LF (new line) or FF (form feed).
The file contains no character with its eighth-bit set.
The file contains no line beginning with the five letters "from ", capitalized or not. (Mail handling programs will often gratuitously insert a > character before it.)
The file is either empty or ends with a LF (newline) byte.
No line in the
file contains more than 200 characters. For counting purpose, lines are
separated by a LF (newline).
Use uuencode prior to packing all files. This increases the size of the archive. The recipient must have uudecode in order to unpack. Compressed files are always encoded.
If you have files with non-ascii bytes or text that some mail handling programs do not like, you may find difficulties. However, if you are using FTP or SSH/SCP, the non-conforming text files should be okay.
Save the archive to files prefix.01 thru prefix.nn instead of sending all output to standard out. Must be specified when the --whole-size-limit or --split-size-limit options are specified.
When prefix contains a % character, prefix is then interpreted as a sprintf format, which should be able to display a single decimal number. When prefix does not contain such a % character, the string .%02d is internally appended.
in the range 8 through 1023, or in the range 8192 through 4194304
Limit the output file size to size bytes, but don’t split input files. If size is less than 1024, then it will be multiplied by 1024. The value may also be specified with a k, K, m or M suffix. The number is then multiplied by 1000, 1024, 1000000, or 1048576, respectively. 4M (4194304) is the maximum allowed.
Unlike the split-size-limit option, this allows the recipient of the shar files to unpack them in any order.
in the range 8 through 1023, or in the range 8192 through 4194304
Limit output file size to size bytes, splitting files if necessary. The allowed values are specified as with the --whole-size-limit option.
The archive parts created with this option must be unpacked in the correct order. If the recipient of the shell archives wants to put all of them in a single email folder (file), they will have to be saved in the correct order for unshar to unpack them all at once (using one of the split archive options). see: unshar Invocation.
This option causes file to be reopened as standard input. If no files are found on the input line, then standard input is read for input file names. Use of this option will prohibit input files from being listed on the command line.
Input must be in a form similar to that generated by find, one filename per line. This switch is especially useful when the command line will not hold the list of files to be archived.
If the --intermix-type option is specified on the command line, then the compression options may be included in the standard input on lines by themselves and no file name may begin with a hyphen.
For example:
{ echo --compact xz find . -type f -print | sort } | shar -S -p -L50K -o /somewhere/big
This option is actually a no-op. It is a wrapper for --input-file-list=-.
NOTE: THIS OPTION IS DEPRECATED
Name of archive to be included in the subject header of the shar files. See the --net-headers option.
shar will normally determine the submitter name by querying the system. Use this option if it is being done on behalf of another.
Adds specialized email headers:
Submitted-by: who@@where Archive-name: name/part##The who@@where is normally derived, but can be specified with the --submitter option. The name must be provided with the --archive-name option. If the archive name includes a slash (/) character, then the /part## is omitted. Thus -n xyzzy produces:
xyzzy/part01 xyzzy/part02
while -n xyzzy/patch produces:
xyzzy/patch01 xyzzy/patch02
and -n xyzzy/patch01. produces:
xyzzy/patch01.01 xyzzy/patch01.02
A line saying ’Cut here’ is placed at the start of each output file.
Translate messages in the script. If you have set the LANG environment variable, messages printed by shar will be in the specified language. The produced script will still be emitted using messages in the lingua franca of the computer world: English. This option will cause the script messages to appear in the languages specified by the LANG environment variable set when the script is produced.
Do NOT check each file with ’wc -c’ after unpack. The default is to check.
Do not use md5sum digest to verify the unpacked files. The default is to check.
Forces the prefix character to be prepended to every line, even if not required. This option may slightly increase the size of the archive, especially if --uuencode or a compression option is used.
Use DELIM to delimit the files in the shar instead of SHAR_EOF. This is for those who want to personalize their shar files. The delimiter will always be prefixed and suffixed with underscores.
This option produces vanilla shars which rely only upon the existence of echo, test and sed in the unpacking environment.
It changes the default behavior from mixed mode (--mixed-uuencode) to text mode (--text-files). Warnings are produced if options are specified that will require decompression or decoding in the unpacking environment.
In the shar file, use a temporary file to hold file contents between unpacking stages instead of using pipes. This option is mandatory when you know the unpacking will happen on systems that do not support pipes.
Create the archive so that when processed it will overwrite existing files without checking first. If neither this option nor the --query-user option is specified, the unpack will not overwrite pre-existing files. In all cases, however, if --cut-mark is passed as a parameter to the script when unpacking, then existing files will be overwritten unconditionally.
sh shar-archive-file -c
When unpacking, interactively ask the user if files should be overwritten. Do not use for shars submitted to the net.
Use of this option produces shars which will cause problems with some unshar-style procedures, particularily when used together with vanilla mode (--vanilla-operation). Use this feature mainly for archives to be passed among agreeable parties. Certainly, -X is not for shell archives which are to be submitted to Usenet or other public networks.
The problem is that unshar programs or procedures often feed /bin/sh from its standard input, thus putting /bin/sh and the shell archive script in competition for input lines. As an attempt to alleviate this problem, shar will try to detect if /dev/tty exists at the receiving site and will use it to read user replies. But this does not work in all cases, it may happen that the receiving user will have to avoid using unshar programs or procedures, and call /bin/sh directly. In vanilla mode, using /dev/tty is not even attempted.
Avoid generating ’touch’ commands to restore the file modification dates when unpacking files from the archive.
When file modification times are not preserved, project build programs like "make" will see built files older than the files they get built from. This is why, when this option is not used, a special effort is made to restore timestamps.
Verbose OFF. Disables the inclusion of comments to be output when the archive is unpacked.
Restore by the base file name only, rather than path. This option causes only file names to be used, which is useful when building a shar from several directories, or another directory. Note that if a directory name is passed to shar, the substructure of that directory will be restored whether this option is specified or not.
Do not produce internationalized shell archives, use default English messages. By default, shar produces archives that will try to output messages in the unpackers preferred language (as determined by the LANG/LC_MESSAGES environmental variables) when they are unpacked. If no message file for the unpackers language is found at unpack time, messages will be in English.
Prints the directory shar looks in to find messages files for different languages, then immediately exits.
omit progress messages.
If a directory is passed to shar, it may be scanned more than once, to conserve memory. Therefore, do not change the directory contents while shar is running.
Be careful that the output file(s) are not included in the inputs or shar may loop until the disk fills up. Be particularly careful when a directory is passed to shar that the output files are not in that directory or a subdirectory of it.
Use of the compression and encoding options will slow the archive process, perhaps considerably.
Use of the --query-user produces shars which will cause problems with many unshar procedures. Use this feature only for archives to be passed among agreeable parties. Certainly, query-user is NOT for shell archives which are to be distributed across the net. The use of compression in net shars will cause you to be flamed off the earth. Not using the --no-timestamp or --force-prefix options may also get you occasional complaints. Put these options into your ~/.sharrc file.
shar *.c > cprog.shar shar -Q *.[ch] > cprog.shar shar -B -l28 -oarc.sh *.arc shar -f /lcl/src/u*.c > u.sh
Please send bug reports to: bug-gnu-utils@gnu.org