Documentation ¶
Index ¶
- Variables
- func AutoDecompress(stream io.Reader) (io.ReadCloser, bool, error)
- func Bzip2Decompressor(r io.Reader) (io.ReadCloser, error)
- func CompressStream(dest io.Writer, algo Algorithm, level *int) (io.WriteCloser, error)
- func CompressStreamWithMetadata(dest io.Writer, metadata map[string]string, algo Algorithm, level *int) (io.WriteCloser, error)
- func DetectCompressionFormat(input io.Reader) (Algorithm, DecompressorFunc, io.Reader, error)
- func GzipDecompressor(r io.Reader) (io.ReadCloser, error)
- func XzDecompressor(r io.Reader) (io.ReadCloser, error)
- func ZstdDecompressor(r io.Reader) (io.ReadCloser, error)
- type Algorithm
- type DecompressorFunc
Constants ¶
This section is empty.
Variables ¶
var ( // Gzip compression. Gzip = internal.NewAlgorithm(types.GzipAlgorithmName, types.GzipAlgorithmName, []byte{0x1F, 0x8B, 0x08}, GzipDecompressor, gzipCompressor) // Bzip2 compression. Bzip2 = internal.NewAlgorithm(types.Bzip2AlgorithmName, types.Bzip2AlgorithmName, []byte{0x42, 0x5A, 0x68}, Bzip2Decompressor, bzip2Compressor) // Xz compression. Xz = internal.NewAlgorithm(types.XzAlgorithmName, types.XzAlgorithmName, []byte{0xFD, 0x37, 0x7A, 0x58, 0x5A, 0x00}, XzDecompressor, xzCompressor) // Zstd compression. Zstd = internal.NewAlgorithm(types.ZstdAlgorithmName, types.ZstdAlgorithmName, []byte{0x28, 0xb5, 0x2f, 0xfd}, ZstdDecompressor, zstdCompressor) // Zstd:chunked compression. ZstdChunked = internal.NewAlgorithm(types.ZstdChunkedAlgorithmName, types.ZstdAlgorithmName, nil, ZstdDecompressor, compressor.ZstdCompressor) )
Functions ¶
func AutoDecompress ¶
AutoDecompress takes a stream and returns an uncompressed version of the same stream. The caller must call Close() on the returned stream (even if the input does not need, or does not even support, closing!).
func Bzip2Decompressor ¶
func Bzip2Decompressor(r io.Reader) (io.ReadCloser, error)
Bzip2Decompressor is a DecompressorFunc for the bzip2 compression algorithm.
func CompressStream ¶
CompressStream returns the compressor by its name
func CompressStreamWithMetadata ¶
func CompressStreamWithMetadata(dest io.Writer, metadata map[string]string, algo Algorithm, level *int) (io.WriteCloser, error)
CompressStreamWithMetadata returns the compressor by its name. If the compression generates any metadata, it is written to the provided metadata map.
func DetectCompressionFormat ¶
DetectCompressionFormat returns an Algorithm and DecompressorFunc if the input is recognized as a compressed format, an invalid value and nil otherwise. Because it consumes the start of input, other consumers must use the returned io.Reader instead to also read from the beginning.
func GzipDecompressor ¶
func GzipDecompressor(r io.Reader) (io.ReadCloser, error)
GzipDecompressor is a DecompressorFunc for the gzip compression algorithm.
func XzDecompressor ¶
func XzDecompressor(r io.Reader) (io.ReadCloser, error)
XzDecompressor is a DecompressorFunc for the xz compression algorithm.
func ZstdDecompressor ¶
func ZstdDecompressor(r io.Reader) (io.ReadCloser, error)
ZstdDecompressor is a DecompressorFunc for the zstd compression algorithm.
Types ¶
type Algorithm ¶
Algorithm is a compression algorithm that can be used for CompressStream.
func AlgorithmByName ¶
AlgorithmByName returns the compressor by its name
type DecompressorFunc ¶
type DecompressorFunc = internal.DecompressorFunc
DecompressorFunc returns the decompressed stream, given a compressed stream. The caller must call Close() on the decompressed stream (even if the compressed input stream does not need closing!).
func DetectCompression ¶
DetectCompression returns a DecompressorFunc if the input is recognized as a compressed format, nil otherwise. Because it consumes the start of input, other consumers must use the returned io.Reader instead to also read from the beginning.