mirror of
https://github.com/cc65/cc65.git
synced 2025-01-10 19:29:45 +00:00
Fix more than 256 codes of same length.
Fix all 256 literal codes of same length.
This commit is contained in:
parent
afcfba9355
commit
84edf4cbfd
@ -1,5 +1,5 @@
|
|||||||
;
|
;
|
||||||
; 2017-11-06, Piotr Fusik
|
; 2017-11-07, Piotr Fusik
|
||||||
;
|
;
|
||||||
; unsigned __fastcall__ inflatemem (char* dest, const char* source);
|
; unsigned __fastcall__ inflatemem (char* dest, const char* source);
|
||||||
;
|
;
|
||||||
@ -344,6 +344,9 @@ buildHuffmanTree_clear:
|
|||||||
buildHuffmanTree_countCodeLengths:
|
buildHuffmanTree_countCodeLengths:
|
||||||
ldx literalSymbolCodeLength,y
|
ldx literalSymbolCodeLength,y
|
||||||
inc nBitCode_literalCount,x
|
inc nBitCode_literalCount,x
|
||||||
|
bne buildHuffmanTree_notAllLiterals
|
||||||
|
stx allLiteralsCodeLength
|
||||||
|
buildHuffmanTree_notAllLiterals:
|
||||||
cpy #CONTROL_SYMBOLS
|
cpy #CONTROL_SYMBOLS
|
||||||
bcs buildHuffmanTree_noControlSymbol
|
bcs buildHuffmanTree_noControlSymbol
|
||||||
ldx controlSymbolCodeLength,y
|
ldx controlSymbolCodeLength,y
|
||||||
@ -394,12 +397,33 @@ fetchCode_nextBit:
|
|||||||
jsr getBit
|
jsr getBit
|
||||||
rol a
|
rol a
|
||||||
inx
|
inx
|
||||||
|
bcs fetchCode_ge256
|
||||||
|
; are all 256 literal codes of this length?
|
||||||
|
cpx allLiteralsCodeLength
|
||||||
|
beq fetchCode_allLiterals
|
||||||
|
; is it literal code of length X?
|
||||||
sec
|
sec
|
||||||
sbc nBitCode_literalCount,x
|
sbc nBitCode_literalCount,x
|
||||||
bcc fetchCode_literal
|
bcs fetchCode_notLiteral
|
||||||
|
; literal code
|
||||||
|
; clc
|
||||||
|
adc nBitCode_literalOffset,x
|
||||||
|
tax
|
||||||
|
lda codeToLiteralSymbol,x
|
||||||
|
fetchCode_allLiterals:
|
||||||
|
clc
|
||||||
|
rts
|
||||||
|
; code >= 256, must be control
|
||||||
|
fetchCode_ge256:
|
||||||
|
; sec
|
||||||
|
sbc nBitCode_literalCount,x
|
||||||
|
sec
|
||||||
|
; is it control code of length X?
|
||||||
|
fetchCode_notLiteral:
|
||||||
; sec
|
; sec
|
||||||
sbc nBitCode_controlCount,x
|
sbc nBitCode_controlCount,x
|
||||||
bcs fetchCode_nextBit
|
bcs fetchCode_nextBit
|
||||||
|
; control code
|
||||||
; clc
|
; clc
|
||||||
adc nBitCode_controlOffset,x
|
adc nBitCode_controlOffset,x
|
||||||
tax
|
tax
|
||||||
@ -408,13 +432,6 @@ fetchCode_nextBit:
|
|||||||
tax
|
tax
|
||||||
; sec
|
; sec
|
||||||
rts
|
rts
|
||||||
fetchCode_literal:
|
|
||||||
; clc
|
|
||||||
adc nBitCode_literalOffset,x
|
|
||||||
tax
|
|
||||||
lda codeToLiteralSymbol,x
|
|
||||||
clc
|
|
||||||
rts
|
|
||||||
|
|
||||||
; Read A minus 1 bits, but no more than 8
|
; Read A minus 1 bits, but no more than 8
|
||||||
getAMinus1BitsMax8:
|
getAMinus1BitsMax8:
|
||||||
@ -523,6 +540,8 @@ nBitCode_literalOffset:
|
|||||||
.res 2*TREE_SIZE
|
.res 2*TREE_SIZE
|
||||||
nBitCode_controlOffset:
|
nBitCode_controlOffset:
|
||||||
.res 2*TREE_SIZE
|
.res 2*TREE_SIZE
|
||||||
|
allLiteralsCodeLength:
|
||||||
|
.res 1
|
||||||
|
|
||||||
codeToLiteralSymbol:
|
codeToLiteralSymbol:
|
||||||
.res 256
|
.res 256
|
||||||
|
Loading…
x
Reference in New Issue
Block a user