📄 sfx.asm
字号:
mov [si], cx ;
sub ax, cx ;
or ax, dx ;
mov cl, 4 ;
ror ax, cl ;
add 2[si], ax ;
ret ;
adjust endp ;
adjust1 endp ;
adjust0 endp ;
;
;-----------------------------------------------;
; 偦偺傑傑弌椡 ;
;-----------------------------------------------;
public copyall ;
copyall proc near ;
xor di, di ;
$_31:
mov bx, offset DGROUP:cpyhdr.OrgSiz
sub [bx], di ;
sbb word ptr 2[bx], 0 ;
mov cx, N ;
jNE $_34
mov ax, [bx] ;
or ax, ax ;
jz cpyend ;
cmp ax, cx
jAE $_34
mov cx, ax ;
$_34:
;
push cx ;
mov di, offset text_buf ;
lds si, dword ptr text_ptr ;
rep movsb ;
push es ;
pop ds ;
pop di ;
call putbuf ;
mov ax, di ;
call adjust1 ;
jmp $_31
$_33:
$_32:
cpyend: ;
ret ;
copyall endp ;
;
;-----------------------------------------------;
; 儊僢僙乕僕偺弌椡 ;
;-----------------------------------------------;
public mesout ;
mesout proc near ;
push ds ;
push ax ;
push dx ;
push cs ;
pop ds ;
mov dx, bx ;
mov ah, 09h ;
int 21h ;
pop dx ;
pop ax ;
pop ds ;
ret ;
mesout endp ;
;
;-----------------------------------------------;
; 栘峔憿偺嵞峔抸 ;
;-----------------------------------------------;
public reconst ;
reconst proc near ;
push si ;
;
xor si, si ;
mov di, si ;
$_35:
mov bx, son[si] ;
lodsw ; freq[si]
cmp bx, bp
jB $_37
inc ax ;
shr ax, 1 ;
mov son[di], bx ;
stosw ; mov freq[di], ax
; add di, 2
$_37:
cmp si, bp
jB $_35
$_36:
xor si, si ;
$_38:
push si ;
lodsw ; freq[si]
add ax, [si] ; freq[bx]
mov [di], ax ; freq[di], ax
;
mov bx, di ;
$_40:
dec bx ;
dec bx ;
cmp ax, [bx]
jB $_40
$_41:
inc bx ;
inc bx ;
;
push ax ;
push di ;
std ;
jmp short rc1 ;
$_42:
mov ax, [di - 2] ; freq[di - 2]
mov cx, son[di - 2] ;
mov son[di], cx ;
stosw ; freq[di], ax
rc1: ;
cmp di, bx
jA $_42
$_43:
cld ;
pop di ;
pop [bx] ; freq[bx]
pop son[bx] ;
;
lodsw ; add si, 2
scasw ; add di, 2
cmp di, bp
jB $_38
$_39:
xor si, si ;
$_44:
mov di, son[si] ;
mov prnt[di], si ;
cmp di, bp
jAE $_46
mov prnt[di + 2], si;
$_46:
lodsw ; add si, 2
cmp si, bp
jB $_44
$_45:
;
pop si ;
ret ;
reconst endp ;
;
;-----------------------------------------------;
; 栘峔憿偺峏怴 ;
;-----------------------------------------------;
; si : prnt[c + T] ;
;-----------------------------------------------;
public update ;
update proc near ;
or freq[R * 2], 0
jNS $_47
call near ptr reconst ;
$_47:
mov si, ds:prnt[si + bp] ;
$_48:
mov di, si ; lea di, freq[si]
mov ax, [di] ;
scasw ; inc di ;
; inc di ;
scasw
jNE $_50
mov cx, 0ffffh ; must large enough
repe scasw ;
sub di, 4 ; offset freq + 4
;
mov bx, son[si] ;
mov prnt[bx], di ;
cmp bx, bp
jAE $_51
mov prnt[bx + 2], di
$_51:
xchg bx, son[di] ;
mov prnt[bx], si ;
cmp bx, bp
jAE $_52
mov prnt[bx + 2], si
$_52:
mov son[si], bx ;
;
mov si, di ;
$_50:
inc word ptr [si] ; freq[si]
mov si, prnt[si] ;
or si, si
jNZ $_48
$_49:
ret ;
update endp ;
;
;-----------------------------------------------;
; 俫倀俥偺夝撉 ;
;-----------------------------------------------;
public DecodeChar ;
DecodeChar proc near ;
push bp ;
mov bp, T * 2 ;
mov si, son[R * 2] ;
mov dx, DGROUP:iobuf ;
mov cl, DGROUP:iolen ;
xor ch, ch ;
$_53:
jcxz GetBuf ;
dc2: ;
shr si, 1 ;
shl dx, 1 ;
adc si, 0 ;
shl si, 1 ;
mov si, son[si] ;
dec cx ;
cmp si, bp
jB $_53
$_54:
mov DGROUP:iobuf, dx ;
mov DGROUP:iolen, cl ;
sub si, bp ;
push si ;
call near ptr update ;
pop ax ;
shr ax, 1 ;
pop bp ;
ret ;
DecodeChar endp ;
;
public GetBuf ;
GetBuf: ;
call getc ;
mov dh, al ;
call getc ;
mov dl, al ;
mov cl, 16 ;
jmp short dc2 ;
;
;-----------------------------------------------;
; getc ;
; ax: 1 byte (return) ;
;-----------------------------------------------;
public getc ;
getc proc near ;
push es ;
les bx, dword ptr text_ptr ;
mov al, es:[bx] ;
inc text_ptr ;
xor ah, ah ;
pop es ;
ret ;
getc endp ;
;
;-----------------------------------------------;
; 擖椡偐傜値價僢僩傪摼傞 ;
;-----------------------------------------------;
; cl : n bits ;
;-----------------------------------------------;
public GetNBits ;
GetNBits proc near ;
push cx ;
mov dx, DGROUP:iobuf ;
cmp iolen, 8
jG $_55
call getc ;
mov cl, 8 ;
sub cl, DGROUP:iolen ;
shl ax, cl ;
or dx, ax ;
add DGROUP:iolen, 8 ;
$_55:
pop cx ;
mov ax, dx ;
shl dx, cl ;
mov DGROUP:iobuf, dx ;
sub DGROUP:iolen, cl ;
mov dx, -1 ;
shr dx, cl ;
not dx ;
and ax, dx ;
ret ;
GetNBits endp ;
;
;-----------------------------------------------;
; 埵抲忣曬偺夝撉 ;
;-----------------------------------------------;
public DecodePosition ;
DecodePosition proc near ;
mov cx, 8 ;
call near ptr GetNBits ;
xchg al, ah ;
mov si, ax ;
mov dl, d_code[si] ;
mov dh, 0 ;
mov cl, 6 ;
shl dx, cl ;
push dx ;
mov cl, d_len[si] ; ch == 0
call near ptr GetNBits ;
or ax, si ;
rol ax, cl ;
and ax, 003fh ;
pop dx ;
add ax, dx ;
ret ;
DecodePosition endp ;
;
;-----------------------------------------------;
; Decode ;
;-----------------------------------------------;
public Decode ;
Decode proc near ;
mov si, offset DGROUP:cpyhdr.OrgSiz ;
lodsw ;
or ax, [si] ;
jNZ $_56
jmp de9 ;
$_56:
;---------------------------- ;
; 俫倀俥梡偺栘峔憿偺弶婜壔 ;
;---------------------------- ;
public StartHuff ;
StartHuff: ;
mov ax, 1 ;
mov cx, N_CHAR ;
push cx ;
xor di, di ; mov di, offset DGROUP:freq
rep stosw ;
mov ax, T * 2 ;
xor dx, dx ;
pop cx ;
mov di, offset DGROUP:son ;
mov bx, offset DGROUP:prnt[T * 2] ;
$_57:
stosw ;
inc ax ; add ax, 2
inc ax ;
mov [bx], dx ;
inc bx ; add bx, 2
inc bx ;
inc dx ; add dx, 2
inc dx ;
LOOP $_57
$_58:
;
xor si, si ;
mov di, N_CHAR * 2 ;
mov cx, N_CHAR - 1 ;
$_59:
mov son[di], si ;
mov prnt[si], di ;
lodsw ; mov ax, freq[si]
add ax, [si] ; add ax, freq[si + 2]
mov prnt[si], di ;
stosw ; mov freq[di], ax
lodsw ;
LOOP $_59
$_60:
xor ax, ax ;
mov iobuf, ax ;
; mov iolen, al ;
mov DGROUP:prnt[R * 2], ax ; prnt[R * 2], 0
dec ax ;
mov [di], ax ; freq[T * 2], -1
;---------------------------- ;
;
mov al, 20h ;
mov cx, F ;
mov di, offset DGROUP:text_buf + N - F
rep stosb ;
;
xor di, di ;
mov bp, N - 1 ;
$_61:
push di ;
call near ptr DecodeChar ;
; $_if ;
or ah, ah ;
jnz de1 ;
pop di ;
mov cx, 1 ;
push cx ;
jmp short de2 ;
; $_else ;
de1: ;
push ax ;
call near ptr DecodePosition
pop cx ;
pop di ;
mov si, di ;
sub si, ax ;
dec si ;
and si, bp ;
sub cx, 255 - THRESHOLD
push cx ;
$_63:
mov al, DGROUP:text_buf[si]
inc si ;
and si, bp ;
de2: ;
mov DGROUP:text_buf[di], al
inc di ;
cmp di, bp
jBE $_65
push cx
call putbuf
pop cx
$_65:
and di, bp ;
LOOP $_63
$_64:
pop cx ;
; $_elseif ;
mov bx, offset DGROUP:cpyhdr.OrgSiz
sub [bx], cx ;
pushf ;
sbb word ptr 2[bx], 0 ;
pop ax ;
lahf ;
and ah, al ;
sahf ;
jG $_61
$_62:
call putbuf ;
de9: ;
ret ;
Decode endp ;
;
public endofcode ;
endofcode: ;
_TEXT ends ;
end start ;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -