mirror of
https://github.com/fergalmoran/ladybird.git
synced 2025-12-29 12:49:08 +00:00
LibCompress: Move CanonicalCode out of DeflateDecompressor.
This commit is contained in:
@@ -34,7 +34,7 @@
|
|||||||
|
|
||||||
namespace Compress {
|
namespace Compress {
|
||||||
|
|
||||||
const DeflateDecompressor::CanonicalCode& DeflateDecompressor::CanonicalCode::fixed_literal_codes()
|
const CanonicalCode& CanonicalCode::fixed_literal_codes()
|
||||||
{
|
{
|
||||||
static CanonicalCode code;
|
static CanonicalCode code;
|
||||||
static bool initialized = false;
|
static bool initialized = false;
|
||||||
@@ -54,7 +54,7 @@ const DeflateDecompressor::CanonicalCode& DeflateDecompressor::CanonicalCode::fi
|
|||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
const DeflateDecompressor::CanonicalCode& DeflateDecompressor::CanonicalCode::fixed_distance_codes()
|
const CanonicalCode& CanonicalCode::fixed_distance_codes()
|
||||||
{
|
{
|
||||||
static CanonicalCode code;
|
static CanonicalCode code;
|
||||||
static bool initialized = false;
|
static bool initialized = false;
|
||||||
@@ -71,7 +71,7 @@ const DeflateDecompressor::CanonicalCode& DeflateDecompressor::CanonicalCode::fi
|
|||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
Optional<DeflateDecompressor::CanonicalCode> DeflateDecompressor::CanonicalCode::from_bytes(ReadonlyBytes bytes)
|
Optional<CanonicalCode> CanonicalCode::from_bytes(ReadonlyBytes bytes)
|
||||||
{
|
{
|
||||||
// FIXME: I can't quite follow the algorithm here, but it seems to work.
|
// FIXME: I can't quite follow the algorithm here, but it seems to work.
|
||||||
|
|
||||||
@@ -103,7 +103,7 @@ Optional<DeflateDecompressor::CanonicalCode> DeflateDecompressor::CanonicalCode:
|
|||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 DeflateDecompressor::CanonicalCode::read_symbol(InputBitStream& stream) const
|
u32 CanonicalCode::read_symbol(InputBitStream& stream) const
|
||||||
{
|
{
|
||||||
u32 code_bits = 1;
|
u32 code_bits = 1;
|
||||||
|
|
||||||
|
|||||||
@@ -34,10 +34,8 @@
|
|||||||
|
|
||||||
namespace Compress {
|
namespace Compress {
|
||||||
|
|
||||||
class DeflateDecompressor final : public InputStream {
|
class CanonicalCode {
|
||||||
private:
|
public:
|
||||||
class CanonicalCode {
|
|
||||||
public:
|
|
||||||
CanonicalCode() = default;
|
CanonicalCode() = default;
|
||||||
u32 read_symbol(InputBitStream&) const;
|
u32 read_symbol(InputBitStream&) const;
|
||||||
|
|
||||||
@@ -46,11 +44,13 @@ private:
|
|||||||
|
|
||||||
static Optional<CanonicalCode> from_bytes(ReadonlyBytes);
|
static Optional<CanonicalCode> from_bytes(ReadonlyBytes);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Vector<u32> m_symbol_codes;
|
Vector<u32> m_symbol_codes;
|
||||||
Vector<u32> m_symbol_values;
|
Vector<u32> m_symbol_values;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class DeflateDecompressor final : public InputStream {
|
||||||
|
private:
|
||||||
class CompressedBlock {
|
class CompressedBlock {
|
||||||
public:
|
public:
|
||||||
CompressedBlock(DeflateDecompressor&, CanonicalCode literal_codes, Optional<CanonicalCode> distance_codes);
|
CompressedBlock(DeflateDecompressor&, CanonicalCode literal_codes, Optional<CanonicalCode> distance_codes);
|
||||||
|
|||||||
Reference in New Issue
Block a user