亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sfx2.asm

?? 這是我碩士論文時的研究的一種高效的壓縮算法,有興趣的同行可以切磋一下
?? ASM
?? 第 1 頁 / 共 2 頁
字號:
page	66, 120					;
;$_init						;
;***********************************************;
;       LHarc version 1.13 (c) Yoshi 1988-89.	;
;       self-extract module : 1989/ 5/ 4	;
;						;
; HTAB = 8					;
;***********************************************;
						;
_TEXT	segment	byte public 'CODE'		;
_TEXT	ends					;
						;
DGROUP	group	_BSS				;
	assume	cs:_TEXT, ds:DGROUP		;
						;
		public	THRESHOLD, F, N_CHAR, T	;
THRESHOLD	equ	2			;
F		equ	60			;
N_CHAR		equ	(256 - THRESHOLD + F)	;
T		equ	(N_CHAR * 2 - 1)	;
R		equ	(T - 1)			;
N		equ	1000h			;
MAX_FREQ	equ	8000h			;
CRC16		equ	0a001h			;
BufSiz		equ	04000h			;
						;
LzHead	struc					;
	HeadSiz	db	?			;
	HeadChk	db	?			;
	HeadID	db	3 dup (?)		;
	Method	db	?			;
		db	?			;
	PacSiz	dw	2 dup (?)		;
	OrgSiz	dw	2 dup (?)		;
	FTime	dw	?			;
	FDate	dw	?			;
	FAttr	dw	?			;
	FnLen	db	?			;
	Fname	db	80h dup (?)		;
LzHead	ends					;
						;
_BSS	segment	para public 'BSS'		;
	public	freq, prnt, son			;
	public	d_len, d_code			;
	public	crctbl				;
	public	cpyhdr, infile, outfile		;
	public	inpptr				;
	public	curcrc, iobuf, iolen, crcflg, orgcrc
	public	myname, keyword, keyword2, keycnt
	public	param, pathname, fnnext, swchar	;
						;
freq		dw	(T + 1) dup (?)		;
prnt		dw	(T + N_CHAR) dup (?)	;
son		dw	T dup (?)		;
d_len		db	100h dup (?)		;
d_code		db	100h dup (?)		;
crctbl		dw	100h dup (?)		;
text_buf	db	N dup (?)		;
inpbuf		db	BufSiz dup (?)		;
inpptr		dw	1 dup (?)		;
cpyhdr		LzHead	1 dup (<?>)		;
infile		dw	1 dup (?)		;
outfile		dw	1 dup (?)		;
orgcrc		dw	1 dup (?)		;
curcrc		dw	1 dup (?)		;
iobuf		dw	1 dup (?)		;
crcflg		db	1 dup (?)		;
iolen		db	1 dup (?)		;
myname		db	80h dup (?)		;
keyword		db	80h dup (?)		;
keyword2	db	80h dup (?)		;
param		dw	20 dup (?)		;
pathname	db	80h dup (?)		;
fnnext		dw	1 dup (?)		;
fnptr		dw	1 dup (?)		;
swchar		db	1 dup (?)		;
endBBS		label	byte			;
_BSS		ends				;
						;
_TEXT	segment	byte public 'CODE'		;
	assume	cs:_TEXT			;
						;
	org	0100h				;
						;
	public	start, main			;
	public	BSSseg				;
	public	cright, chglen, crlf, space	;
	public	absent, myself, broken, extend	;
start:						;
	jmp	main				;
						;
BSSseg	=	(endofcode - start + 10fh) / 10h;
mes_yn	equ	space - 1			;
space	db	' ', 0				;
cright	db	"LHarc's SFX 1.13L (c)Yoshi, 1989."
	db	13, 10, 10, 0			;
absent	db	'Rename to '			;
myself	db	'            ', 0		;
chglen	db	01h, 04h, 0ch, 18h, 30h		; next byte must not be 3?h
overwt	db	'Overwrite ', 0			;
yesno	db	'[Y/N] ', 0			;
broken	db	'Broken file ', 0		;
write	db	'Write', 0			;
header	db	'Header', 0			;
crcmes	db	'CRC'				;
error	db	' Error'			;
crlf	db	13, 10, 0			;
auto	db	8, 'AUTOLARC'			;
autoflg	db	'.'				;
	db	'BAT'				;
extend	db	0				;
attrib	db	0				;
keycnt	dw	0				;
						;
envseg	=	002ch				;
cmdcnt	=	0080h				;
cmdline	=	0081h				;
						;
;-----------------------------------------------;
;	儊僀儞儖乕僠儞				;
;-----------------------------------------------;
main:						;
	cld					;
	mov	sp, offset start		;
	mov	bx, offset cright		;
	call	mesout				;
	mov	ax, cs				;
	add	ax, BSSseg			;
	mov	es, ax				;
						;
	assume	es:DGROUP			;
;-----------------------------------------------;
;	Get options				;
;-----------------------------------------------;
	public	getopt				;
getopt:						;
	mov	ax, 3700h			;
	int	21h				; get switch char
	mov	si, cmdline			;
	mov	es:swchar, dl			;
						;
	mov	es:fnnext, offset DGROUP:pathname
$_1:
	    lodsb				;
	    call isspace
	    jE $_3
		cmp al, es:swchar
		jE $_4
		cmp al, '-'
		jNE $_5
$_4:
lp0:						;
		    lodsb			;
		    call isspace
		    jE $_6
			cmp al, 'e'
			jNE $_8
			    lodsb		;
			    mov	    di, offset DGROUP:pathname
			    mov	    ah, '\'	;
			    call    trans_t	;
			    mov	    al, ah	;
			    call isdelim2
			    jE $_9
				mov	al, '\'	;
				stosb		;
$_9:
			    mov	    es:fnnext, di
			    dec	    si		;
			    jmp short $_7
$_8:
			cmp al, 'x'
			jNE $_10
			    inc	    cs:extend	;
			    jmp short $_7
$_10:
			cmp al, 'a'
			jNE $_11
			    inc	    cs:attrib	;
$_11:
$_7:
			jmp	lp0		;
$_6:
		jmp short $_12
$_5:
		    mov	    di, offset DGROUP:keyword
		    mov	    dx, di		;
		    call    trans		;
		    sub	    di, dx		;
		    mov	    cs:keycnt, di	;
$_12:
lp1:						;
$_3:
	cmp al, 0dh
	jNE $_1
$_2:
						;
public	mnlp1					;
mnlp1:						;
	push	es				;
	pop	ds				;
						;
	assume	ds:DGROUP			;
;-----------------------------------------------;
;	Get my name				;
;-----------------------------------------------;
	mov	ah, 30h				;
	int	21h				; get DOS ver.
	push	ds				;
	cmp al, 3
	jB $_13
		mov	ax, cs:[envseg]		;
		mov	es, ax			;
		xor	ax, ax			;
		mov	di, ax			;
		mov	cx, -1			;
$_14:
			repne	scasb		;
			scasb			;
		jNE $_14
$_15:
		inc	ax			;
		scasw				;
		push	es			;
		pop	ds			;
		mov	dx, di			;
		je	openme			;
	jmp short $_16
$_13:
		mov	ax, cs:[0002h]		;
		sub	ax, 38h			;
		mov	ds, ax			;
		mov	dx, 0009h		;
		jmp	short openme		;
$_16:
brknenv:					;
	push	cs				;
	pop	ds				;
	mov	dx, offset myself		;
openme:						;
	mov	ax, 3d00h			;
	int	21h				; Open Myself
	jNC $_17
		cmp	dx, offset myself	;
		jne	brknenv			;
		mov	bx, offset absent	;
		call	mesout			;
		mov	bx, offset crlf		;
		jmp	errout1			;
$_17:
	pop	ds				;
	mov	infile, ax			;
						;
	mov	bx, ax				;
	xor	cx, cx				;
exehdr	=	20h				;
	mov	dx, (endofcode - start) + exehdr;
	mov	ax, 4200h			;
	int	21h				; Move a File Pointer
	jNC $_18
		mov	bx, offset broken	; Broken file
		jmp	errout			;
$_18:
	push	ds				;
	pop	es				;
;-----------------------------------------------;
;	Get Key-word from SFX-file		;
;-----------------------------------------------;
	mov	di, offset DGROUP:keyword2	;
	lea	dx, [di + 79]			;
	mov	si, dx				;
	mov	cx, 1				;
	mov	bx, infile			;
$_19:
		mov	[si], ch		; for error detect (ch = 0)
		mov	ah, 3fh			;
		int	21h			; Read 1 char
		mov	al, [si]		;
		stosb				;
	or al,al
	jNZ $_19
$_20:
;---------------------------------------	;
;	make CRC table				;
;---------------------------------------	;
	mov	di, offset crctbl		;
	xor	dx, dx				;
$_21:
		mov	ax, dx			;
		mov	cx, 8			;
$_23:
			shr ax, 1
			jNC $_25
				xor	ax, CRC16
$_25:
		LOOP $_23
$_24:
		stosw				;
	inc dl
	jNZ $_21
$_22:
;---------------------------------------	;
; make table for position			;
;---------------------------------------	;
	mov	si, offset _TEXT:chglen		;
	mov	di, offset DGROUP:d_len		;
	mov	ax, 1				; d_len = real length - 2
	mov	dx, 0020h			;
$_26:
		cmp ah, cs:[si]
		jNE $_28
			inc	al		;
			inc	si		;
			shr	dx, 1		;
$_28:
		mov	cx, dx			;
$_29:
			mov	[di + d_code - d_len], ah
			stosb			;
		LOOP $_29
$_30:
		inc	ah			;
	cmp ah, 040h
	jL $_26
$_27:
;---------------------------------------	;
						;
	public mainloop				;
mainloop:					;
$_31:
						;
; Get Header ---------------------------	;
		mov	DGROUP:cpyhdr.HeadSiz, 0;
		mov	bx, infile		;
		mov	cx, 1			;
		mov	dx, offset DGROUP:cpyhdr.HeadSiz
		mov	ah, 3fh			;
		int	21h			; Read header size
		dec	cx			; cx = 0
		add	cl, DGROUP:cpyhdr.HeadSiz
		jNZ $_34
			jmp	exit		;
$_34:
		inc	dx			;
		mov	si, dx			;
						;
		inc	cx			;
		mov	ah, 3fh			;
		int	21h			; Read header
						;
; Test Header Sum ----------------------	;
		lodsb				;
		mov	di, si			; cpyhdr.HeadID
		dec	cx			;
$_35:
			sub	al, [si]	;
			inc	si		;
		LOOP $_35
$_36:
		or	al, al			;
		jne	errhdr			;
		xchg	di, si			; di = end of cpyhdr
						;
; Test Header ID -----------------------	;
		lodsw				;
		cmp	ax, 'l-'		;
		jne	errhdr			;
		lodsw				;
		xchg	al, ah			;
		sub	ax, 'h0'		;
		mov	bp, ax			; bp = method
		cmp	ax, 0001h		;
		ja	errhdr			;
		lodsb				;
		cmp	al, '-'			;
		jE $_37
errhdr:						;
			mov	bx, offset header
			jmp	errout		;
$_37:
						;
; Get original CRC ---------------------	;
		mov	bx, offset DGROUP:cpyhdr.Fname
		mov	dx, bx			;
		mov	cl, [bx - 1]		; ch = 0
		add	bx, cx			;
						;
		mov	ax, [bx]		; may be CRC
		mov	orgcrc, ax		;
						;
		sub	di, bx			; bx  = end of Fname
		mov	word ptr crcflg, di	; if 2, crc supported.
						; iolen = 0 also.
						;
; Test Special File ? ------------------	;
		mov	ax, 1			;
		mov	fnptr, dx		;
		cmp	word ptr DGROUP:cpyhdr.FnLen, 2101h ; 01h, '!'
		jNE $_38
			jmp	mn7		;
$_38:
						;
		mov	si, dx			;
		mov	di, offset auto + 1	; AUTOLARC.BAT ?
		mov	cl, 12			; ch may be 0
		push	es			;
		push	cs			;
		pop	es			;
		rep	cmpsb			;
		pop	es			;
		je	mn2			;
						;
; -x switch ----------------------------	;
		mov	si, dx			;
		cmp cs:extend, 0
		jNE $_39
$_40:
				lodsb		;
				call isdelim2
				jNE $_43
					mov	dx, si
					jmp short $_42
$_43:
				call iskanji
				jNE $_44
					inc	si
$_44:
$_42:
			cmp si, bx
			jB $_40
$_41:
			mov	si, dx		;
$_39:
						;
; -eDIRECTORY --------------------------	;
		mov	al, [si]		;
		call isdelim2
		jE $_45
			mov	cx, bx		;
			sub	cx, dx		;
			mov	dx, offset DGROUP:pathname
			mov	di, fnnext	;
			rep	movsb		;
			mov	bx, di		;
		jmp short $_46
$_45:
			mov	ax, word ptr DGROUP:pathname
			cmp ah, ':'
			jNE $_47
				dec	dx	;
				dec	dx	;
				mov	di, dx	;
				mov	[di], ax; brakes FnLen and
$_47:
$_46:
		mov	fnptr, dx		;
		mov	cx, 1			;
						;
; Display File name --------------------	;
mn2:						;
		mov	word ptr [bx], 0 * 256 + ' '
		mov	bx, dx			;
		push	dx			;
		call	dispent			; output file name
		pop	dx			;
		mov	byte ptr [bx - 1], 0	;
						;
		jcxz	mn9			; AUTOLARC.BAT ?
						;
; Check Existence of File --------------	;
		mov	ax, 4300h		; get file attr
		int	21h			;   (for MS-DOS 3.3)
		jc	mn5			;
						;
		mov	bx, offset overwt	; prompt
		call	mesout			;
		call	getyn			;
		je	mn1			;
						;
; Skip to next File --------------------	;
		mov	dx, DGROUP:cpyhdr.PacSiz	; skip file
		mov	cx, DGROUP:cpyhdr.PacSiz + 2
						;
		mov	bx, infile		;
		mov	ax, 4201h		;
		int	21h			; Move a File Pointer
		jmp	mn6			;
mn9:						;
		mov	cs:autoflg, 0dh		;
						;
; Make Directories ---------------------	;
mn5:						;
		mov	si, dx			;
		lodsb				;
		jmp	short mn0		;
$_48:
			lodsb			;
			call isdelim2
			jNE $_50
				mov	byte ptr [si - 1], 0
				mov	ah, 39h	; make dir
				int	21h	;
				mov	byte ptr [si - 1], '\'
$_50:
mn0:						;
			call iskanji
			jNE $_51
				inc	si	;
$_51:
		cmp al, 0
		jNE $_48
$_49:
						;
; Create a New File --------------------	;
mn1:						;
		mov	cl, 20h			; ch may be 0
		mov	ah, 3ch			;
		int	21h			; Create a File
		jNC $_52
			jmp	errwrite	;
$_52:
						;
; Decode -------------------------------	;
mn7:						;
		mov	outfile, ax		;
						;
		mov	curcrc, 0		;
;		mov	iolen, 0		; already iolen = 0
		mov	inpptr, -1		;
						;
		push	dx			;
		or bp, bp
		jZ $_53
			call	Decode		;
		jmp short $_54
$_53:
			call	copyall		;
$_54:
		pop	si			;
						;
; Set Time-Stamp -----------------------	;
		mov	bx, outfile		;
		cmp	bx, 1			; file '!' ?
		je	mn8			;
						;
		mov	dx, DGROUP:cpyhdr.FDate	;
		mov	cx, DGROUP:cpyhdr.FTime	;
		mov	ax, 5701h		; set date
		int	21h			;
		mov	bx, outfile		;
		call	close			;
						;
; Check CRC ----------------------------	;
		mov	dx, si			;
		cmp crcflg, 2
		jNE $_55
			mov	ax, curcrc	;
			cmp	ax, orgcrc	;
			jne	errcrc		;
$_55:
						;
; Set File Attributes ------------------	;
		cmp attrib, 0
		jE $_56
			mov	cl, byte ptr DGROUP:cpyhdr.FAttr
			mov	ch, 0		;
			mov	ax, 4301h	;
			int	21h		; Set File Attributes
$_56:
		jmp	mn6			;
mn8:						;
		call	getyn			;
		jne	exit1			;
mn6:						;
		mov	bx, offset crlf		;
		call	mesout			;
	jmp $_31
$_33:
$_32:
	public	exit				;
exit:						;
	push	ds				;
	pop	es				;
	cmp cs:autoflg, 0dh
	jNE $_57
		mov	cx, keycnt		;
		jcxz	exit1			;
		inc	cx			;
		mov	si, offset DGROUP:keyword
		mov	di, offset DGROUP:keyword2
	repe cmpsb
	jNE $_57
		push	cs			;
		pop	es			;
		mov	bx, (offset resident - start + 100h + 15) / 16
		mov	ah, 4ah			;
		int	21h			;
		push	cs			;
		pop	ds			;
		mov	si, offset auto		;
		int	2eh			; execute
$_57:
exit1:						;
	mov	ax, 4c00h			;
	int	21h				;
resident:					;
						;
;-----------------------------------------------;
;	僄儔乕張棟				;
;-----------------------------------------------;
	public	errhdr, errwrite, errout	;
errcrc:						;
	call	unlink				;
	mov	bx, offset crcmes		;
	jmp	short errout1			;
						;
errwrite:					;
	mov	bx, outfile			;
	call	close				;
	call	unlink				;
	mov	bx, offset write		;
						;
errout:						;
	call	mesout				;
	mov	bx, offset error		;
errout1:					;
	call	mesout				;
	mov	bx, infile			;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
视频一区欧美精品| 欧美一级高清片在线观看| 69堂成人精品免费视频| 日本一区二区三区国色天香| 夜夜亚洲天天久久| 国产精品99久久不卡二区| 欧美性猛交xxxx黑人交| 国产精品第四页| 久久精品国产一区二区| 欧美亚男人的天堂| 亚洲欧美一区二区视频| 国产成人综合自拍| 久久这里只有精品6| 美女视频免费一区| 91精品视频网| 手机精品视频在线观看| 欧美自拍丝袜亚洲| 日韩久久一区二区| 99国产精品久久久久久久久久 | 国产精品成人一区二区艾草 | 国产亚洲自拍一区| 蜜臀av性久久久久蜜臀av麻豆| 欧美少妇xxx| 亚洲免费在线看| av在线不卡免费看| 国产精品久久久久影院亚瑟 | 色婷婷av一区二区三区大白胸| 久久久蜜桃精品| 国产大陆亚洲精品国产| 久久久久国产精品人| 国产精品白丝jk黑袜喷水| 精品播放一区二区| 国产一区二区网址| 国产精品麻豆网站| 色婷婷久久综合| 亚洲国产精品影院| 欧美一区二区在线播放| 精品一区二区三区影院在线午夜 | 欧美视频完全免费看| 一二三四区精品视频| 欧美午夜精品久久久久久孕妇| 亚洲自拍与偷拍| 9191久久久久久久久久久| 日韩精品色哟哟| 久久免费偷拍视频| 成人av电影免费在线播放| 亚洲乱码国产乱码精品精98午夜| 一本到高清视频免费精品| 亚洲国产日产av| 日韩精品中文字幕一区| 国产黄色精品视频| 亚洲狼人国产精品| 制服丝袜国产精品| 狠狠狠色丁香婷婷综合激情 | 成人免费毛片app| 亚洲精品欧美激情| 日韩亚洲欧美成人一区| 国产电影精品久久禁18| 亚洲精品乱码久久久久久 | 欧美亚洲综合色| 老司机精品视频在线| 国产精品久久久久四虎| 在线视频你懂得一区| 免费精品视频在线| 国产精品全国免费观看高清| 在线观看免费亚洲| 国产乱人伦偷精品视频免下载| 亚洲色欲色欲www在线观看| 欧美喷潮久久久xxxxx| 国产精品资源在线| 亚洲国产欧美在线| 国产精品视频yy9299一区| 欧美日韩成人综合天天影院| 国产精品一区二区x88av| 一区二区三区欧美日| 欧美xxxx老人做受| 日本精品一区二区三区高清 | 久久久久久久久久久久电影| 色播五月激情综合网| 国产一区二区福利| 亚洲成a人在线观看| 国产日产欧产精品推荐色 | 在线一区二区三区| 国产不卡免费视频| 蓝色福利精品导航| 亚洲成人精品一区| 亚洲天堂中文字幕| 欧美激情综合网| 欧美va亚洲va香蕉在线| 欧美日韩三级在线| 99这里只有久久精品视频| 久久爱www久久做| 日韩黄色一级片| 一区二区不卡在线播放 | 2020国产精品| 678五月天丁香亚洲综合网| 99久久er热在这里只有精品15 | 九色|91porny| 日韩av一区二| 亚洲成人www| 一区二区三区中文在线观看| 国产精品欧美久久久久无广告 | 精品乱人伦小说| 91精品国模一区二区三区| 欧美视频一区二区在线观看| 在线视频国内自拍亚洲视频| 91污在线观看| 91同城在线观看| 99精品在线观看视频| 成人99免费视频| a在线欧美一区| 91网站视频在线观看| 成人99免费视频| 97aⅴ精品视频一二三区| 91欧美一区二区| 一本色道久久加勒比精品 | 欧美mv和日韩mv的网站| 日韩午夜在线播放| 欧美mv和日韩mv的网站| 久久久亚洲精品石原莉奈| 久久久三级国产网站| 中文字幕精品一区二区精品绿巨人 | 最近中文字幕一区二区三区| 国产精品素人一区二区| 欧美国产97人人爽人人喊| 欧美韩国一区二区| 亚洲男人的天堂av| 亚洲一区中文日韩| 男人的天堂久久精品| 六月丁香婷婷久久| 成人午夜私人影院| 欧美在线999| 欧美一区二区视频免费观看| 日韩欧美激情四射| 国产日产欧产精品推荐色| 国产精品不卡在线观看| 亚洲免费三区一区二区| 日韩在线观看一区二区| 激情综合色播激情啊| 成人午夜免费电影| 欧美亚男人的天堂| 欧美精品一区二区蜜臀亚洲| 欧美国产国产综合| 婷婷丁香激情综合| 国产麻豆成人传媒免费观看| 色综合天天在线| 日韩女同互慰一区二区| 中文字幕成人网| 午夜免费欧美电影| 国产成人夜色高潮福利影视| 日本丶国产丶欧美色综合| 日韩欧美色综合| 亚洲日本电影在线| 久久99久久精品| 色老汉一区二区三区| 精品成人佐山爱一区二区| 亚洲美女电影在线| 国产专区综合网| 欧美美女一区二区在线观看| 国产亚洲一二三区| 午夜精品视频在线观看| 丁香婷婷综合激情五月色| 欧美巨大另类极品videosbest | 成人av免费网站| 欧美tickle裸体挠脚心vk| 一区二区三区在线免费视频| 极品尤物av久久免费看| 色婷婷综合久色| 中文字幕精品一区| 久久99这里只有精品| 欧美日韩在线播放| 自拍av一区二区三区| 国产自产高清不卡| 欧美成人性战久久| 亚洲二区在线视频| 91在线观看美女| 欧美高清在线一区二区| 激情另类小说区图片区视频区| 91高清视频在线| 亚洲日本韩国一区| 成人动漫av在线| 久久一二三国产| 老司机午夜精品99久久| 欧美精品久久久久久久多人混战| 一区二区在线观看视频在线观看| 高清久久久久久| 久久婷婷成人综合色| 韩国v欧美v亚洲v日本v| 91精品免费观看| 热久久久久久久| 欧美精品v国产精品v日韩精品| 亚洲综合一区二区| 欧美性生活一区| 亚洲最新在线观看| 欧美在线观看18| 亚洲五月六月丁香激情| 欧美日韩国产综合久久| 天天综合网天天综合色| 欧美电影影音先锋| 久久成人综合网|