Merge pull request #8870 from s-hadinger/unishox_python_fix

Unishox fix bug in python uncompress
This commit is contained in:
Theo Arends 2020-07-08 20:17:16 +02:00 committed by GitHub
commit e4d04e5587
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 9 additions and 8 deletions

View File

@ -344,15 +344,16 @@ class Unishox:
#print("getCodeIdx not found = {r}".format(r=1)) #print("getCodeIdx not found = {r}".format(r=1))
return 1, bit_no_p return 1, bit_no_p
def getNumFromBits(self, inn, bit_no, count): def getNumFromBits(self, inn, bit_no_p, count):
ret = 0 ret = 0
while count: while count:
count -= 1 count -= 1
if self.ESCAPE_MARKER == inn[bit_no >> 3]: if self.ESCAPE_MARKER == inn[bit_no_p >> 3]:
bit_no += 8 # skip marker bit_no_p += 8 # skip marker
ret += self.getBitVal(inn, bit_no, count) ret += self.getBitVal(inn, bit_no_p, count)
bit_no += 1 bit_no_p += 1
return ret # print("getNumFromBits = {r}".format(r=ret))
return ret, bit_no_p
def readCount(self, inn, bit_no_p, len_): def readCount(self, inn, bit_no_p, len_):
(idx, bit_no_p) = self.getCodeIdx(self.us_hcode, inn, len_, bit_no_p) (idx, bit_no_p) = self.getCodeIdx(self.us_hcode, inn, len_, bit_no_p)
@ -372,10 +373,10 @@ class Unishox:
till += (1 << bit_len_idx) till += (1 << bit_len_idx)
i += 1 i += 1
count = self.getNumFromBits(inn, bit_no_p, bit_len_idx) + base (count, bit_no_p) = self.getNumFromBits(inn, bit_no_p, bit_len_idx)
count = count + base
#print("readCount getNumFromBits = {count} ({bl})".format(count=count,bl=bit_len_idx)) #print("readCount getNumFromBits = {count} ({bl})".format(count=count,bl=bit_len_idx))
bit_no_p += bit_len_idx
return count, bit_no_p return count, bit_no_p
def decodeRepeat(self, inn, len_, out, ol, bit_no): def decodeRepeat(self, inn, len_, out, ol, bit_no):