MTDBG: Fixed some glitches in GUI. Added ability to select color theme before assembling.

git-svn-id: svn://kolibrios.org@4591 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
hidnplayr 2014-02-25 17:34:48 +00:00
parent c8bb902077
commit 6ba242ab84
2 changed files with 1642 additions and 1648 deletions

View File

@ -5,55 +5,85 @@
;----------------------------------------------------------------------------- ;-----------------------------------------------------------------------------
; Color scheme ; Color scheme
BLACK_ON_WHITE equ 0
MOVIEOS equ 1
WHITE_ON_BLACK equ 2
; format - 0xRRGGBB ; format - 0xRRGGBB
COLOR_BG_NORMAL equ 0x101010 ; was 0xFFFFFF white if COLOR_THEME eq MOVIEOS
COLOR_BG_BREAKPOINT equ 0xFF0000 ; red
COLOR_BG_SELECTED equ 0x0000FF ; blue COLOR_BG_NORMAL = 0x1d272f
COLOR_LINE equ 0xFFFFFF ; was 0x000000 black COLOR_BG_BREAKPOINT = 0x0000aa
COLOR_TXT_NORMAL equ 0xFFFFFF ; was 0x000000 black COLOR_BG_SELECTED = 0xec9300
COLOR_TXT_INACTIVE equ 0x808080 ; grey COLOR_LINE = 0x00b9a0
COLOR_TXT_CHANGED equ 0x00AA00 ; green COLOR_TXT_NORMAL = 0xffffff
COLOR_TXT_SELECTED equ 0xFFFFFF ; white COLOR_TXT_INACTIVE = 0x8f7948
COLOR_TXT_CHANGED = 0xec9300
COLOR_TXT_SELECTED = 0x1d272f
else if COLOR_THEME eq WHITE_ON_BLACK
COLOR_BG_NORMAL = 0x101010 ; dark grey
COLOR_BG_BREAKPOINT = 0xFF0000 ; red
COLOR_BG_SELECTED = 0x0000FF ; blue
COLOR_LINE = 0xFFFFFF ; white
COLOR_TXT_NORMAL = 0xFFFFFF ; white
COLOR_TXT_INACTIVE = 0x808080 ; grey
COLOR_TXT_CHANGED = 0x00AA00 ; green
COLOR_TXT_SELECTED = 0xFFFFFF ; white
else ; BLACK ON WHITE
COLOR_BG_NORMAL = 0xffffff ; white
COLOR_BG_BREAKPOINT = 0xFF0000 ; red
COLOR_BG_SELECTED = 0x0000FF ; blue
COLOR_LINE = 0x000000 ; black
COLOR_TXT_NORMAL = 0x000000 ; black
COLOR_TXT_INACTIVE = 0x808080 ; grey
COLOR_TXT_CHANGED = 0x00AA00 ; green
COLOR_TXT_SELECTED = 0xFFFFFF ; white
end if
;----------------------------------------------------------------------------- ;-----------------------------------------------------------------------------
data_width equ 80 data_width equ 80
data_x_pos equ 12 data_x_pos equ 12
data_x_size equ data_width*6 data_x_size equ data_width*6
title_x_pos equ 30 title_x_pos equ 30
title_y_pos equ 32 title_y_pos equ 32
title_y_size equ 10 title_y_size equ 10
;dump_y_pos equ (registers_y_pos + registers_y_size + 5) ;dump_y_pos equ (registers_y_pos + registers_y_size + 5)
dump_y_pos equ (title_y_pos + title_y_size) dump_y_pos equ (title_y_pos + title_y_size)
dump_height equ 6 dump_height equ 6
dump_y_size equ (dump_height*10) dump_y_size equ (dump_height*10)
disasm_y_pos equ (dump_y_pos + dump_y_size + 4) disasm_y_pos equ (dump_y_pos + dump_y_size + 4)
disasm_height equ 18 disasm_height equ 18
disasm_y_size equ (disasm_height*10) disasm_y_size equ (disasm_height*10)
messages_width equ data_width messages_width equ data_width
messages_height equ 8 messages_height equ 8
messages_x_pos equ data_x_pos messages_x_pos equ data_x_pos
messages_y_pos equ (disasm_y_pos + disasm_y_size + 4) messages_y_pos equ (disasm_y_pos + disasm_y_size + 4)
messages_x_size equ messages_width*6 messages_x_size equ messages_width*6
messages_y_size equ messages_height*10 messages_y_size equ messages_height*10
cmdline_width equ data_width cmdline_width equ data_width
cmdline_x_pos equ data_x_pos cmdline_x_pos equ data_x_pos
cmdline_y_pos equ (messages_y_pos + messages_y_size + 4) cmdline_y_pos equ (messages_y_pos + messages_y_size + 4)
cmdline_x_size equ messages_x_size cmdline_x_size equ messages_x_size
cmdline_y_size equ 10 cmdline_y_size equ 10
registers_x_pos equ (data_x_pos + messages_x_size + 4) registers_x_pos equ (data_x_pos + messages_x_size + 4)
registers_y_pos equ (title_y_pos + title_y_size - 3) registers_y_pos equ (title_y_pos + title_y_size - 3)
registers_x_size equ 134 registers_x_size equ 134
registers_y_size equ (cmdline_y_pos + cmdline_y_size - registers_y_pos+1) registers_y_size equ (cmdline_y_pos + cmdline_y_size - registers_y_pos+1)
wnd_x_size equ (data_x_pos + messages_x_size + data_x_pos + registers_x_size+3) wnd_x_size equ (data_x_pos + messages_x_size + data_x_pos + registers_x_size+3)
wnd_y_size equ (cmdline_y_pos + cmdline_y_size + data_x_pos) wnd_y_size equ (cmdline_y_pos + cmdline_y_size + data_x_pos)
;----------------------------------------------------------------------------- ;-----------------------------------------------------------------------------
; Entry point ; Entry point
@ -577,7 +607,6 @@ draw_title:
;mov ebx, (data_x_pos-2)*10000h + title_x_pos-5 ;mov ebx, (data_x_pos-2)*10000h + title_x_pos-5
;mov ecx, (title_y_pos+5)*10001h ;mov ecx, (title_y_pos+5)*10001h
; draw line with COLOR_LINE (in edx) ; draw line with COLOR_LINE (in edx)
; was 'xor edx, edx'
mcall 38, (data_x_pos-2)*10000h+title_x_pos-5, (title_y_pos+5)*10001h, COLOR_LINE mcall 38, (data_x_pos-2)*10000h+title_x_pos-5, (title_y_pos+5)*10001h, COLOR_LINE
push NoPrgLoaded_len push NoPrgLoaded_len
pop esi pop esi
@ -603,7 +632,6 @@ draw_title:
mov al, 4 mov al, 4
mov ebx, title_x_pos*10000h+title_y_pos mov ebx, title_x_pos*10000h+title_y_pos
; setting up text color scheme and attributes ; setting up text color scheme and attributes
; was 'xor ecx, ecx'
mov ecx, COLOR_TXT_NORMAL mov ecx, COLOR_TXT_NORMAL
mov edx, NoPrgLoaded_str mov edx, NoPrgLoaded_str
cmp [debuggee_pid], 0 cmp [debuggee_pid], 0
@ -635,8 +663,6 @@ draw_title:
mov al, 38 mov al, 38
mov ebx, (data_x_pos+data_x_size-10-6*7-5)*0x10000 + data_x_pos+data_x_size+2 mov ebx, (data_x_pos+data_x_size-10-6*7-5)*0x10000 + data_x_pos+data_x_size+2
mov ecx, (title_y_pos+5)*10001h mov ecx, (title_y_pos+5)*10001h
; setting up line color scheme
; was 'xor edx, edx'
mov edx, COLOR_LINE mov edx, COLOR_LINE
jmp @b jmp @b
@ -1014,6 +1040,7 @@ draw_main_registers:
mov edx, aColon mov edx, aColon
xor esi, esi xor esi, esi
inc esi inc esi
mov ecx, COLOR_TXT_INACTIVE
;mov ebx, (registers_x_pos+10)*10000h + registers_y_pos+122 ;mov ebx, (registers_x_pos+10)*10000h + registers_y_pos+122
; draw a text string in the window, color in ecx ; draw a text string in the window, color in ecx
mcall 4, (registers_x_pos+10)*10000h+registers_y_pos+122 mcall 4, (registers_x_pos+10)*10000h+registers_y_pos+122
@ -1497,26 +1524,12 @@ update_disasm:
draw_window: draw_window:
; start window redraw ; start window redraw
;push 12
;pop eax
;push 1
;pop ebx
mcall 12, 1 mcall 12, 1
; define window ; define window
;xor eax, eax mcall 0, wnd_x_size, wnd_y_size, (COLOR_BG_NORMAL or 0x54000000), caption_str
;mov ebx, wnd_x_size
;mov ecx, wnd_y_size
;mov edx, 54FFFFFFh
mov edi, caption_str
; draw window with color in edx
; was 0x54FFFFFF - white background
mcall 0, wnd_x_size, wnd_y_size, (COLOR_BG_NORMAL or 0x54000000)
; clear unused areas ; clear unused areas
;mov al, 48
;push 4
;pop ebx
; get window skin height ; get window skin height
mcall 48, 4 mcall 48, 4
cmp eax, title_y_pos cmp eax, title_y_pos
@ -1532,9 +1545,7 @@ draw_window:
shl eax, 16 shl eax, 16
add ecx, eax add ecx, eax
mov ebx, 5*10000h + (wnd_x_size-9) mov ebx, 5*10000h + (wnd_x_size-9)
;push 13 mov edx, COLOR_BG_NORMAL
;pop eax
; color in edx for all rectangles (COLOR_BG_NORMAL)
; draw container rectangle/box for registers information region ; draw container rectangle/box for registers information region
mcall 13 mcall 13
mov ecx, (dump_y_pos+dump_y_size)*10000h + (disasm_y_pos-dump_y_pos-dump_y_size) mov ecx, (dump_y_pos+dump_y_size)*10000h + (disasm_y_pos-dump_y_pos-dump_y_size)
@ -1556,53 +1567,43 @@ draw_window:
mov ebx, (data_x_pos+data_x_size)*10000h + (wnd_x_size-data_x_pos-data_x_size-4) mov ebx, (data_x_pos+data_x_size)*10000h + (wnd_x_size-data_x_pos-data_x_size-4)
; draw container rectangle/box ; draw container rectangle/box
mcall mcall
mov ebx, 5*10000h + title_x_pos - 5
mov ecx, (title_y_pos)*10000h + (title_y_size)
; draw container rectangle/box for dump memory region title
mcall
; messages frame ; messages frame
;mov al, 38
mov ebx, (messages_x_pos-2)*10000h + (messages_x_pos+messages_x_size+2) mov ebx, (messages_x_pos-2)*10000h + (messages_x_pos+messages_x_size+2)
push ebx push ebx
mov ecx, (messages_y_pos-2)*10001h mov ecx, (messages_y_pos-2)*10001h
; setting up lines color
; was 'xor edx, edx' - black
mov edx, COLOR_LINE mov edx, COLOR_LINE
; draw line, color in edx
mcall 38 mcall 38
mov ecx, (messages_y_pos+messages_y_size+2)*10001h mov ecx, (messages_y_pos+messages_y_size+2)*10001h
; draw line, color in edx
mcall mcall
mov ebx, (messages_x_pos-2)*10001h mov ebx, (messages_x_pos-2)*10001h
push ebx push ebx
mov ecx, (messages_y_pos-2)*10000h + (messages_y_pos+messages_y_size+2) mov ecx, (messages_y_pos-2)*10000h + (messages_y_pos+messages_y_size+2)
; draw line, color in edx
mcall mcall
mov ebx, (messages_x_pos+messages_x_size+2)*10001h mov ebx, (messages_x_pos+messages_x_size+2)*10001h
push ebx push ebx
; draw line, color in edx
mcall mcall
; command line frame ; command line frame
mov ecx, (cmdline_y_pos-2)*10000h + (cmdline_y_pos+cmdline_y_size+2) mov ecx, (cmdline_y_pos-2)*10000h + (cmdline_y_pos+cmdline_y_size+2)
pop ebx pop ebx
; draw line, color in edx
mcall mcall
pop ebx pop ebx
; draw line, color in edx
mcall mcall
pop ebx pop ebx
mov ecx, (cmdline_y_pos+cmdline_y_size+2)*10001h mov ecx, (cmdline_y_pos+cmdline_y_size+2)*10001h
; draw line, color in edx
mcall mcall
mov ecx, (cmdline_y_pos-2)*10001h mov ecx, (cmdline_y_pos-2)*10001h
; draw line, color in edx
mcall mcall
; registers frame ; registers frame
;push 13
;pop eax
mov ebx, (registers_x_pos-2)*10000h + (registers_x_size+4) mov ebx, (registers_x_pos-2)*10000h + (registers_x_size+4)
mov ecx, (registers_y_pos-2)*10000h + (registers_y_size+4) mov ecx, (registers_y_pos-2)*10000h + (registers_y_size+4)
; draw container rectangle/box for registers information window region ; draw container rectangle/box for registers information window region
; color in edx
mcall 13 mcall 13
; messages ; messages
@ -1613,20 +1614,14 @@ draw_window:
call draw_cursor call draw_cursor
; title & registers & dump & disasm ; title & registers & dump & disasm
;mov al, 38
mov ebx, (data_x_pos-2)*10001h mov ebx, (data_x_pos-2)*10001h
mov ecx, (title_y_pos+5)*10000h + (messages_y_pos-2) mov ecx, (title_y_pos+5)*10000h + (messages_y_pos-2)
; draw line, color in edx mov edx, COLOR_LINE
mcall 38 mcall 38
mov ebx, (data_x_pos+data_x_size+2)*10001h mov ebx, (data_x_pos+data_x_size+2)*10001h
; draw line, color in edx
mcall mcall
mov ebx, (data_x_pos-2)*10000h + (data_x_pos+data_x_size+2) mov ebx, (data_x_pos-2)*10000h + (data_x_pos+data_x_size+2)
mov ecx, (dump_y_pos-3)*10001h
; draw line, color in edx
mcall
mov ecx, (disasm_y_pos-4)*10001h mov ecx, (disasm_y_pos-4)*10001h
; draw line, color in edx
mcall mcall
; redraw whole window again ; redraw whole window again
@ -1636,10 +1631,6 @@ draw_window:
call draw_disasm.redraw call draw_disasm.redraw
; end of window redraw ; end of window redraw
;push 12
;pop eax
;push 2
;pop ebx
mcall 12, 2 mcall 12, 2
ret ret

View File

@ -1,4 +1,7 @@
format binary COLOR_THEME equ BLACK_ON_WHITE
format binary as ""
include '../../macros.inc' include '../../macros.inc'
use32 use32
db 'MENUET01' db 'MENUET01'
@ -2357,7 +2360,7 @@ caption_str db 'Kolibri Debugger',0
caption_len = $ - caption_str caption_len = $ - caption_str
begin_str db 'Kolibri Debugger, version 0.33',10 begin_str db 'Kolibri Debugger, version 0.33',10
db 'Hint: type "help" for help, "quit" for quit' db 'Hint: type "help" for help, "quit" to quit'
newline db 10,0 newline db 10,0
prompt db '> ',0 prompt db '> ',0
@ -2645,10 +2648,10 @@ NoPrgLoaded_str db 'No program loaded'
NoPrgLoaded_len = $ - NoPrgLoaded_str NoPrgLoaded_len = $ - NoPrgLoaded_str
aRunning db 'Running' aRunning db 'Running'
aPaused db 'Paused' aPaused db 'Paused'
aMain db '[ CPU ]' aMain db '[ CPU ]'
aSSE db '[ SSE ]' aSSE db '[ SSE ]'
aAVX db '[ AVX ]' aAVX db '[ AVX ]'
aMSR db '[ MSR ]' aMSR db '[ MSR ]'
aPoint db 0x1C aPoint db 0x1C
aMinus db '-' aMinus db '-'
aColon db ':' aColon db ':'
@ -2708,7 +2711,7 @@ mmx_strs:
db 'MM6=' db 'MM6='
db 'MM7=' db 'MM7='
sse_strs: sse_strs:
db '-XMM0-' db '-XMM0-'
db '-XMM1-' db '-XMM1-'
db '-XMM2-' db '-XMM2-'
db '-XMM3-' db '-XMM3-'