From 2fa4df354957fa63dcaf334e425042abe19cdabb Mon Sep 17 00:00:00 2001 From: "Marat Zakiyanov (Mario79)" Date: Sat, 1 Mar 2014 19:33:34 +0000 Subject: [PATCH] Box_Lib - Editbox support for Clipboard (Ctrl + C|V) git-svn-id: svn://kolibrios.org@4601 a494cfbc-eb01-0410-851d-a64ba20cac60 --- .../libraries/box_lib/trunk/box_lib.asm | 1 + .../libraries/box_lib/trunk/box_lib.mac | 4 + .../libraries/box_lib/trunk/editbox.mac | 136 +++++++++++++++++- 3 files changed, 137 insertions(+), 4 deletions(-) diff --git a/programs/develop/libraries/box_lib/trunk/box_lib.asm b/programs/develop/libraries/box_lib/trunk/box_lib.asm index 01ae74af44..91d9b8f82a 100644 --- a/programs/develop/libraries/box_lib/trunk/box_lib.asm +++ b/programs/develop/libraries/box_lib/trunk/box_lib.asm @@ -20,6 +20,7 @@ include '../../../../macros.inc' include '../../../../proc32.inc' include 'bl_sys.mac' include 'box_lib.mac' ;macro which should make life easier :) +;include '../../../../debug.inc' ;----------------------------------------------------------------------------- mem.alloc dd ? ;ЇєэъЎш  фы  т√фхыхэш  ярь Єш diff --git a/programs/develop/libraries/box_lib/trunk/box_lib.mac b/programs/develop/libraries/box_lib/trunk/box_lib.mac index 8a1e4583c4..8747d05022 100644 --- a/programs/develop/libraries/box_lib/trunk/box_lib.mac +++ b/programs/develop/libraries/box_lib/trunk/box_lib.mac @@ -49,6 +49,10 @@ ed_insert_cl= 1111111101111111b ed_mouse_on = 100000000b ed_mous_adn_b= 100011000b ed_mouse_on_off=1111111011111111b +ed_ctrl_on = 1000000000b +ed_ctrl_off = 1111110111111111b +ed_alt_on = 10000000000b +ed_alt_off = 1111101111111111b ed_height=14 ; высота struc edit_box width,left,top,color,shift_color,focus_border_color,\ diff --git a/programs/develop/libraries/box_lib/trunk/editbox.mac b/programs/develop/libraries/box_lib/trunk/editbox.mac index 5a7b3a61f3..959ef10bb8 100644 --- a/programs/develop/libraries/box_lib/trunk/editbox.mac +++ b/programs/develop/libraries/box_lib/trunk/editbox.mac @@ -8,6 +8,7 @@ macro use_editbox_draw edit_box: .draw: pushad +.draw_1: ;--- рисуем рамку --- mov edi,dword [esp+36] call .draw_border ; Функция стабильна @@ -68,7 +69,7 @@ pushad pop eax ;-------------------------------------- ;Проверка нажат shift ? - call edit_box_key.check_shift + call edit_box_key.check_shift_ctrl_alt ;---------------------------------------------------------- ;--- проверяем, что нажато -------------------------------- ;---------------------------------------------------------- @@ -86,6 +87,17 @@ pushad jz edit_box_key.end cmp ah,185 ;insert jz edit_box_key.insert +; комбинации Ctrl + клавиша + test word ed_flags,ed_ctrl_on + jz @f +; проверка сканкода + ror eax,8 + cmp ah,46 ; Ctrl + C + je edit_box_key.ctrl_c + cmp ah,47 ; Ctrl + V + je edit_box_key.ctrl_v + rol eax,8 +@@: ;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;Заглушка на обработку клавиш вверх и вниз т.е. при обнаружении этих кодов происходит выход из обработчика ;;;;;;;;;;;;;;;;;;;;;;;;;;;; @@ -779,12 +791,22 @@ edit_box_key.draw_rectangle: ;;;;;;;;;;;;;;;;;; ;;Проверка нажат ли shift ;;;;;;;;;;;;;;;;;; -edit_box_key.check_shift: +edit_box_key.check_shift_ctrl_alt: pusha ;сохраним все регистры mcall 66,3 - test al,0x03 + test al,11b je @f - or word ed_flags,ed_shift ;установим флаг + or word ed_flags,ed_shift ;установим флаг Shift +@@: + and word ed_flags,ed_ctrl_off ; очистим флаг Ctrl + test al,1100b + je @f + or word ed_flags,ed_ctrl_on ;установим флаг Ctrl +@@: + and word ed_flags,ed_alt_off ; очистим флаг Alt + test al,110000b + je @f + or word ed_flags,ed_alt_on ;установим флаг Alt @@:edit_ex } @@ -1052,6 +1074,112 @@ edit_box_key.end: mov ed_pos,eax call edit_box_key.sh_home_end jmp edit_box.draw_cursor_text +;----------------------------------------------------------------------------- +edit_box_key.ctrl_c: +; add memory area + mov ecx,ed_size + add ecx,3*4 + mcall 68,12 +; building the clipboard slot header + xor ecx,ecx + mov [eax+4],ecx ; type 'text' + inc ecx + mov [eax+8],ecx ; cp866 text encoding + mov ecx,ed_size + add ecx,3*4 + mov [eax],ecx + sub ecx,3*4 +; copy data + mov esi,ed_text + push edi + mov edi,eax + add edi,3*4 + cld + rep movsb + pop edi +; put slot to the kernel clipboard + mov edx,eax + mov ecx,[edx] + push eax + mcall 54,2 + pop ecx +; remove unnecessary memory area + mcall 68,13 +;-------------------------------------- +.exit: + jmp edit_box.editbox_exit +;----------------------------------------------------------------------------- +edit_box_key.ctrl_v: + mcall 54,0 +; no slots of clipboard ? + test eax,eax + jz .exit +; main list area not found ? + inc eax + test eax,eax + jz .exit + + sub eax,2 + mov ecx,eax + mcall 54,1 +; main list area not found ? + inc eax + test eax,eax + jz .exit +; error ? + sub eax,2 + test eax,eax + jz .exit + + inc eax +; check contents of container + mov ebx,[eax+4] +; check for text + test ebx,ebx + jnz .no_valid_text + + mov ebx,[eax+8] +; check for cp866 + cmp bl,1 + jnz .no_valid_text + + mov ecx,[eax] + sub ecx,3*4 + cmp ecx,ed_max + jb @f + + mov ecx,ed_max +@@: + mov esi,eax + add esi,3*4 + mov ed_size,ecx + mov ed_pos,ecx + push eax edi + mov edi,ed_text + cld +@@: + lodsb + cmp al,0x0d ; EOS (end of string) + je .replace + + cmp al,0x0a ; EOS (end of string) + jne .continue +.replace: + mov al,0x20 ; space +.continue: + stosb + dec ecx + jnz @b +; rep movsb + pop edi eax +;-------------------------------------- +.no_valid_text: +; remove unnecessary memory area + mov ecx,eax + mcall 68,13 +;-------------------------------------- +.exit: + jmp edit_box.draw_1 } macro use_mouse_func