mirror of
https://github.com/SerenityOS/serenity
synced 2024-10-02 22:24:26 +00:00
AK+LibCompress: Break when seekback copying to a full CircularBuffer
Otherwise, we just end up infinitely looping while waiting for more space in the destination.
This commit is contained in:
parent
767fb01a8c
commit
b88c58b94c
|
@ -213,6 +213,9 @@ ErrorOr<size_t> CircularBuffer::copy_from_seekback(size_t distance, size_t lengt
|
|||
|
||||
auto remaining_length = length;
|
||||
while (remaining_length > 0) {
|
||||
if (empty_space() == 0)
|
||||
break;
|
||||
|
||||
auto next_span = next_read_span_with_seekback(distance);
|
||||
if (next_span.size() == 0)
|
||||
break;
|
||||
|
|
|
@ -208,7 +208,10 @@ ErrorOr<bool> DeflateDecompressor::CompressedBlock::try_read_more()
|
|||
m_decompressor.m_output_buffer.write({ &byte, sizeof(byte) });
|
||||
}
|
||||
} else {
|
||||
TRY(m_decompressor.m_output_buffer.copy_from_seekback(distance, length));
|
||||
auto copied_length = TRY(m_decompressor.m_output_buffer.copy_from_seekback(distance, length));
|
||||
|
||||
// TODO: What should we do if the output buffer is full?
|
||||
VERIFY(copied_length == length);
|
||||
}
|
||||
|
||||
return true;
|
||||
|
|
Loading…
Reference in a new issue