aboutsummaryrefslogtreecommitdiff
path: root/src/liblzma
diff options
context:
space:
mode:
authorLasse Collin <lasse.collin@tukaani.org>2008-01-08 22:58:42 +0200
committerLasse Collin <lasse.collin@tukaani.org>2008-01-08 22:58:42 +0200
commit7054c5f5888ac6a7178cd43dc9583ce6c7e78c9f (patch)
tree3e5c08c79d3549f24b84163a0be2359661f2ed29 /src/liblzma
parentAdded good-single-subblock_implicit.lzma. (diff)
downloadxz-7054c5f5888ac6a7178cd43dc9583ce6c7e78c9f.tar.xz
Fix decoding of Blocks that have only Block Header.
Diffstat (limited to 'src/liblzma')
-rw-r--r--src/liblzma/common/block_decoder.c37
1 files changed, 14 insertions, 23 deletions
diff --git a/src/liblzma/common/block_decoder.c b/src/liblzma/common/block_decoder.c
index af2b0203..820fee05 100644
--- a/src/liblzma/common/block_decoder.c
+++ b/src/liblzma/common/block_decoder.c
@@ -345,28 +345,7 @@ lzma_block_decoder_init(lzma_next_coder *next, lzma_allocator *allocator,
return_if_error(lzma_check_init(&next->coder->check, options->check));
- if (!options->has_eopm && options->uncompressed_size == 0) {
- if (!is_size_valid(0, options->compressed_size))
- return LZMA_PROG_ERROR;
-
- if (options->check != LZMA_CHECK_NONE) {
- lzma_check_finish(&next->coder->check, options->check);
- next->coder->sequence = SEQ_CHECK;
- } else if (options->handle_padding) {
- next->coder->sequence = SEQ_PADDING;
- } else {
- next->coder->sequence = SEQ_END;
- }
- } else {
- next->coder->sequence = SEQ_CODE;
- }
-
- return_if_error(lzma_raw_decoder_init(&next->coder->next, allocator,
- options->filters, options->has_eopm
- ? LZMA_VLI_VALUE_UNKNOWN
- : options->uncompressed_size,
- true));
-
+ next->coder->sequence = SEQ_CODE;
next->coder->options = options;
next->coder->pos = 0;
next->coder->total_size = options->header_size;
@@ -379,7 +358,19 @@ lzma_block_decoder_init(lzma_next_coder *next, lzma_allocator *allocator,
next->coder->tmp = 0;
next->coder->size_of_backward_size = 0;
- return LZMA_OK;
+ if (!options->has_eopm && options->uncompressed_size == 0) {
+ // The Compressed Data field is empty, thus we skip SEQ_CODE
+ // phase completely.
+ const lzma_ret ret = update_sequence(next->coder);
+ if (ret != LZMA_OK && ret != LZMA_STREAM_END)
+ return LZMA_PROG_ERROR;
+ }
+
+ return lzma_raw_decoder_init(&next->coder->next, allocator,
+ options->filters, options->has_eopm
+ ? LZMA_VLI_VALUE_UNKNOWN
+ : options->uncompressed_size,
+ true);
}