summaryrefslogtreecommitdiffstats
path: root/decoder.h
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-01-23 05:35:03 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-01-23 05:35:03 +0000
commit3ac1eed6033500851faea31f0e07945491685d56 (patch)
tree28b1c8d5af47dd63f3ca1318081ce56cba92c3bc /decoder.h
parentAdding upstream version 1.13. (diff)
downloadlunzip-13c50a83f8993af54e78d92dddb3a5812dfad010.tar.xz
lunzip-13c50a83f8993af54e78d92dddb3a5812dfad010.zip
Adding upstream version 1.14~rc1.upstream/1.14_rc1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'decoder.h')
-rw-r--r--decoder.h12
1 files changed, 8 insertions, 4 deletions
diff --git a/decoder.h b/decoder.h
index 0afdd83..0651cc2 100644
--- a/decoder.h
+++ b/decoder.h
@@ -1,5 +1,5 @@
/* Lunzip - Decompressor for the lzip format
- Copyright (C) 2010-2022 Antonio Diaz Diaz.
+ Copyright (C) 2010-2023 Antonio Diaz Diaz.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -79,13 +79,16 @@ static inline int Rd_read_data( struct Range_decoder * const rdec,
return sz;
}
-static inline void Rd_load( struct Range_decoder * const rdec )
+static inline bool Rd_load( struct Range_decoder * const rdec,
+ const bool ignore_marking )
{
int i;
rdec->code = 0;
- for( i = 0; i < 5; ++i ) rdec->code = (rdec->code << 8) | Rd_get_byte( rdec );
rdec->range = 0xFFFFFFFFU;
- rdec->code &= rdec->range; /* make sure that first byte is discarded */
+ /* check and discard first byte of the LZMA stream */
+ if( Rd_get_byte( rdec ) != 0 && !ignore_marking ) return false;
+ for( i = 0; i < 4; ++i ) rdec->code = (rdec->code << 8) | Rd_get_byte( rdec );
+ return true;
}
static inline void Rd_normalize( struct Range_decoder * const rdec )
@@ -390,4 +393,5 @@ LZd_data_position( const struct LZ_decoder * const d )
{ return d->partial_data_pos + d->pos; }
int LZd_decode_member( struct LZ_decoder * const d,
+ const struct Cl_options * const cl_opts,
struct Pretty_print * const pp );