forked from KolibriOS/kolibrios
archiver.obj: fix function deflate_rle
kiv: clean code git-svn-id: svn://kolibrios.org@6801 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
ee04f7ac02
commit
fb9e611d64
@ -2912,7 +2912,7 @@ align 4
|
||||
mov esi,[edx+deflate_state.window]
|
||||
add esi,[edx+deflate_state.strstart]
|
||||
dec esi
|
||||
lodsb
|
||||
lodsb ;prev = *scan; ++scan
|
||||
mov edi,esi
|
||||
scasb
|
||||
jnz .end2
|
||||
@ -2925,6 +2925,7 @@ align 4
|
||||
;ecx = strend-scan
|
||||
mov ecx,MAX_MATCH-2
|
||||
repz scasb
|
||||
dec edi
|
||||
sub edi,[edx+deflate_state.window]
|
||||
sub edi,[edx+deflate_state.strstart]
|
||||
mov [edx+deflate_state.match_length],edi
|
||||
|
@ -112,7 +112,7 @@ button:
|
||||
|
||||
align 4
|
||||
draw_window:
|
||||
mcall SF_REDRAW, SSF_BEGIN_DRAW ; äãªæ¨ï 12: á®®¡é¨âì Ž‘ ® ç «¥ ®âà¨á®¢ª¨
|
||||
mcall SF_REDRAW, SSF_BEGIN_DRAW
|
||||
mcall SF_STYLE_SETTINGS, SSF_GET_COLORS, sc,sizeof.system_colors
|
||||
mov edx, [sc.work] ; 梥â ä®
|
||||
or edx, 0x33000000 ; ¨ ⨯ ®ª 3
|
||||
@ -127,8 +127,12 @@ draw_window:
|
||||
cStr edx,'Outp. size:'
|
||||
mcall , <10,120>,,,11
|
||||
|
||||
mcall SF_DRAW_NUMBER, (1 shl 16)+1, strategy, <90,10>, 0
|
||||
mcall , (5 shl 16)+1, m0size, <90,20>
|
||||
mov edx,[strategy]
|
||||
imul edx,12
|
||||
add edx,capt_strateg
|
||||
mcall , <90,10>,0,,12
|
||||
|
||||
mcall SF_DRAW_NUMBER, (5 shl 16)+1, m0size, <90,20>
|
||||
mcall , (5 shl 16)+1, m1size, <90,30>
|
||||
mcall , (5 shl 16)+1, m2size, <90,120>
|
||||
;mov ecx,(1 shl 31)
|
||||
@ -149,7 +153,7 @@ draw_window:
|
||||
dec esi
|
||||
jnz .cycle1
|
||||
|
||||
mcall SF_REDRAW, SSF_END_DRAW ; äãªæ¨ï 12.2, § ª®ç¨«¨ à¨á®¢ âì
|
||||
mcall SF_REDRAW, SSF_END_DRAW
|
||||
ret
|
||||
|
||||
align 4
|
||||
@ -238,10 +242,18 @@ proc print_z_struct uses eax ebx
|
||||
ret
|
||||
endp
|
||||
|
||||
align 4
|
||||
sc system_colors
|
||||
|
||||
align 4
|
||||
title db 'Zlib test, press on [Up], [Down], [Left], [Right]',0
|
||||
|
||||
align 4
|
||||
capt_strateg db '0) Default ',0
|
||||
db '1) Filtered',0
|
||||
db '2) Huffman ',0
|
||||
db '3) Rle ',0
|
||||
db '4) Fixed ',0
|
||||
|
||||
align 4
|
||||
import_archiver:
|
||||
deflate_unpack dd sz_deflate_unpack
|
||||
|
@ -12,6 +12,7 @@ include '../../../config.inc'
|
||||
include '../../../proc32.inc'
|
||||
include '../../../macros.inc'
|
||||
include '../../../dll.inc'
|
||||
include '../../../KOSfuncs.inc'
|
||||
;include '../../../debug.inc'
|
||||
|
||||
include '../../../develop/libraries/libs-dev/libio/libio.inc'
|
||||
@ -22,7 +23,7 @@ include '../../../develop/libraries/libs-dev/libimg/libimg.inc'
|
||||
;-----------------------------------------------------------------------------
|
||||
|
||||
START:
|
||||
mcall 68, 11
|
||||
mcall SF_SYS_MISC, SSF_HEAP_INIT
|
||||
|
||||
stdcall dll.Load, @IMPORT
|
||||
or eax, eax
|
||||
@ -58,7 +59,7 @@ START:
|
||||
mov [slide_key], eax
|
||||
invoke ini_get_shortcut, inifilename, aShortcuts, aTglbar, -1, tglbar_mod
|
||||
mov [tglbar_key], eax
|
||||
mcall 66, 1, 1 ; set kbd mode to scancodes
|
||||
mcall SF_KEYBOARD, SSF_SET_INPUT_MODE, 1 ; set kbd mode to scancodes
|
||||
|
||||
cmp byte [@PARAMS], 0
|
||||
jnz params_given
|
||||
@ -82,7 +83,7 @@ START:
|
||||
jmp params_given
|
||||
|
||||
set_bgr:
|
||||
mcall 15, 4
|
||||
mcall SF_BACKGROUND_SET, SSF_MODE_BG
|
||||
mov eax, @PARAMS + 4
|
||||
call load_image
|
||||
jc exit
|
||||
@ -112,7 +113,7 @@ still:
|
||||
push 10
|
||||
pop eax
|
||||
jz @f
|
||||
mcall 26, 9
|
||||
mcall SF_SYSTEM_GET, SSF_TIME_COUNT
|
||||
mov edx, [cur_frame]
|
||||
mov ebx, [cur_frame_time]
|
||||
add ebx, [edx + Image.Delay]
|
||||
@ -134,12 +135,12 @@ still:
|
||||
key:
|
||||
xor esi, esi
|
||||
keyloop:
|
||||
mcall 2
|
||||
mcall SF_GET_KEY
|
||||
test al, al
|
||||
jnz keyloopdone
|
||||
shr eax, 8
|
||||
mov ecx, eax
|
||||
mcall 66, 3
|
||||
mcall SF_KEYBOARD, SSF_GET_CONTROL_KEYS
|
||||
mov edx, next_mod
|
||||
call check_shortcut
|
||||
jz .next
|
||||
@ -195,14 +196,14 @@ red_update_frame:
|
||||
mov eax, [image]
|
||||
@@:
|
||||
mov [cur_frame], eax
|
||||
mcall 26, 9
|
||||
mcall SF_SYSTEM_GET, SSF_TIME_COUNT
|
||||
mov [cur_frame_time], eax
|
||||
mcall 9, procinfo, -1
|
||||
mcall SF_THREAD_INFO, procinfo, -1
|
||||
call draw_cur_frame
|
||||
jmp still
|
||||
|
||||
button:
|
||||
mcall 17
|
||||
mcall SF_GET_BUTTON
|
||||
shr eax, 8
|
||||
|
||||
; flip horizontally
|
||||
@ -310,7 +311,7 @@ button:
|
||||
jne still
|
||||
|
||||
exit:
|
||||
mcall -1
|
||||
mcall SF_TERMINATE_PROCESS
|
||||
|
||||
redraw_image = red
|
||||
|
||||
@ -417,9 +418,9 @@ update_image_sizes:
|
||||
jz .no_resize
|
||||
test [wnd_style], 1 SHL 25
|
||||
jz .no_resize
|
||||
mcall 48, 4
|
||||
mcall SF_STYLE_SETTINGS, SSF_GET_SKIN_HEIGHT
|
||||
add esi, eax
|
||||
mcall 67,-1,-1
|
||||
mcall SF_CHANGE_WINDOW,-1,-1
|
||||
.no_resize:
|
||||
ret
|
||||
|
||||
@ -427,19 +428,19 @@ set_as_bgr:
|
||||
mov esi, [image]
|
||||
mov ecx, [esi + Image.Width]
|
||||
mov edx, [esi + Image.Height]
|
||||
mcall 15, 1
|
||||
mcall SF_BACKGROUND_SET, SSF_SIZE_BG
|
||||
|
||||
mcall 15, 6
|
||||
mcall SF_BACKGROUND_SET, SSF_MAP_BG
|
||||
test eax, eax
|
||||
jz @f
|
||||
|
||||
push eax
|
||||
invoke img.to_rgb2, esi, eax
|
||||
pop ecx
|
||||
mcall 15, 7
|
||||
mcall SF_BACKGROUND_SET, SSF_UNMAP_BG
|
||||
|
||||
@@:
|
||||
mcall 15, 3
|
||||
mcall SF_BACKGROUND_SET, SSF_REDRAW_BG
|
||||
ret
|
||||
|
||||
slide_show:
|
||||
@ -573,13 +574,13 @@ load_directory:
|
||||
rep movsb
|
||||
@@:
|
||||
mov byte [edi], 0
|
||||
mcall 68, 12, 0x1000
|
||||
mcall SF_SYS_MISC, SSF_MEM_ALLOC, 0x1000
|
||||
test eax, eax
|
||||
jz .ret
|
||||
mov ebx, readdir_fileinfo
|
||||
mov dword [ebx+12], (0x1000 - 32) / 304
|
||||
mov dword [ebx+16], eax
|
||||
mcall 70
|
||||
mcall SF_FILE
|
||||
cmp eax, 6
|
||||
jz .dirok
|
||||
test eax, eax
|
||||
@ -589,11 +590,11 @@ load_directory:
|
||||
mov [readblocks], ecx
|
||||
imul ecx, 304
|
||||
add ecx, 32
|
||||
mcall 68, 20
|
||||
mcall SF_SYS_MISC, SSF_MEM_REALLOC
|
||||
test eax, eax
|
||||
jz free_directory
|
||||
mov [directory_ptr], eax
|
||||
mcall 70, readdir_fileinfo
|
||||
mcall SF_FILE, readdir_fileinfo
|
||||
.dirok:
|
||||
cmp ebx, 0
|
||||
jle free_directory
|
||||
@ -704,7 +705,7 @@ load_directory:
|
||||
ret
|
||||
|
||||
free_directory:
|
||||
mcall 68, 13, [directory_ptr]
|
||||
mcall SF_SYS_MISC, SSF_MEM_FREE, [directory_ptr]
|
||||
and [directory_ptr], 0
|
||||
ret
|
||||
|
||||
@ -734,7 +735,7 @@ init_frame:
|
||||
test byte [eax + Image.Flags], Image.IsAnimated
|
||||
jz @f
|
||||
push ebx
|
||||
mcall 26, 9
|
||||
mcall SF_SYSTEM_GET, SSF_TIME_COUNT
|
||||
pop ebx
|
||||
mov [cur_frame_time], eax
|
||||
@@:
|
||||
@ -753,15 +754,15 @@ draw_window:
|
||||
mov eax, [image]
|
||||
cmp eax, eax
|
||||
call update_image_sizes
|
||||
mcall 48, 4
|
||||
mcall SF_STYLE_SETTINGS, SSF_GET_SKIN_HEIGHT
|
||||
mov esi, [wnd_height]
|
||||
add esi, eax
|
||||
test byte [bTglbar], 1
|
||||
jz @f
|
||||
mcall 67, -1, -1, [wnd_width],
|
||||
mcall SF_CHANGE_WINDOW, -1, -1, [wnd_width],
|
||||
jmp .mode_not_changed
|
||||
@@:
|
||||
mcall 67, [wnd_x], [wnd_y], [wnd_width],
|
||||
mcall SF_CHANGE_WINDOW, [wnd_x], [wnd_y], [wnd_width],
|
||||
jmp .mode_not_changed
|
||||
.mode_slide:
|
||||
mov [bg_color], 0x00000000
|
||||
@ -769,19 +770,19 @@ draw_window:
|
||||
mov [wnd_x], eax
|
||||
mov eax, [procinfo.box.top]
|
||||
mov [wnd_y], eax
|
||||
mcall 14
|
||||
mcall SF_GET_SCREEN_SIZE
|
||||
mov edx, eax
|
||||
shr edx, 16
|
||||
movzx eax, ax
|
||||
mov esi, eax
|
||||
mcall 67, 0, 0, ,
|
||||
mcall SF_CHANGE_WINDOW, 0, 0, ,
|
||||
jmp .posok.slide_show
|
||||
|
||||
.mode_not_changed:
|
||||
cmp [bFirstDraw], 0
|
||||
jz .posok
|
||||
or ecx, -1
|
||||
mcall 9, procinfo
|
||||
mcall SF_THREAD_INFO, procinfo
|
||||
|
||||
test byte [procinfo.wnd_state], 0x04
|
||||
jnz .posok
|
||||
@ -801,14 +802,14 @@ draw_window:
|
||||
cmp eax, -1
|
||||
jz @f
|
||||
mov ebx, ecx
|
||||
mcall 67
|
||||
mcall SF_CHANGE_WINDOW
|
||||
@@:
|
||||
|
||||
.posok:
|
||||
test [wnd_style], 1 SHL 25
|
||||
jz .posok.slide_show
|
||||
mcall 12, 1
|
||||
mcall 48, 4
|
||||
mcall SF_REDRAW, SSF_BEGIN_DRAW
|
||||
mcall SF_STYLE_SETTINGS, SSF_GET_SKIN_HEIGHT
|
||||
mov ebp, eax ; save skin height
|
||||
add eax, [wnd_height]
|
||||
mov ebx, [wnd_x]
|
||||
@ -817,18 +818,18 @@ draw_window:
|
||||
mov ecx, [wnd_y]
|
||||
shl ecx, 16
|
||||
add ecx, eax
|
||||
mcall 0, , , [wnd_style], 0, real_header
|
||||
mcall SF_CREATE_WINDOW, , , [wnd_style], 0, real_header
|
||||
jmp .posok.common
|
||||
.posok.slide_show:
|
||||
mcall 12, 1
|
||||
mcall 14
|
||||
mcall SF_REDRAW, SSF_BEGIN_DRAW
|
||||
mcall SF_GET_SCREEN_SIZE
|
||||
mov ebx, eax
|
||||
shr ebx, 16
|
||||
movzx eax, ax
|
||||
mov ecx, eax
|
||||
mcall 0, , , [wnd_style], 0, real_header
|
||||
mcall SF_CREATE_WINDOW, , , [wnd_style], 0, real_header
|
||||
.posok.common:
|
||||
mcall 9, procinfo, -1
|
||||
mcall SF_THREAD_INFO, procinfo, -1
|
||||
mov eax, [procinfo.client_box.width]
|
||||
sub eax, [image_padding]
|
||||
sub eax, [image_padding]
|
||||
@ -859,7 +860,7 @@ draw_window:
|
||||
mov ebx, [procinfo.client_box.width]
|
||||
inc ebx
|
||||
mov ecx, [draw_y]
|
||||
mcall 13, , , [bg_color]
|
||||
mcall SF_DRAW_RECT, , , [bg_color]
|
||||
mov ecx, [procinfo.client_box.height]
|
||||
inc ecx
|
||||
mov esi, [cur_frame]
|
||||
@ -900,7 +901,7 @@ draw_window:
|
||||
je .decorations_done
|
||||
mov ebx, [procinfo.client_box.width]
|
||||
push ebx
|
||||
mcall 38, , <30, 30>, 0x007F7F7F
|
||||
mcall SF_DRAW_LINE, , <30, 30>, 0x007F7F7F
|
||||
mcall , <5 + 25 * 1, 5 + 25 * 1>, <0, 30>
|
||||
mcall , <10 + 25 * 3, 10 + 25 * 3>
|
||||
mcall , <15 + 25 * 5, 15 + 25 * 5>
|
||||
@ -910,7 +911,7 @@ draw_window:
|
||||
imul ebx, 10001h
|
||||
mcall
|
||||
|
||||
mcall 8, <5 + 25 * 0, 20>, <5, 20>, 'opn'+40000000h
|
||||
mcall SF_DEFINE_BUTTON, <5 + 25 * 0, 20>, <5, 20>, 'opn'+40000000h
|
||||
mcall , <10 + 25 * 1, 20>, , 'bck'+40000000h
|
||||
mcall , <10 + 25 * 2, 20>, , 'fwd'+40000000h
|
||||
mcall , <15 + 25 * 3, 20>, , 'bgr'+40000000h
|
||||
@ -931,7 +932,7 @@ draw_window:
|
||||
|
||||
mov ebp, (numimages-1)*20
|
||||
|
||||
mcall 65, buttons+openbtn*20, <20, 20>, <5 + 25 * 0, 5>, 8, palette
|
||||
mcall SF_PUT_IMAGE_EXT, buttons+openbtn*20, <20, 20>, <5 + 25 * 0, 5>, 8, palette
|
||||
mcall , buttons+backbtn*20, , <10 + 25 * 1, 5>
|
||||
mcall , buttons+forwardbtn*20, , <10 + 25 * 2, 5>
|
||||
mcall , buttons+bgrbtn*20, , <15 + 25 * 3, 5>
|
||||
@ -957,7 +958,7 @@ draw_window:
|
||||
call draw_cur_frame
|
||||
|
||||
.nodraw:
|
||||
mcall 12, 2
|
||||
mcall SF_REDRAW, SSF_END_DRAW
|
||||
|
||||
ret
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user