Fix for DESKTOP colors select.

git-svn-id: svn://kolibrios.org@3271 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Marat Zakiyanov (Mario79) 2013-02-24 19:52:43 +00:00
parent 4fe36c5853
commit b4d539ba9c
2 changed files with 539 additions and 597 deletions

View File

@ -1,5 +0,0 @@
@echo lang fix en >lang.inc
@fasm -m 16384 tinypad.asm tinypad
@erase lang.inc
@kpack tinypad
@pause

View File

@ -16,7 +16,7 @@
dd 1 ; header version dd 1 ; header version
dd START ; start address dd START ; start address
dd I_END ; file size dd I_END ; file size
dd i_end ;28000h ; memory dd i_end ; memory
dd stacktop ; stack pointer dd stacktop ; stack pointer
dd skin_info ; parameters dd skin_info ; parameters
dd cur_dir_path ; path to file dd cur_dir_path ; path to file
@ -71,7 +71,7 @@ struct SKIN_BITMAPS
_data dd ? _data dd ?
ends ends
;---------------------------------------------------------------------
START: ; start of execution START: ; start of execution
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
mcall 68,11 mcall 68,11
@ -82,11 +82,9 @@ START: ; start of execution
load_libraries l_libs_start,end_l_libs load_libraries l_libs_start,end_l_libs
;if return code =-1 then exit, else nornary work ;if return code =-1 then exit, else nornary work
; cmp eax,-1
inc eax inc eax
test eax,eax test eax,eax
jz close jz close
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
mov edi,filename_area mov edi,filename_area
mov esi,start_temp_file_name mov esi,start_temp_file_name
@ -109,21 +107,6 @@ load_libraries l_libs_start,end_l_libs
test eax,eax test eax,eax
jnz @b jnz @b
;---------------------------------------------------------------------
; mov esi, param
; cmp byte [esi], 0
; je @f
; jnz has_param
; mov esi,default_skn
; mov edi,fname
; mov ecx,default_skn.size
; rep movsb
; jmp skin_path_ready
;has_param:
; mov ecx, 256/4
; mov edi, fname
; rep movsd
; skin_path_ready
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
mov edi,skin_info mov edi,skin_info
cmp byte [edi], 0 cmp byte [edi], 0
@ -152,27 +135,14 @@ skin_path_ready:
push dword PathShow_data_2 push dword PathShow_data_2
call [PathShow_prepare] call [PathShow_prepare]
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
mov eax,48 ; get current colors mcall 48,3,color_table,4*10 ; get current colors
mov ebx,3
mov ecx,color_table
mov edx,4*10
mcall
call load_skin_file.2 call load_skin_file.2
;---------------------------------------------------------------------
; mov esi, default_dtp
; mov edi, fname
; mov ecx, default_dtp.size
; rep movsb
red: red:
call draw_window ; at first, draw the window call draw_window ; at first, draw the window
;---------------------------------------------------------------------
still: still:
mcall 23,5 ; wait here for event
mov eax,23 ; wait here for event
mov ebx,5
mcall
dec eax ; redraw request ? dec eax ; redraw request ?
jz red jz red
@ -184,84 +154,79 @@ still:
call draw_cursor call draw_cursor
jmp still jmp still
;---------------------------------------------------------------------
key: ; key key: ; key
mov al,2 ; just read it and ignore mcall 2 ; just read it and ignore
mcall
jmp still jmp still
;---------------------------------------------------------------------
button: ; button button: ; button
mov al,17 ; get id mcall 17 ; get id
mcall
; cmp ah,11 ; read string
; jne no_string
; call read_string
; jmp still
; no_string:
cmp ah,12 ; load file cmp ah,12 ; load file
jne no_load jne no_load
call load_file call load_file
call draw_window call draw_window
jmp still jmp still
;--------------------------------------
no_load: no_load:
cmp ah,13 ; save file cmp ah,13 ; save file
jne no_save jne no_save
call save_file call save_file
jmp still jmp still
;--------------------------------------
no_save: no_save:
cmp ah,14 ; set 3d buttons cmp ah,14 ; set 3d buttons
jne no_3d jne no_3d
mov eax,48
mov ebx,1
mov ecx,1
mcall
jmp doapply
no_3d:
mcall 48,1,1
jmp doapply
;--------------------------------------
no_3d:
cmp ah,15 ; set flat buttons cmp ah,15 ; set flat buttons
jne no_flat jne no_flat
mcall 48, 1, 0 mcall 48, 1, 0
;--------------------------------------
doapply: doapply:
mcall 48, 0, 0 mcall 48, 0, 0
jmp still jmp still
;--------------------------------------
no_flat: no_flat:
cmp ah,16 ; apply cmp ah,16 ; apply
jne no_apply jne no_apply
;--------------------------------------
apply_direct: apply_direct:
mov eax,48 mcall 48,2,color_table,10*4
mov ebx,2
mov ecx,color_table
mov edx,10*4
mcall
jmp doapply jmp doapply
;--------------------------------------
no_apply: no_apply:
cmp ah,17 ; load skin file cmp ah,17 ; load skin file
jne no_load_skin jne no_load_skin
call load_skin_file call load_skin_file
call draw_window call draw_window
jmp still jmp still
;--------------------------------------
no_load_skin: no_load_skin:
cmp ah,18 ; apply skin cmp ah,18 ; apply skin
jne no_apply_skin jne no_apply_skin
cmp [skin_info],0 cmp [skin_info],0
je no_apply_skin je no_apply_skin
mcall 48,8,skin_info mcall 48,8,skin_info
call draw_window call draw_window
jmp still jmp still
;--------------------------------------
no_apply_skin: no_apply_skin:
cmp ah,31 cmp ah,31
jb no_new_colour jb no_new_colour
cmp ah,41 cmp ah,41
jg no_new_colour jg no_new_colour
shr eax,8 shr eax,8
sub eax,31 sub eax,31
shl eax,2 shl eax,2
@ -269,59 +234,56 @@ doapply:
mov [eax+color_table],ebx mov [eax+color_table],ebx
cmp dword[not_packed_area+SKIN_HEADER.ident],'SKIN' cmp dword[not_packed_area+SKIN_HEADER.ident],'SKIN'
jne @f jne @f
mov edi,[not_packed_area+SKIN_HEADER.params] mov edi,[not_packed_area+SKIN_HEADER.params]
mov dword[edi+not_packed_area+SKIN_PARAMS.dtp.data+eax],ebx mov dword[edi+not_packed_area+SKIN_PARAMS.dtp.data+eax],ebx
call draw_skin call draw_skin
@@: call draw_colours ;--------------------------------------
@@:
call draw_colours
jmp still jmp still
;--------------------------------------
no_new_colour: no_new_colour:
cmp ah,1 ; terminate cmp ah,1 ; terminate
jnz noid1 jnz noid1
;--------------------------------------
close: close:
or eax,-1 or eax,-1
mcall mcall
;--------------------------------------
noid1: noid1:
jmp still jmp still
;---------------------------------------------------------------------
draw_cursor: draw_cursor:
pusha pusha
mov eax,37 mcall 37,2
mov ebx,2
mcall
cmp eax,0 cmp eax,0
jne dc1 jne dc1
popa popa
ret ret
;--------------------------------------
dc1: dc1:
mcall 37,1
mov eax,37
mov ebx,1
mcall
mov ebx,eax mov ebx,eax
shr ebx,16 shr ebx,16
mov ecx,eax mov ecx,eax
and ecx,0xffff and ecx,0xffff
cmp ecx,29
cmp ecx,32
jbe no_color jbe no_color
cmp ebx,32 cmp ebx,32
jbe no_color jbe no_color
cmp ebx,266 ; CHANGE COLOR cmp ebx,266 ; CHANGE COLOR
jb no_color jb no_color
cmp ebx,266+20*3 cmp ebx,266+20*3
jg no_color jg no_color
cmp ecx,30+128 cmp ecx,30+128
jge no_color jge no_color
cmp ecx,30
cmp ecx,29
jb no_color jb no_color
sub ebx,266 sub ebx,266
@ -331,22 +293,15 @@ draw_cursor:
div ebx div ebx
mov ebx,2 mov ebx,2
sub ebx,eax sub ebx,eax
add ecx,-30 add ecx,-30
not ecx not ecx
shl ecx,1 shl ecx,1
mov byte [ebx+color],cl mov byte [ebx+color],cl
call draw_color call draw_color
popa
ret
no_color: no_color:
popa popa
ret ret
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
load_file: load_file:
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
@ -403,26 +358,23 @@ load_skin_file:
cmp dword [esi], 'KPCK' cmp dword [esi], 'KPCK'
jnz notpacked jnz notpacked
cmp dword [esi+4], 32*1024 ; max 32 KBytes cmp dword [esi+4], 32*1024 ; max 32 KBytes
ja doret ja doret
push unpack_area push unpack_area
push esi push esi
call unpack call unpack
mov esi,unpack_area mov esi,unpack_area
;--------------------------------------
notpacked: notpacked:
cmp [esi+SKIN_HEADER.ident],dword 'SKIN'
cmp dword[esi+SKIN_HEADER.ident],'SKIN'
jne doret jne doret
mov edi,not_packed_area mov edi,not_packed_area
mov ecx,0x8000/4 mov ecx,0x8000/4
rep movsd rep movsd
; mov esi,fname
; mov edi,skin_info.fname
; mov ecx,257
; rep movsb
mov ebp,not_packed_area mov ebp,not_packed_area
mov esi,[ebp+SKIN_HEADER.params] mov esi,[ebp+SKIN_HEADER.params]
add esi,ebp add esi,ebp
@ -430,10 +382,9 @@ notpacked:
mov edi,color_table mov edi,color_table
mov ecx,10 mov ecx,10
rep movsd rep movsd
;--------------------------------------
doret: doret:
ret ret
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
save_file: save_file:
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
@ -451,53 +402,33 @@ save_file:
call draw_PathShow call draw_PathShow
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
xor eax,eax
mov ebx,write_info mov ebx,write_info
mov dword [ebx], 2 ; subfunction: write mov [ebx],dword 2 ; subfunction: write
and dword [ebx+4], 0 ; (reserved) and [ebx+4],eax ; (reserved)
and dword [ebx+8], 0 ; (reserved) and [ebx+8],eax ; (reserved)
mov dword [ebx+12], 10*4 ; bytes to write mov [ebx+12],dword 10*4 ; bytes to write
mov dword [ebx+16], color_table ; address mov [ebx+16],dword color_table ; address
mcall 70 mcall 70
ret ret
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
draw_color: draw_color:
pusha pusha
mcall 13,<266,60>,<170,30>,[color]
mov eax,13 mcall ,,<200,10>,[w_work]
mov ebx,266*65536+60 mcall 47,<8,0+1*256>,[color],<272,201>,[w_work_text]
mov ecx,170*65536+30
mov edx,[color]
mcall
; mov eax,13
mov ebx,266*65536+60
mov ecx,200*65536+10
mov edx,[w_work]
mcall
mov eax,47
mov ebx,0+1*256+8*65536
mov ecx,[color]
mov edx,272*65536+201
mov esi,[w_work_text]
mcall
popa popa
ret ret
;---------------------------------------------------------------------- ;----------------------------------------------------------------------
draw_colours: draw_colours:
pusha pusha
mov esi,color_table mov esi,color_table
mov ebx,225*65536+32 mov ebx,225*65536+32
mov ecx,32*65536+12 mov ecx,32*65536+12
;--------------------------------------
newcol: newcol:
mov eax,13
mov edx,[esi] mov edx,[esi]
mcall mcall 13
add ecx,18*65536 add ecx,18*65536
add esi,4 add esi,4
cmp esi,color_table+4*9 cmp esi,color_table+4*9
@ -535,31 +466,48 @@ find_bitmap:
mov edi,[ebp+SKIN_HEADER.bitmaps] mov edi,[ebp+SKIN_HEADER.bitmaps]
add edi,ebp add edi,ebp
xor ebx,ebx xor ebx,ebx
.lp1: cmp dword[edi],0 ;--------------------------------------
.lp1:
cmp dword[edi],0
je .lp2 je .lp2
cmp dword[edi+0],eax cmp dword[edi+0],eax
jne @f jne @f
;--------------------------------------
mov ebx,[edi+SKIN_BITMAPS._data] mov ebx,[edi+SKIN_BITMAPS._data]
add ebx,ebp add ebx,ebp
mov ecx,[ebx-2] mov ecx,[ebx-2]
mov cx,[ebx+4] mov cx,[ebx+4]
add ebx,8 add ebx,8
.lp2: ret ;--------------------------------------
@@: add edi,8 .lp2:
ret
;--------------------------------------
@@:
add edi,8
jmp .lp1 jmp .lp1
;---------------------------------------------------------------------- ;----------------------------------------------------------------------
dec_edx: dec_edx:
sub dl,4 sub dl,4
jnc @f jnc @f
xor dl,dl xor dl,dl
@@: sub dh,4 ;--------------------------------------
@@:
sub dh,4
jnc @f jnc @f
xor dh,dh xor dh,dh
@@: rol edx,16 ;--------------------------------------
@@:
rol edx,16
sub dl,4 sub dl,4
jnc @f jnc @f
xor dl,dl xor dl,dl
@@: rol edx,16 ;--------------------------------------
@@:
rol edx,16
ret ret
;---------------------------------------------------------------------- ;----------------------------------------------------------------------
area: area:
@ -567,35 +515,37 @@ area:
.y = 20 .y = 20
.width = 206 .width = 206
.height = 191 .height = 191
;--------------------------------------
wnd1: wnd1:
.x = area.x+49 .x = area.x+49
.y = area.y+5 .y = area.y+5
.width = 150 .width = 150
.height = 90 .height = 90
;--------------------------------------
wnd2: wnd2:
.x = area.x+35 .x = area.x+35
.y = area.y+35 .y = area.y+35
.width = 150 .width = 150
.height = 90 .height = 90
;--------------------------------------
wnd3: wnd3:
.x = area.x+21 .x = area.x+21
.y = area.y+65 .y = area.y+65
.width = 150 .width = 150
.height = 90 .height = 90
;--------------------------------------
wnd4: wnd4:
.x = area.x+7 .x = area.x+7
.y = area.y+95 .y = area.y+95
.width = 150 .width = 150
.height = 90 .height = 90
;--------------------------------------
virtual at edi+SKIN_PARAMS.dtp.data virtual at edi+SKIN_PARAMS.dtp.data
dtp system_colors dtp system_colors
end virtual end virtual
;---------------------------------------------------------------------- ;----------------------------------------------------------------------
draw_skin: draw_skin:
mcall 13,<area.x,area.width>,<area.y+2,area.height-2>,0x00FFFFFF mcall 13,<area.x,area.width>,<area.y+2,area.height-2>,0x00FFFFFF
mov ebp,not_packed_area mov ebp,not_packed_area
mov edi,[ebp+SKIN_HEADER.params] mov edi,[ebp+SKIN_HEADER.params]
add edi,ebp add edi,ebp
@ -604,13 +554,14 @@ draw_skin:
mov edx,[dtp.frame] mov edx,[dtp.frame]
call draw_framerect call draw_framerect
mcall 13,<wnd1.x+1,wnd1.width-2>,<wnd1.y+1,wnd1.height-2>,dword[dtp.work] mcall 13,<wnd1.x+1,wnd1.width-2>,<wnd1.y+1,wnd1.height-2>,dword[dtp.work]
mov eax,38 mov eax,38
mpack ebx,wnd1.x+1,wnd1.x+wnd1.width-2 mpack ebx,wnd1.x+1,wnd1.x+wnd1.width-2
mpack ecx,wnd1.y+1,wnd1.y+1 mpack ecx,wnd1.y+1,wnd1.y+1
mov edx,[dtp.grab] mov edx,[dtp.grab]
mov esi,20 mov esi,20
@@: mcall ;--------------------------------------
@@:
mcall
call dec_edx call dec_edx
add ecx,0x00010001 add ecx,0x00010001
dec esi dec esi
@ -619,12 +570,9 @@ draw_skin:
mov edi,[ebp+SKIN_HEADER.params] mov edi,[ebp+SKIN_HEADER.params]
add edi,ebp add edi,ebp
mcall 4,<wnd1.x+6,wnd1.y+7>,dword[dtp.grab_text],caption_text,caption_text.size mcall 4,<wnd1.x+6,wnd1.y+7>,dword[dtp.grab_text],caption_text,caption_text.size
mcall 8,<wnd1.x+wnd1.width-18,12>,<wnd1.y+4,12>,0,[dtp.grab_button] mcall 8,<wnd1.x+wnd1.width-18,12>,<wnd1.y+4,12>,0,[dtp.grab_button]
mcall 4,<wnd1.x+wnd1.width-18+4,wnd1.y+4+2>,dword[dtp.grab_button_text],close_text,close_text.size mcall 4,<wnd1.x+wnd1.width-18+4,wnd1.y+4+2>,dword[dtp.grab_button_text],close_text,close_text.size
;---------------------------------------------------------------------- ;----------------------------------------------------------------------
mov edi,[ebp+SKIN_HEADER.params] mov edi,[ebp+SKIN_HEADER.params]
add edi,ebp add edi,ebp
mpack ebx,wnd2.x,wnd2.width mpack ebx,wnd2.x,wnd2.width
@ -649,7 +597,9 @@ draw_skin:
mpack ecx,wnd2.y+4,wnd2.y+4 mpack ecx,wnd2.y+4,wnd2.y+4
mov edx,[dtp.grab] mov edx,[dtp.grab]
mov esi,16 mov esi,16
@@: mcall ;--------------------------------------
@@:
mcall
call dec_edx call dec_edx
add ecx,0x00010001 add ecx,0x00010001
dec esi dec esi
@ -658,12 +608,9 @@ draw_skin:
mov edi,[ebp+SKIN_HEADER.params] mov edi,[ebp+SKIN_HEADER.params]
add edi,ebp add edi,ebp
mcall 4,<wnd2.x+8,wnd2.y+7>,dword[dtp.grab_text],caption_text,caption_text.size mcall 4,<wnd2.x+8,wnd2.y+7>,dword[dtp.grab_text],caption_text,caption_text.size
mcall 8,<wnd2.x+wnd2.width-20,12>,<wnd2.y+4,12>,0,[dtp.grab_button] mcall 8,<wnd2.x+wnd2.width-20,12>,<wnd2.y+4,12>,0,[dtp.grab_button]
mcall 4,<wnd2.x+wnd2.width-20+4,wnd2.y+4+2>,dword[dtp.grab_button_text],close_text,close_text.size mcall 4,<wnd2.x+wnd2.width-20+4,wnd2.y+4+2>,dword[dtp.grab_button_text],close_text,close_text.size
;---------------------------------------------------------------------- ;----------------------------------------------------------------------
mov edi,[ebp+SKIN_HEADER.params] mov edi,[ebp+SKIN_HEADER.params]
add edi,ebp add edi,ebp
mpack ebx,wnd3.x,wnd3.width mpack ebx,wnd3.x,wnd3.width
@ -695,15 +642,18 @@ draw_skin:
shl edx,16 shl edx,16
add edx,wnd3.x*65536+wnd3.y add edx,wnd3.x*65536+wnd3.y
mcall 7 mcall 7
@@: rol edx,16 ;--------------------------------------
@@:
rol edx,16
add dx,[ebx-8] add dx,[ebx-8]
cmp dx,si cmp dx,si
ja @f ja @f
rol edx,16 rol edx,16
mcall 7 mcall 7
jmp @b jmp @b
;--------------------------------------
@@: @@:
mov eax,0x00000002 ; oper, inactive mov eax,0x00000002 ; oper, inactive
call find_bitmap call find_bitmap
mov edx,ecx mov edx,ecx
@ -725,9 +675,7 @@ draw_skin:
push eax push eax
lea ebx,[eax+wnd3.x*65536+wnd3.y] lea ebx,[eax+wnd3.x*65536+wnd3.y]
mcall 4,,dword[dtp.grab_text],caption_text,caption_text.size mcall 4,,dword[dtp.grab_text],caption_text,caption_text.size
;--------------------------------------------------------- ;---------------------------------------------------------
mov edi,[ebp+SKIN_HEADER.params] mov edi,[ebp+SKIN_HEADER.params]
add edi,ebp add edi,ebp
mpack ebx,wnd4.x,wnd4.width mpack ebx,wnd4.x,wnd4.width
@ -759,15 +707,18 @@ draw_skin:
shl edx,16 shl edx,16
add edx,wnd4.x*65536+wnd4.y add edx,wnd4.x*65536+wnd4.y
mcall 7 mcall 7
@@: rol edx,16 ;--------------------------------------
@@:
rol edx,16
add dx,[ebx-8] add dx,[ebx-8]
cmp dx,si cmp dx,si
ja @f ja @f
rol edx,16 rol edx,16
mcall 7 mcall 7
jmp @b jmp @b
;--------------------------------------
@@: @@:
mov eax,0x00010002 ; oper, inactive mov eax,0x00010002 ; oper, inactive
call find_bitmap call find_bitmap
mov edx,ecx mov edx,ecx
@ -783,13 +734,14 @@ draw_skin:
pop eax pop eax
lea ebx,[eax+wnd4.x*65536+wnd4.y] lea ebx,[eax+wnd4.x*65536+wnd4.y]
mcall 4,,dword[dtp.grab_text],caption_text,caption_text.size mcall 4,,dword[dtp.grab_text],caption_text,caption_text.size
;---------------------------------------------------------------------- ;----------------------------------------------------------------------
mov edi,[ebp+SKIN_HEADER.buttons] mov edi,[ebp+SKIN_HEADER.buttons]
add edi,ebp add edi,ebp
.lp1: cmp dword[edi],0 ;--------------------------------------
.lp1:
cmp dword[edi],0
je .lp2 je .lp2
mov ebx,dword[edi+SKIN_BUTTONS.left-2] mov ebx,dword[edi+SKIN_BUTTONS.left-2]
mov bx,[edi+SKIN_BUTTONS.width] mov bx,[edi+SKIN_BUTTONS.width]
mov ecx,dword[edi+SKIN_BUTTONS.top-2] mov ecx,dword[edi+SKIN_BUTTONS.top-2]
@ -801,8 +753,8 @@ draw_skin:
mcall 8,,,0x40000000 mcall 8,,,0x40000000
add edi,12 add edi,12
jmp .lp1 jmp .lp1
;--------------------------------------
.lp2: .lp2:
mov edi,[ebp+SKIN_HEADER.params] mov edi,[ebp+SKIN_HEADER.params]
add edi,ebp add edi,ebp
mpack ebx,wnd4.x+10,wnd4.y+10 mpack ebx,wnd4.x+10,wnd4.y+10
@ -823,7 +775,6 @@ draw_skin:
mov bx,cx mov bx,cx
add ebx,0x00060006 add ebx,0x00060006
mcall 4,,[dtp.work_button_text],button_text,button_text.size mcall 4,,[dtp.work_button_text],button_text,button_text.size
ret ret
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
draw_PathShow: draw_PathShow:
@ -872,8 +823,6 @@ else
end if end if
; LOAD BUTTON ; LOAD BUTTON
; mov ebx,15*65536+load_w
; mov ecx,(35+18*12)*65536+14
mcall 8,<15,load_w>,<35+18*12,14>,12,[w_work_button] mcall 8,<15,load_w>,<35+18*12,14>,12,[w_work_button]
; SAVE BUTTON ; SAVE BUTTON
add ebx,(load_w+2)*65536-load_w+save_w add ebx,(load_w+2)*65536-load_w+save_w
@ -1267,7 +1216,8 @@ db 'SKN',0
.end: .end:
db 0 db 0
start_temp_file_name: db 'default.dtp',0 start_temp_file_name:
db 'default.dtp',0
default_skin: default_skin:
db '/sys/default.skn',0 db '/sys/default.skn',0
@ -1331,9 +1281,6 @@ cur_dir_path:
library_path: library_path:
rb 4096 rb 4096
;--------------------------------------------------------------------- ;---------------------------------------------------------------------
;fname_buf:
; rb 4096
;---------------------------------------------------------------------
temp_dir_pach: temp_dir_pach:
rb 4096 rb 4096
;--------------------------------------------------------------------- ;---------------------------------------------------------------------