Платформа ЦРНП "Мирокод" для разработки проектов
https://git.mirocod.ru
124 lines
3.7 KiB
124 lines
3.7 KiB
/* |
|
* XZ decompressor |
|
* |
|
* Authors: Lasse Collin <lasse.collin@tukaani.org> |
|
* Igor Pavlov <http://7-zip.org/> |
|
* |
|
* Translation to Go: Michael Cross <https://github.com/xi2> |
|
* |
|
* This file has been put into the public domain. |
|
* You can do whatever you want with this file. |
|
*/ |
|
|
|
package xz |
|
|
|
/* from linux/include/linux/xz.h **************************************/ |
|
|
|
/** |
|
* xzRet - Return codes |
|
* @xzOK: Everything is OK so far. More input or more |
|
* output space is required to continue. |
|
* @xzStreamEnd: Operation finished successfully. |
|
* @xzUnSupportedCheck: Integrity check type is not supported. Decoding |
|
* is still possible by simply calling xzDecRun |
|
* again. |
|
* @xzMemlimitError: A bigger LZMA2 dictionary would be needed than |
|
* allowed by the dictMax argument given to |
|
* xzDecInit. |
|
* @xzFormatError: File format was not recognized (wrong magic |
|
* bytes). |
|
* @xzOptionsError: This implementation doesn't support the requested |
|
* compression options. In the decoder this means |
|
* that the header CRC32 matches, but the header |
|
* itself specifies something that we don't support. |
|
* @xzDataError: Compressed data is corrupt. |
|
* @xzBufError: Cannot make any progress. |
|
* |
|
* xzBufError is returned when two consecutive calls to XZ code cannot |
|
* consume any input and cannot produce any new output. This happens |
|
* when there is no new input available, or the output buffer is full |
|
* while at least one output byte is still pending. Assuming your code |
|
* is not buggy, you can get this error only when decoding a |
|
* compressed stream that is truncated or otherwise corrupt. |
|
*/ |
|
type xzRet int |
|
|
|
const ( |
|
xzOK xzRet = iota |
|
xzStreamEnd |
|
xzUnsupportedCheck |
|
xzMemlimitError |
|
xzFormatError |
|
xzOptionsError |
|
xzDataError |
|
xzBufError |
|
) |
|
|
|
/** |
|
* xzBuf - Passing input and output buffers to XZ code |
|
* @in: Input buffer. |
|
* @inPos: Current position in the input buffer. This must not exceed |
|
* input buffer size. |
|
* @out: Output buffer. |
|
* @outPos: Current position in the output buffer. This must not exceed |
|
* output buffer size. |
|
* |
|
* Only the contents of the output buffer from out[outPos] onward, and |
|
* the variables inPos and outPos are modified by the XZ code. |
|
*/ |
|
type xzBuf struct { |
|
in []byte |
|
inPos int |
|
out []byte |
|
outPos int |
|
} |
|
|
|
/* All XZ filter IDs */ |
|
type xzFilterID int64 |
|
|
|
const ( |
|
idDelta xzFilterID = 0x03 |
|
idBCJX86 xzFilterID = 0x04 |
|
idBCJPowerPC xzFilterID = 0x05 |
|
idBCJIA64 xzFilterID = 0x06 |
|
idBCJARM xzFilterID = 0x07 |
|
idBCJARMThumb xzFilterID = 0x08 |
|
idBCJSPARC xzFilterID = 0x09 |
|
idLZMA2 xzFilterID = 0x21 |
|
) |
|
|
|
// CheckID is the type of the data integrity check in an XZ stream |
|
// calculated from the uncompressed data. |
|
type CheckID int |
|
|
|
func (id CheckID) String() string { |
|
switch id { |
|
case CheckNone: |
|
return "None" |
|
case CheckCRC32: |
|
return "CRC32" |
|
case CheckCRC64: |
|
return "CRC64" |
|
case CheckSHA256: |
|
return "SHA256" |
|
default: |
|
return "Unknown" |
|
} |
|
} |
|
|
|
const ( |
|
CheckNone CheckID = 0x00 |
|
CheckCRC32 CheckID = 0x01 |
|
CheckCRC64 CheckID = 0x04 |
|
CheckSHA256 CheckID = 0x0A |
|
checkMax CheckID = 0x0F |
|
checkUnset CheckID = -1 |
|
) |
|
|
|
// An XZ stream contains a stream header which holds information about |
|
// the stream. That information is exposed as fields of the |
|
// Reader. Currently it contains only the stream's data integrity |
|
// check type. |
|
type Header struct { |
|
CheckType CheckID // type of the stream's data integrity check |
|
}
|
|
|