COMPACT(1)
NAME
compact, uncompact, ccat − compress and uncompress files, and then cat them
USAGE
compact [ name ... ]
uncompact [ name ... ]
ccat [ file ... ]
DESCRIPTION
Compact compresses the named files using an adaptive Huffman code. If no filenames are given, the standard input is compacted to the standard output. Compact operates as an on-line algorithm. Each time a byte is read, it is encoded immediately according to the current prefix code. This code is an optimal Huffman code for the set of frequencies seen so far. It is unnecessary to prepend a decoding tree to the compressed file, since the encoder and the decoder start in the same state and stay synchronized. Furthermore, compact and uncompact can operate as filters. In particular,
... | compact | uncompact |
operates as a very slow no-op.
When an argument file is given, it is compacted and the resulting file is placed in file.C; file is removed. The first two bytes of the compacted file code the fact that the file is compacted. This code is used to prohibit recompaction.
The amount of compression to be expected depends on the type of file being compressed. Typical compression values are: text (38%), Pascal source (43%), C source (36%), and binary (19%). These values are the percentages of file bytes reduced.
Uncompact restores the original file from a file compressed by compact. If no filenames are given, the standard input is uncompacted to the standard output.
Ccat concatenates the original file from a file compressed by compact, without uncompressing the file.
CAUTIONS
The last segment of the filename must contain fewer than 30 characters to allow space for the .C that gets appended.
FILES
*.Ccompacted file created by compact, removed by uncompact