forked from KolibriOS/kolibrios
128 lines
2.1 KiB
PHP
128 lines
2.1 KiB
PHP
|
;<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> [dest] <EFBFBD><EFBFBD> EAX
|
|||
|
test_path:
|
|||
|
pushad
|
|||
|
mov cx, [lineCoord + eax*2 - 4]
|
|||
|
mov edx, eax
|
|||
|
cmp eax, [current]
|
|||
|
je .recurs_call
|
|||
|
|
|||
|
cmp eax, [dest]
|
|||
|
je .end_yes
|
|||
|
|
|||
|
cmp byte [eax + lineBall - 2], 0
|
|||
|
jne .end_no
|
|||
|
|
|||
|
or byte [eax + lineBall - 2], 0x8 ;4-<EFBFBD> <EFBFBD><EFBFBD><EFBFBD> - 1 (cheked)
|
|||
|
|
|||
|
.recurs_call:
|
|||
|
;<EFBFBD>㯮<EFBFBD> <EFBFBD>맮<EFBFBD> <EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD>ᥤ<EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD>⮪
|
|||
|
test cl, cl
|
|||
|
jz @F
|
|||
|
sub eax, 9
|
|||
|
call test_path
|
|||
|
jc .end_yes
|
|||
|
|
|||
|
@@:
|
|||
|
test cl, 8
|
|||
|
jnz @F
|
|||
|
mov eax, edx
|
|||
|
add eax, 9
|
|||
|
call test_path
|
|||
|
jc .end_yes
|
|||
|
|
|||
|
@@:
|
|||
|
test ch, ch
|
|||
|
jz @F
|
|||
|
mov eax, edx
|
|||
|
dec eax
|
|||
|
call test_path
|
|||
|
jc .end_yes
|
|||
|
|
|||
|
@@:
|
|||
|
test ch, 8
|
|||
|
jnz .end_no
|
|||
|
mov eax, edx
|
|||
|
inc eax
|
|||
|
call test_path
|
|||
|
jc .end_yes
|
|||
|
|
|||
|
.end_no:
|
|||
|
clc
|
|||
|
popad
|
|||
|
ret
|
|||
|
.end_yes:
|
|||
|
stc
|
|||
|
popad
|
|||
|
ret
|
|||
|
|
|||
|
;<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ([dest] - ID <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD>᪠)
|
|||
|
find_line:
|
|||
|
mov dword [findRightLeft], 0 ;<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>塞 <EFBFBD><EFBFBD>砫<EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD>祭<EFBFBD><EFBFBD>
|
|||
|
|
|||
|
mov eax, [dest]
|
|||
|
add eax, lineBall - 2
|
|||
|
mov dh, [eax]
|
|||
|
mov [baseAddr], eax
|
|||
|
or byte [eax], 0xF0
|
|||
|
|
|||
|
mov ecx, 8 ;<EFBFBD> ecx - <EFBFBD><EFBFBD><EFBFBD><EFBFBD>稪
|
|||
|
.cycle_find:
|
|||
|
lea eax, [ecx*4 + ecx]
|
|||
|
shl eax, 1 ;eax = ecx*10
|
|||
|
mov edi, [eax + findTable - 4] ;edi - <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>뢠<EFBFBD><EFBFBD> १-<EFBFBD><EFBFBD>
|
|||
|
mov ebp, [eax + findTable - 8] ;ebp - <EFBFBD>ਡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
mov bx, [eax + findTable - 10] ;bx - <EFBFBD>ਡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD>न<EFBFBD><EFBFBD><EFBFBD>
|
|||
|
mov dl, cl
|
|||
|
shl dl, 4
|
|||
|
mov esi, [baseAddr]
|
|||
|
mov eax, [dest]
|
|||
|
mov ax, [eax*2 + lineCoord - 4]
|
|||
|
.small_cycle_find:
|
|||
|
add al, bh
|
|||
|
cmp al, 8 ;<EFBFBD> [0..8] ?
|
|||
|
ja @F
|
|||
|
add ah, bl
|
|||
|
cmp ah, 8
|
|||
|
ja @F
|
|||
|
|
|||
|
add esi, ebp
|
|||
|
cmp byte [esi], dh
|
|||
|
jne @F
|
|||
|
|
|||
|
or byte [esi], dl
|
|||
|
inc byte [edi]
|
|||
|
jmp .small_cycle_find
|
|||
|
@@:
|
|||
|
loop .cycle_find
|
|||
|
ret
|
|||
|
|
|||
|
findRightLeft db ?
|
|||
|
findUpRight_DownLeft db ?
|
|||
|
findUpDown db ?
|
|||
|
findUpLeft_DownRight db ?
|
|||
|
|
|||
|
findTable:
|
|||
|
Up:
|
|||
|
db -1, 0
|
|||
|
dd -1, findUpDown
|
|||
|
Down:
|
|||
|
db +1, 0
|
|||
|
dd +1, findUpDown
|
|||
|
Left:
|
|||
|
db 0, -1
|
|||
|
dd -9, findRightLeft
|
|||
|
Right:
|
|||
|
db 0, +1
|
|||
|
dd +9, findRightLeft
|
|||
|
UpLeft:
|
|||
|
db -1, -1
|
|||
|
dd -10, findUpLeft_DownRight
|
|||
|
DownRight:
|
|||
|
db +1, +1
|
|||
|
dd +10, findUpLeft_DownRight
|
|||
|
UpRight:
|
|||
|
db -1, +1
|
|||
|
dd +8, findUpRight_DownLeft
|
|||
|
DownLeft:
|
|||
|
db +1, -1
|
|||
|
dd -8, findUpRight_DownLeft
|