From ee04f7ac0293c58f1963d99973871e6ca4c6641b Mon Sep 17 00:00:00 2001 From: pathoswithin Date: Sun, 18 Dec 2016 03:13:18 +0000 Subject: [PATCH] more unicode functions git-svn-id: svn://kolibrios.org@6800 a494cfbc-eb01-0410-851d-a64ba20cac60 --- kernel/trunk/docs/sysfuncr.txt | 29 ++++ kernel/trunk/docs/sysfuncs.txt | 30 ++++ kernel/trunk/gui/window.inc | 291 +++++++++++++-------------------- kernel/trunk/kernel.asm | 70 +++++--- 4 files changed, 216 insertions(+), 204 deletions(-) diff --git a/kernel/trunk/docs/sysfuncr.txt b/kernel/trunk/docs/sysfuncr.txt index 371a1062a2..4198ce709d 100644 --- a/kernel/trunk/docs/sysfuncr.txt +++ b/kernel/trunk/docs/sysfuncr.txt @@ -1940,6 +1940,15 @@ path db 'HD0/1',0 * После прочтения значения обнуляются. * Данные имеют знаковые значения. +------- Подфункция 8 - загрузить курсор с указанием кодировки. ------- +Параметры: + * eax = 37 - номер функции + * ebx = 8 - номер подфункции + * ecx = указатель на строку с путём к файлу курсора + * edx = кодировка строки, подробности указаны в описании функции 80. +Возвращаемое значение: + * eax = хэндл курсора, 0 - неудача + ---------------------- Константы для регистров: ---------------------- eax - SF_MOUSE_GET (37) ebx - SSF_SCREEN_POSITION (0), SSF_WINDOW_POSITION (1), @@ -2429,6 +2438,26 @@ dword-значение цвета 0x00RRGGBB eax - SF_STYLE_SETTINGS (48) ebx - SSF_SET_FONT_SIZE (12) ====================================================================== += Функция 48, подфункция 13 - установить скин с указанием кодировки. = +====================================================================== +Параметры: + * eax = 48 - номер функции + * ebx = 13 - номер подфункции + * ecx = указатель на строку с путём к файлу скина + * edx = кодировка строки, подробности указаны в описании функции 80. +Возвращаемое значение: + * eax = 0 - успешно + * eax = 1 - не удалось загрузить файл + * eax = 2 - файл не является файлом скина +Замечания: + * При успешной загрузке скина все окна извещаются о необходимости + перерисовки (событие 1). + * При загрузке система считывает скин из файла default.skn + на рамдиске. + * Пользователь может изменять скин статически, создав свой + default.skn, или динамически с помощью приложения desktop. + +====================================================================== ============ Функция 49 - Advanced Power Management (APM). =========== ====================================================================== Параметры: diff --git a/kernel/trunk/docs/sysfuncs.txt b/kernel/trunk/docs/sysfuncs.txt index a297529b2f..21a1c3b0a9 100644 --- a/kernel/trunk/docs/sysfuncs.txt +++ b/kernel/trunk/docs/sysfuncs.txt @@ -1922,6 +1922,15 @@ Remarks: * Values are zeroed after reading. * Values are signed. +-------- Subfunction 8 - load cursor, specifying the encoding -------- +Parameters: + * eax = 37 - function number + * ebx = 8 - subfunction number + * ecx = pointer to the cursor file path string + * edx = string encoding, details can be found in function 80 description. +Returned value: + * eax = cursor handle, 0 - failed + ---------------------- Constants for registers: ---------------------- eax - SF_MOUSE_GET (37) ebx - SSF_SCREEN_POSITION (0), SSF_WINDOW_POSITION (1), @@ -2407,6 +2416,27 @@ Parameters: eax - SF_STYLE_SETTINGS (48) ebx - SSF_SET_FONT_SIZE (12) ====================================================================== +== Function 48, subfunction 13 - set skin, specifying the encoding. == +====================================================================== +Parameters: + * eax = 48 - function number + * ebx = 13 - subfunction number + * ecx = pointer to the skin file path string + * edx = string encoding, details can be found in function 80 description. +Returned value: + * eax = 0 - success + * otherwise eax = file system error code; if file does not + contain valid skin, function returns error 3 + (unknown file system). +Remarks: + * After successful skin loading the system sends to all windows + redraw message (the event 1). + * At booting the system reads skin from file 'default.skn' + on ramdisk. + * User can change the skin statically by creating hisself + 'default.skn' or dynamically with the application 'desktop'. + +====================================================================== =========== Function 49 - Advanced Power Management (APM). =========== ====================================================================== Parameters: diff --git a/kernel/trunk/gui/window.inc b/kernel/trunk/gui/window.inc index b24eb0e247..d09948bee3 100644 --- a/kernel/trunk/gui/window.inc +++ b/kernel/trunk/gui/window.inc @@ -14,17 +14,6 @@ $Revision$ window.BORDER_SIZE = 5 -macro FuncTable name, table_name, [label] -{ - common - align 4 - \label name#.#table_name dword - forward - dd name#.#label - common - name#.sizeof.#table_name = $ - name#.#table_name -} - uglobal common_colours rd 48 draw_limits RECT @@ -82,85 +71,58 @@ syscall_draw_window: ;///// system function 0 ///////////////////////////////// ;------------------------------------------------------------------------------ syscall_display_settings: ;///// system function 48 /////////////////////////// ;------------------------------------------------------------------------------ -;; Redraw screen: -;< ebx = 0 -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Set button style: -;< ebx = 1 -;< ecx = 0 (flat) or 1 (with gradient) -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Set system color palette: -;< ebx = 2 -;< ecx = pointer to color table -;< edx = size of color table -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Get system color palette: -;< ebx = 3 -;< ecx = pointer to color table buffer -;< edx = size of color table buffer -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Get skinned caption height: -;< ebx = 4 -;> eax = height in pixels -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Get screen working area: -;< ebx = 5 -;> eax = pack[16(left), 16(right)] -;> ebx = pack[16(top), 16(bottom)] -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Set screen working area: -;< ebx = 6 -;< ecx = pack[16(left), 16(right)] -;< edx = pack[16(top), 16(bottom)] -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Get skin margins: -;< ebx = 7 -;> eax = pack[16(left), 16(right)] -;> ebx = pack[16(top), 16(bottom)] -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Set skin: -;< ebx = 8 -;< ecx = pointer to FileInfoBlock struct -;> eax = FS error code -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Get font smoothing: -;< ebx = 9 -;> eax = 0 — off, 1 — on, 2 — subpixel -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Set font smoothing: -;< ebx = 10 -;< ecx = 0 — off, 1 — on, 2 — subpixel -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Get font size: -;< ebx = 11 -;> eax = height in pixels -; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -;; Set font size: -;< ebx = 12 -;< ecx = height in pixels -;------------------------------------------------------------------------------ - cmp ebx, .sizeof.ftable / 4 + cmp ebx, 13 ja @f - jmp [.ftable + ebx * 4] -;------------------------------------------------------------------------------ -syscall_display_settings.00: + jmp dword[.ftable + ebx*4] + +align 4 +.ftable: +dd .redrawWholeScreen +dd .setButtonStyle +dd .setSystemColors +dd .getSystemColors +dd .getCaptionHeight +dd .getScreenWorkingArea +dd .setScreenWorkingArea +dd .getSkinMargins +dd .setSkin +dd .getFontSmoothing +dd .setFontSmoothing +dd .getFontSize +dd .setFontSize +dd .setSkinUnicode + +.redrawWholeScreen: xor eax, eax inc ebx cmp [windowtypechanged], ebx - jne @f + jne .ret mov [windowtypechanged], eax - jmp syscall_display_settings._.redraw_whole_screen -;------------------------------------------------------------------------------ -syscall_display_settings.01: +.redrawScreen: + xor eax, eax + mov [draw_limits.left], eax + mov [draw_limits.top], eax + mov eax, [_display.width] + dec eax + mov [draw_limits.right], eax + mov eax, [_display.height] + dec eax + mov [draw_limits.bottom], eax + mov eax, window_data + jmp redrawscreen + +.setButtonStyle: +; in: ecx: 0 = flat, 1 = with gradient and ecx, 1 cmp ecx, [buttontype] - je @f + je .ret mov [buttontype], ecx mov [windowtypechanged], ebx -@@: +.ret: ret -;------------------------------------------------------------------------------ -syscall_display_settings.02: + +.setSystemColors: +; in: ecx = pointer to color table, edx = size of color table dec ebx mov esi, ecx cmp edx, 192 @@ -172,8 +134,9 @@ syscall_display_settings.02: rep movsb mov [windowtypechanged], ebx ret -;------------------------------------------------------------------------------ -syscall_display_settings.03: + +.getSystemColors: +; in: ecx = pointer to color table, edx = size of color table mov edi, ecx cmp edx, 192 jnae @f @@ -183,13 +146,14 @@ syscall_display_settings.03: mov ecx, edx rep movsb ret -;------------------------------------------------------------------------------ -syscall_display_settings.04: + +.getCaptionHeight: mov eax, [_skinh] mov [esp + 32], eax ret -;------------------------------------------------------------------------------ -syscall_display_settings.05: + +.getScreenWorkingArea: +; out: eax = pack[left, right], ebx = pack[top, bottom] mov eax, [screen_workarea.left - 2] mov ax, word[screen_workarea.right] mov [esp + 32], eax @@ -197,8 +161,9 @@ syscall_display_settings.05: mov ax, word[screen_workarea.bottom] mov [esp + 20], eax ret -;------------------------------------------------------------------------------ -syscall_display_settings.06: + +.setScreenWorkingArea: +; in: ecx = pack[left, right], edx = pack[top, bottom] xor esi, esi mov edi, [_display.width] dec edi @@ -240,49 +205,8 @@ syscall_display_settings.06: .check_if_redraw_needed: or esi, esi jz @f - call repos_windows - jmp syscall_display_settings._.calculate_whole_screen -;------------------------------------------------------------------------------ -syscall_display_settings.07: - mov eax, [_skinmargins + 0] - mov [esp + 32], eax - mov eax, [_skinmargins + 4] - mov [esp + 20], eax -@@: - ret -;------------------------------------------------------------------------------ -syscall_display_settings.08: - mov ebx, ecx - call read_skin_file - mov [esp + 32], eax - test eax, eax - jnz @b - - call syscall_display_settings._.calculate_whole_screen - jmp syscall_display_settings._.redraw_whole_screen -;------------------------------------------------------------------------------ -syscall_display_settings.09: - xor eax, eax - mov al, [fontSmoothing] - mov [esp + 32], eax - ret -;------------------------------------------------------------------------------ -syscall_display_settings.10: - mov [fontSmoothing], cl - ret -;------------------------------------------------------------------------------ -syscall_display_settings.11: - xor eax, eax - mov al, [fontSize] - mov [esp + 32], eax - ret -;------------------------------------------------------------------------------ -syscall_display_settings.12: - mov [fontSize], cl - ret -;------------------------------------------------------------------------------ -syscall_display_settings._.calculate_whole_screen: +.calculateScreen: xor eax, eax xor ebx, ebx mov ecx, [_display.width] @@ -290,19 +214,63 @@ syscall_display_settings._.calculate_whole_screen: dec ecx dec edx jmp calculatescreen -;------------------------------------------------------------------------------ -syscall_display_settings._.redraw_whole_screen: + +.getSkinMargins: +; out: eax = pack[left, right], ebx = pack[top, bottom] + mov eax, [_skinmargins + 0] + mov [esp + 32], eax + mov eax, [_skinmargins + 4] + mov [esp + 20], eax + ret + +.setSkin: +; in: ecx -> file path string + mov ebx, ecx + call read_skin_file + mov [esp + 32], eax + test eax, eax + jnz .ret + call .calculateScreen + jmp .redrawScreen + +.getFontSmoothing: xor eax, eax - mov [draw_limits.left], eax - mov [draw_limits.top], eax - mov eax, [_display.width] - dec eax - mov [draw_limits.right], eax - mov eax, [_display.height] - dec eax - mov [draw_limits.bottom], eax - mov eax, window_data - jmp redrawscreen + mov al, [fontSmoothing] + mov [esp + 32], eax + ret + +.setFontSmoothing: + mov [fontSmoothing], cl + ret + +.getFontSize: + xor eax, eax + mov al, [fontSize] + mov [esp + 32], eax + ret + +.setFontSize: + mov [fontSize], cl + ret + +.setSkinUnicode: +; in: ecx -> file path string, edx = string encoding + push ecx edx + stdcall kernel_alloc, maxPathLength + mov edi, eax + pop eax esi + push edi + call getFullPath + test eax, eax + jz @f + mov ebx, [esp] + call read_skin_file + mov [esp + 32 + 4], eax +@@: + call kernel_free + call .calculateScreen + jmp .redrawScreen + ;------------------------------------------------------------------------------ syscall_set_window_shape: ;///// system function 50 /////////////////////////// ;------------------------------------------------------------------------------ @@ -617,29 +585,6 @@ align 4 mov [edi + WDATA.box.height], eax jmp .fix_client_box ;------------------------------------------------------------------------------ -;align 4 -;------------------------------------------------------------------------------ -;sys_window_mouse: ;//////////////////////////////////////////////////////////// -;------------------------------------------------------------------------------ -;? -;------------------------------------------------------------------------------ - ; NOTE: commented out since doesn't provide necessary functionality - ; anyway, to be reworked -; push eax -; -; mov eax, [timer_ticks] -; cmp [new_window_starting], eax -; jb .exit -; -; mov byte[MOUSE_BACKGROUND], 0 -; mov byte[DONT_DRAW_MOUSE], 0 -; -; mov [new_window_starting], eax -; -; .exit: -; pop eax -; ret -;------------------------------------------------------------------------------ align 4 ;------------------------------------------------------------------------------ draw_rectangle: ;////////////////////////////////////////////////////////////// @@ -1046,8 +991,8 @@ align 4 jz @f push edx - call syscall_display_settings._.calculate_whole_screen - call syscall_display_settings._.redraw_whole_screen + call syscall_display_settings.calculateScreen + call syscall_display_settings.redrawScreen pop edx ;-------------------------------------- align 4 @@ -1381,11 +1326,8 @@ sys_window_moving_handler: ;/////////////////////////////////////////////////// ;============================================================================== iglobal - FuncTable syscall_display_settings, ftable, \ - 00, 01, 02, 03, 04, 05, 06, 07, 08, 09, 10, 11, 12 - - align 4 - window_topleft dd \ +align 4 +window_topleft dd \ 1, 21, \ ;type 0 0, 0, \ ;type 1 5, 20, \ ;type 2 @@ -1393,11 +1335,6 @@ iglobal 5, ? ;type 4 {set by skin} endg -;uglobal - ; NOTE: commented out since doesn't provide necessary functionality anyway, - ; to be reworked -; new_window_starting dd ? -;endg ;------------------------------------------------------------------------------ align 4 ;------------------------------------------------------------------------------ diff --git a/kernel/trunk/kernel.asm b/kernel/trunk/kernel.asm index 312f2fa307..f5db5e1437 100644 --- a/kernel/trunk/kernel.asm +++ b/kernel/trunk/kernel.asm @@ -1871,20 +1871,7 @@ get_timer_ticks: mov eax, [timer_ticks] ret ;----------------------------------------------------------------------------- -iglobal -align 4 -mousefn dd msscreen - dd mswin - dd msbutton - dd msbuttonExt - dd app_load_cursor - dd app_set_cursor - dd app_delete_cursor - dd msz -endg -;----------------------------------------------------------------------------- readmousepos: - ; eax=0 screen relative ; eax=1 window relative ; eax=2 buttons pressed @@ -1893,12 +1880,24 @@ readmousepos: ; eax=5 set cursor ; eax=6 delete cursor ; eax=7 get mouse_z - - cmp ebx, 7 +; eax=8 load cursor unicode + cmp ebx, 8 ja @f - jmp [mousefn+ebx*4] + jmp dword[.mousefn+ebx*4] -msscreen: +align 4 +.mousefn: +dd .msscreen +dd .mswin +dd .msbutton +dd .msbuttonExt +dd .app_load_cursor +dd .app_set_cursor +dd .app_delete_cursor +dd .msz +dd .loadCursorUni + +.msscreen: mov eax, [MOUSE_X] shl eax, 16 mov ax, [MOUSE_Y] @@ -1906,7 +1905,7 @@ msscreen: @@: ret -mswin: +.mswin: mov eax, [MOUSE_X] shl eax, 16 mov ax, [MOUSE_Y] @@ -1924,17 +1923,17 @@ mswin: mov [esp+36-4], eax ret -msbutton: +.msbutton: movzx eax, byte [BTN_DOWN] mov [esp+36-4], eax ret -msbuttonExt: +.msbuttonExt: mov eax, [BTN_DOWN] mov [esp+36-4], eax ret -app_load_cursor: +.app_load_cursor: cmp ecx, OS_BASE jae @f stdcall load_cursor, ecx, edx @@ -1942,17 +1941,35 @@ app_load_cursor: @@: ret -app_set_cursor: +.loadCursorUni: + cmp ecx, OS_BASE + jae @b + push ecx edx + stdcall kernel_alloc, maxPathLength + mov edi, eax + pop eax esi + push edi + call getFullPath + pop ebp + test eax, eax + jz @f + stdcall load_cursor, ebp, LOAD_FROM_FILE + mov [esp+32], eax +@@: + stdcall kernel_free, ebp + ret + +.app_set_cursor: stdcall set_cursor, ecx mov [esp+36-4], eax ret -app_delete_cursor: +.app_delete_cursor: stdcall delete_cursor, ecx mov [esp+36-4], eax ret -msz: +.msz: mov edi, [TASK_COUNT] movzx edi, word [WIN_POS + edi*2] cmp edi, [CURRENT_TASK] @@ -2278,9 +2295,8 @@ sysfn_deactivate: ; 18.1 = DEACTIVATE WINDOW movzx esi, word [WIN_STACK + ecx * 2] lea esi, [WIN_POS + esi * 2] call window._.window_deactivate - - call syscall_display_settings._.calculate_whole_screen - call syscall_display_settings._.redraw_whole_screen + call syscall_display_settings.calculateScreen + call syscall_display_settings.redrawScreen .nowindowdeactivate: ret ;------------------------------------------------------------------------------