forked from KolibriOS/kolibrios
changes in 'TreeList':
- fix 'tl_node_lev_inc' - fix 'tl_node_lev_dec' git-svn-id: svn://kolibrios.org@1402 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
e1a0b0c660
commit
505644f066
@ -1,6 +1,6 @@
|
||||
; ìàêðîñ äëÿ ñèñòåìíîé áèáëèîòåêè box_lib.obj
|
||||
; ýëåìåíò TreeList äëÿ Kolibri OS
|
||||
; ôàéë ïîñëåäíèé ðàç èçìåíÿëñÿ 09.02.2010 IgorA
|
||||
; файл последний раз изменялся 10.02.2010 IgorA
|
||||
; íà êîä ïðèìåíåíà GPL2 ëèöåíçèÿ
|
||||
|
||||
|
||||
@ -681,7 +681,7 @@ tl_draw: ;
|
||||
;output:
|
||||
; edx = pointer to next node struct
|
||||
align 4
|
||||
tl_iterat_next:
|
||||
tl_iterat_next: ;переход на следущий видимый узел (пропуская закрытые)
|
||||
push bx
|
||||
mov bl,0x7f
|
||||
cmp byte[edx+3],1
|
||||
@ -724,7 +724,7 @@ tl_iterat_next:
|
||||
; edx = pointer to some node struct
|
||||
; edi = pointer to 'TreeList' struct
|
||||
align 4
|
||||
tl_iterat_next_all:
|
||||
tl_iterat_next_all: ;переход на следущий видимый узел (и на закрытые тоже)
|
||||
cmp tl_tim_undo,0
|
||||
je .else
|
||||
|
||||
@ -753,7 +753,7 @@ tl_iterat_next_all:
|
||||
; edx = pointer to some node struct
|
||||
; edi = pointer to 'TreeList' struct
|
||||
align 4
|
||||
tl_iterat_perv:
|
||||
tl_iterat_perv: ;переход на предыдущий видимый узел (пропуская закрытые)
|
||||
push eax
|
||||
cmp tl_tim_undo,0
|
||||
je .beg1
|
||||
@ -865,7 +865,7 @@ tl_move_par: ;
|
||||
; al = 1 if sumbol not visible
|
||||
; (node[i].td+tim_Undo<=ch_tim && node[i].td) || (node[i].tc>ch_tim-tim_Undo)
|
||||
align 4
|
||||
tl_node_not_vis:
|
||||
tl_node_not_vis: ;проверяет видимый ли указанный узел с учетом: добавлений, удалений, отмен действий
|
||||
cmp dword[edx+16],0
|
||||
je @f
|
||||
mov eax,dword[edx+16] ;eax=node[i].td
|
||||
@ -1027,7 +1027,7 @@ tl_get_display_cur_pos: ;
|
||||
; edi = pointer to 'TreeList' struct
|
||||
; esi = coord of bottom border
|
||||
align 4
|
||||
tl_draw_node:
|
||||
tl_draw_node: ;рисует узел с: картинкой, подписью, иконкой открытия/закрытия и линиями к родит. узлу
|
||||
push eax ebx ecx edx esi
|
||||
|
||||
mov ebx,1 ;1 - ìåñòî ïîä êóðñîð è ïîä çíàê +,-
|
||||
@ -1101,11 +1101,11 @@ tl_draw_node:
|
||||
dec ah
|
||||
.close:
|
||||
|
||||
call tl_draw_node_icon_opn_clo
|
||||
call tl_draw_node_icon_opn_clo ;рисование иконки открытого или закрытого узла
|
||||
bt tl_style,1
|
||||
jae .end_draw
|
||||
call tl_draw_node_icon_par_lin
|
||||
call tl_draw_node_icon_par_lin_up
|
||||
call tl_draw_node_icon_par_lin ;рисование линии к родительскому элементу
|
||||
call tl_draw_node_icon_par_lin_up ;рисование вертикальной линии к родительскому элементу
|
||||
.end_draw:
|
||||
pop esi edx ecx ebx eax
|
||||
ret
|
||||
@ -1159,7 +1159,7 @@ tl_draw_node_icon_opn_clo: ;
|
||||
; edx = pointer to some node struct
|
||||
;...
|
||||
align 4
|
||||
tl_draw_node_icon_par_lin:
|
||||
tl_draw_node_icon_par_lin: ;рисование линии к родительскому элементу
|
||||
cmp byte[edx+3],1
|
||||
je .close
|
||||
push eax ebx ecx edx esi
|
||||
@ -2023,9 +2023,12 @@ tl_node_lev_inc: ;
|
||||
mov edx,eax
|
||||
call tl_iterat_perv ;ïðîâåðÿåì åñòü ëè âåðõíèé óçåë
|
||||
cmp edx,ecx
|
||||
jle @f ;åñëè âåðõíåãî óçëà íå òî òåêóùèé óçåë íå äâèãàåì
|
||||
|
||||
inc word[eax+2]
|
||||
jle @f ;если верхнего узла нет то текущий узел не двигаем
|
||||
mov cl,byte[edx+2] ;берем уровень родительского узла
|
||||
inc cl ;добавляем 1 и получаем максимальное значение
|
||||
cmp byte[eax+2],cl
|
||||
jge @f
|
||||
inc byte[eax+2] ;увеличиваем значение узла
|
||||
@@:
|
||||
pop edi edx ecx eax
|
||||
pop ebp
|
||||
@ -2042,9 +2045,9 @@ tl_node_lev_dec: ;
|
||||
jl @f
|
||||
imul eax,sizeof.TreeList
|
||||
add eax,tl_data_nodes
|
||||
cmp word[eax+2],0
|
||||
cmp byte[eax+2],0
|
||||
je @f
|
||||
dec word[eax+2]
|
||||
dec byte[eax+2]
|
||||
@@:
|
||||
pop edi eax
|
||||
pop ebp
|
||||
@ -2258,7 +2261,7 @@ tl_save_mem:
|
||||
jg .err_mem_size
|
||||
|
||||
;save tree params (in header)
|
||||
mov dword[esi],0x65657274 ;0x65657274 = 'tree'
|
||||
mov dword[esi],'tree'
|
||||
mov word[esi+4],bx
|
||||
mov dword[esi+6],eax ;element count
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user