forked from KolibriOS/kolibrios
Changed structure of svn repository
git-svn-id: svn://kolibrios.org@109 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
@@ -0,0 +1,4 @@
|
||||
@erase lang.inc
|
||||
@echo lang fix en >lang.inc
|
||||
@fasm scancode.asm scancode
|
||||
@pause
|
||||
@@ -0,0 +1,4 @@
|
||||
@erase lang.inc
|
||||
@echo lang fix ru >lang.inc
|
||||
@fasm scancode.asm scancode
|
||||
@pause
|
||||
@@ -0,0 +1,266 @@
|
||||
; new application structure
|
||||
macro meos_app_start
|
||||
{
|
||||
use32
|
||||
org 0x0
|
||||
|
||||
db 'MENUET01'
|
||||
dd 0x01
|
||||
dd __start
|
||||
dd __end
|
||||
dd __memory
|
||||
dd __stack
|
||||
|
||||
if used __params & ~defined __params
|
||||
dd __params
|
||||
else
|
||||
dd 0x0
|
||||
end if
|
||||
|
||||
dd 0x0
|
||||
}
|
||||
MEOS_APP_START fix meos_app_start
|
||||
|
||||
macro code
|
||||
{
|
||||
__start:
|
||||
}
|
||||
CODE fix code
|
||||
|
||||
macro data
|
||||
{
|
||||
__data:
|
||||
}
|
||||
DATA fix data
|
||||
|
||||
macro udata
|
||||
{
|
||||
if used __params & ~defined __params
|
||||
__params:
|
||||
db 0
|
||||
__end:
|
||||
rb 255
|
||||
else
|
||||
__end:
|
||||
end if
|
||||
__udata:
|
||||
}
|
||||
UDATA fix udata
|
||||
|
||||
macro meos_app_end
|
||||
{
|
||||
align 32
|
||||
rb 2048
|
||||
__stack:
|
||||
__memory:
|
||||
}
|
||||
MEOS_APP_END fix meos_app_end
|
||||
|
||||
|
||||
; macro for defining multiline text data
|
||||
struc mstr [sstring]
|
||||
{
|
||||
forward
|
||||
local ssize
|
||||
virtual at 0
|
||||
db sstring
|
||||
ssize = $
|
||||
end virtual
|
||||
dd ssize
|
||||
db sstring
|
||||
common
|
||||
dd -1
|
||||
}
|
||||
|
||||
|
||||
; strings
|
||||
macro sz name,[data] { ; from MFAR [mike.dld]
|
||||
common
|
||||
if used name
|
||||
label name
|
||||
end if
|
||||
forward
|
||||
if used name
|
||||
db data
|
||||
end if
|
||||
common
|
||||
if used name
|
||||
.size = $-name
|
||||
end if
|
||||
}
|
||||
|
||||
macro lsz name,[lng,data] { ; from MFAR [mike.dld]
|
||||
common
|
||||
if used name
|
||||
label name
|
||||
end if
|
||||
forward
|
||||
if (used name)&(lang eq lng)
|
||||
db data
|
||||
end if
|
||||
common
|
||||
if used name
|
||||
.size = $-name
|
||||
end if
|
||||
}
|
||||
|
||||
|
||||
|
||||
; easy system call macro
|
||||
macro mpack dest, hsrc, lsrc
|
||||
{
|
||||
if (hsrc eqtype 0) & (lsrc eqtype 0)
|
||||
mov dest, (hsrc) shl 16 + lsrc
|
||||
else
|
||||
if (hsrc eqtype 0) & (~lsrc eqtype 0)
|
||||
mov dest, (hsrc) shl 16
|
||||
add dest, lsrc
|
||||
else
|
||||
mov dest, hsrc
|
||||
shl dest, 16
|
||||
add dest, lsrc
|
||||
end if
|
||||
end if
|
||||
}
|
||||
|
||||
macro __mov reg,a,b { ; mike.dld
|
||||
if (~a eq)&(~b eq)
|
||||
mpack reg,a,b
|
||||
else if (~a eq)&(b eq)
|
||||
mov reg,a
|
||||
end if
|
||||
}
|
||||
|
||||
macro mcall a,b,c,d,e,f { ; mike.dld
|
||||
__mov eax,a
|
||||
__mov ebx,b
|
||||
__mov ecx,c
|
||||
__mov edx,d
|
||||
__mov esi,e
|
||||
__mov edi,f
|
||||
int 0x40
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
; optimize the code for size
|
||||
__regs fix <eax,ebx,ecx,edx,esi,edi,ebp,esp>
|
||||
|
||||
macro add arg1,arg2
|
||||
{
|
||||
if (arg2 eqtype 0)
|
||||
if (arg2) = 1
|
||||
inc arg1
|
||||
else
|
||||
add arg1,arg2
|
||||
end if
|
||||
else
|
||||
add arg1,arg2
|
||||
end if
|
||||
}
|
||||
|
||||
macro sub arg1,arg2
|
||||
{
|
||||
if (arg2 eqtype 0)
|
||||
if (arg2) = 1
|
||||
dec arg1
|
||||
else
|
||||
sub arg1,arg2
|
||||
end if
|
||||
else
|
||||
sub arg1,arg2
|
||||
end if
|
||||
}
|
||||
|
||||
macro mov arg1,arg2
|
||||
{
|
||||
if (arg1 in __regs) & (arg2 eqtype 0)
|
||||
if (arg2) = 0
|
||||
xor arg1,arg1
|
||||
else if (arg2) = 1
|
||||
xor arg1,arg1
|
||||
inc arg1
|
||||
else if (arg2) = -1
|
||||
or arg1,-1
|
||||
else if (arg2) > -128 & (arg2) < 128
|
||||
push arg2
|
||||
pop arg1
|
||||
else
|
||||
mov arg1,arg2
|
||||
end if
|
||||
else
|
||||
mov arg1,arg2
|
||||
end if
|
||||
}
|
||||
|
||||
|
||||
macro struct name
|
||||
{
|
||||
virtual at 0
|
||||
name name
|
||||
sizeof.#name = $ - name
|
||||
end virtual
|
||||
}
|
||||
|
||||
; structures used in MeOS
|
||||
struc process_information
|
||||
{
|
||||
.cpu_usage dd ? ; +0
|
||||
.window_stack_position dw ? ; +4
|
||||
.window_stack_value dw ? ; +6
|
||||
.not_used1 dw ? ; +8
|
||||
.process_name rb 12 ; +10
|
||||
.memory_start dd ? ; +22
|
||||
.used_memory dd ? ; +26
|
||||
.PID dd ? ; +30
|
||||
.x_start dd ? ; +34
|
||||
.y_start dd ? ; +38
|
||||
.x_size dd ? ; +42
|
||||
.y_size dd ? ; +46
|
||||
.slot_state dw ? ; +50
|
||||
rb (1024-52)
|
||||
}
|
||||
struct process_information
|
||||
|
||||
struc system_colors
|
||||
{
|
||||
.frame dd ?
|
||||
.grab dd ?
|
||||
.grab_button dd ?
|
||||
.grab_button_text dd ?
|
||||
.grab_text dd ?
|
||||
.work dd ?
|
||||
.work_button dd ?
|
||||
.work_button_text dd ?
|
||||
.work_text dd ?
|
||||
.work_graph dd ?
|
||||
}
|
||||
struct system_colors
|
||||
|
||||
|
||||
; constants
|
||||
|
||||
; events
|
||||
EV_IDLE = 0
|
||||
EV_TIMER = 0
|
||||
EV_REDRAW = 1
|
||||
EV_KEY = 2
|
||||
EV_BUTTON = 3
|
||||
EV_EXIT = 4
|
||||
EV_BACKGROUND = 5
|
||||
EV_MOUSE = 6
|
||||
EV_IPC = 7
|
||||
EV_STACK = 8
|
||||
|
||||
; event mask bits for function 40
|
||||
EVM_REDRAW = 1b
|
||||
EVM_KEY = 10b
|
||||
EVM_BUTTON = 100b
|
||||
EVM_EXIT = 1000b
|
||||
EVM_BACKGROUND = 10000b
|
||||
EVM_MOUSE = 100000b
|
||||
EVM_IPC = 1000000b
|
||||
EVM_STACK = 10000000b
|
||||
@@ -0,0 +1,336 @@
|
||||
;
|
||||
; KEYBOARD SCANCODE EXAMPLE
|
||||
;
|
||||
; Compile with FASM for Menuet
|
||||
;
|
||||
|
||||
include "lang.inc"
|
||||
include "macros.inc"
|
||||
|
||||
use32
|
||||
org 0x0
|
||||
|
||||
db 'MENUET01' ; 8 byte id
|
||||
dd 0x01 ; header version
|
||||
dd START ; start of code
|
||||
dd I_END ; size of image
|
||||
dd 0x1000 ; memory for app
|
||||
dd 0x1000 ; esp
|
||||
dd 0x0 , 0x0 ; I_Param , I_Icon
|
||||
|
||||
START: ; start of execution
|
||||
|
||||
mov eax,66 ; keyboard mode definitions
|
||||
mov ebx,1 ; set
|
||||
mov ecx,1 ; return scancodes
|
||||
int 0x40
|
||||
|
||||
mov eax,26 ; get setup for keyboard
|
||||
mov ebx,2
|
||||
mov ecx,1 ; base keymap
|
||||
mov edx,keymap
|
||||
int 0x40
|
||||
|
||||
call draw_window
|
||||
|
||||
still:
|
||||
|
||||
mov eax,10 ; wait here for event
|
||||
int 0x40
|
||||
|
||||
cmp eax,1 ; redraw request ?
|
||||
je red
|
||||
cmp eax,2 ; key in buffer ?
|
||||
je key
|
||||
cmp eax,3 ; button in buffer ?
|
||||
je button
|
||||
|
||||
jmp still
|
||||
|
||||
|
||||
red: ; redraw
|
||||
call draw_window
|
||||
jmp still
|
||||
|
||||
|
||||
key: ; key
|
||||
mov eax,2 ; just read it and ignore
|
||||
int 0x40
|
||||
|
||||
mov esi,scan_codes+1
|
||||
mov edi,scan_codes+0
|
||||
mov ecx,15
|
||||
cld
|
||||
rep movsb
|
||||
|
||||
mov esi,key_codes+12
|
||||
mov edi,key_codes+0
|
||||
mov ecx,15*12
|
||||
cld
|
||||
rep movsb
|
||||
|
||||
shr eax,8 ; scancode
|
||||
and eax,0xff
|
||||
mov [scan_codes+15],al
|
||||
|
||||
mov [key_codes+15*12+8],dword 'Down'
|
||||
cmp eax,128
|
||||
jb no_up
|
||||
mov [key_codes+15*12+8],dword 'Up '
|
||||
no_up:
|
||||
|
||||
mov ebx,eax
|
||||
and ebx,0x7f
|
||||
|
||||
movzx edx,byte [keymap+ebx] ; key from keymap
|
||||
mov [key_codes+15*12+0],edx
|
||||
mov [key_codes+15*12+4],dword ' '
|
||||
|
||||
movzx edx,byte [ext]
|
||||
shl edx,8
|
||||
add ebx,edx
|
||||
|
||||
mov esi,ext0-10
|
||||
new_ext0:
|
||||
add esi,10
|
||||
cmp esi,ext0end
|
||||
jg exit_ext0
|
||||
movzx edx,word [esi]
|
||||
cmp edx,ebx
|
||||
jne new_ext0
|
||||
mov edx,[esi+2]
|
||||
mov [key_codes+15*12+0],edx
|
||||
mov edx,[esi+6]
|
||||
mov [key_codes+15*12+4],edx
|
||||
exit_ext0:
|
||||
no_ext_off:
|
||||
|
||||
cmp [ext2],0
|
||||
je noext2dec
|
||||
dec [ext2]
|
||||
jne noext2dec
|
||||
mov [key_codes+15*12+0],dword '----'
|
||||
mov [key_codes+15*12+4],dword '----'
|
||||
noext2dec:
|
||||
|
||||
mov [ext],0
|
||||
|
||||
cmp eax,224
|
||||
jne no_ext
|
||||
mov [key_codes+15*12+0],dword ' '
|
||||
mov [key_codes+15*12+4],dword ' '
|
||||
mov [key_codes+15*12+8],dword 'Ext '
|
||||
mov [ext],1
|
||||
no_ext:
|
||||
|
||||
cmp eax,225
|
||||
jne no_ext2
|
||||
mov [key_codes+15*12+0],dword ' '
|
||||
mov [key_codes+15*12+4],dword ' '
|
||||
mov [key_codes+15*12+8],dword 'Ext2'
|
||||
mov [ext],2
|
||||
mov [ext2],2
|
||||
no_ext2:
|
||||
|
||||
|
||||
call draw_codes
|
||||
jmp still
|
||||
|
||||
|
||||
|
||||
button: ; button
|
||||
or eax, -1 ; close this program
|
||||
int 0x40
|
||||
|
||||
|
||||
|
||||
|
||||
; *********************************************
|
||||
; ******* WINDOW DEFINITIONS AND DRAW ********
|
||||
; *********************************************
|
||||
|
||||
|
||||
draw_window:
|
||||
|
||||
mov eax, 48 ; GET SYSTEM COLORS
|
||||
mov ebx, 3
|
||||
mov ecx, sc
|
||||
mov edx, sizeof.system_colors
|
||||
int 0x40
|
||||
|
||||
mov eax,12 ; function 12:tell os about windowdraw
|
||||
mov ebx,1 ; 1, start of draw
|
||||
int 0x40
|
||||
|
||||
; DRAW WINDOW
|
||||
mov eax, 0 ; function 0 : define and draw window
|
||||
mov ebx, 100*65536+200 ; [x start] *65536 + [x size]
|
||||
mov ecx, 100*65536+275 ; [y start] *65536 + [y size]
|
||||
mov edx, [sc.work] ; color of work area RRGGBB,8->color gl
|
||||
or edx, 0x03000000
|
||||
mov esi, [sc.grab] ; color of grab bar RRGGBB,8->color gl
|
||||
or esi, 0x80000000
|
||||
mov edi, [sc.frame] ; color of frames RRGGBB
|
||||
int 0x40
|
||||
|
||||
; WINDOW LABEL
|
||||
mov eax, 4 ; function 4 : write text to window
|
||||
mov ebx, 8*65536+8 ; [x start] *65536 + [y start]
|
||||
mov ecx, [sc.grab_text] ; font 1 & color ( 0xF0RRGGBB )
|
||||
or ecx, 0x10000000
|
||||
mov edx, header ; pointer to text beginning
|
||||
mov esi, header.len ; text length
|
||||
int 0x40
|
||||
|
||||
mov eax, 4
|
||||
mov ebx, 20*65536+35
|
||||
mov ecx, 0
|
||||
mov edx, text
|
||||
mov esi, text.len
|
||||
int 0x40
|
||||
|
||||
call draw_codes
|
||||
|
||||
mov eax,12 ; function 12:tell os about windowdraw
|
||||
mov ebx,2 ; 2, end of draw
|
||||
int 0x40
|
||||
|
||||
ret
|
||||
|
||||
|
||||
draw_codes:
|
||||
|
||||
mov eax,47
|
||||
mov ebx,6*65536
|
||||
mov edx,20*65536+60
|
||||
mov edi,0
|
||||
mov esi,0
|
||||
newscan:
|
||||
pusha
|
||||
mov cx,dx
|
||||
shl ecx,16
|
||||
add ecx,10
|
||||
mov eax,13 ; filled rectangle
|
||||
mov ebx,20*65536+160
|
||||
mov edx,[sc.work]
|
||||
int 0x40
|
||||
popa
|
||||
pusha
|
||||
mov ebx,edx
|
||||
add ebx,70*65536
|
||||
mov eax,4 ; text
|
||||
mov ecx,[sc.work_text]
|
||||
mov edx,key_codes
|
||||
imul edi,12
|
||||
add edx,edi
|
||||
mov esi,12
|
||||
int 0x40
|
||||
popa
|
||||
movzx ecx,byte [scan_codes+edi]
|
||||
int 0x40 ; number
|
||||
inc ecx
|
||||
add edx,12
|
||||
inc edi
|
||||
cmp edi,16
|
||||
jne newscan
|
||||
|
||||
ret
|
||||
|
||||
|
||||
; DATA AREA
|
||||
|
||||
ext0:
|
||||
|
||||
db 1,0,'Esc '
|
||||
db 28,0,'Enter '
|
||||
db 29,0,'L-Ctrl '
|
||||
db 41,0,'1/2 '
|
||||
db 42,0,'L-Shift '
|
||||
db 54,0,'R-Shift '
|
||||
db 55,0,'Num * '
|
||||
db 56,0,'Alt '
|
||||
db 58,0,'CapsLck '
|
||||
db 59,0,'F1 '
|
||||
db 60,0,'F2 '
|
||||
db 61,0,'F3 '
|
||||
db 62,0,'F4 '
|
||||
db 63,0,'F5 '
|
||||
db 64,0,'F6 '
|
||||
db 65,0,'F7 '
|
||||
db 66,0,'F8 '
|
||||
db 67,0,'F9 '
|
||||
db 68,0,'F10 '
|
||||
db 69,0,'NumLock '
|
||||
db 70,0,'SclLock '
|
||||
db 71,0,'Num 7 '
|
||||
db 72,0,'Num 8 '
|
||||
db 73,0,'Num 9 '
|
||||
db 74,0,'Num - '
|
||||
db 75,0,'Num 4 '
|
||||
db 76,0,'Num 5 '
|
||||
db 77,0,'Num 6 '
|
||||
db 78,0,'Num + '
|
||||
db 79,0,'Num 1 '
|
||||
db 80,0,'Num 2 '
|
||||
db 81,0,'Num 3 '
|
||||
db 82,0,'Num 0 '
|
||||
db 83,0,'Num , '
|
||||
db 87,0,'F11 '
|
||||
db 88,0,'F12 '
|
||||
|
||||
db 28,1,'Num Ent '
|
||||
db 29,1,'R-Ctrl '
|
||||
db 53,1,'Num / '
|
||||
db 55,1,'PrScr '
|
||||
db 56,1,'Alt Gr '
|
||||
db 71,1,'Home '
|
||||
db 72,1,'Up-A '
|
||||
db 73,1,'PgUp '
|
||||
db 75,1,'Left-A '
|
||||
db 77,1,'Right-A '
|
||||
db 79,1,'End '
|
||||
db 80,1,'Down-A '
|
||||
db 81,1,'PgDown '
|
||||
db 82,1,'Insert '
|
||||
db 83,1,'Delete '
|
||||
db 91,1,'Menu-1 '
|
||||
db 92,1,'Menu-2 '
|
||||
db 93,1,'Menu-3 '
|
||||
|
||||
db 29,2,'Break '
|
||||
|
||||
ext0end:
|
||||
|
||||
|
||||
if lang eq ru
|
||||
text:
|
||||
db '‘—ˆ’›‚€ž „€��›… ‘ Š‹€‚ˆ€’“�›'
|
||||
.len = $ - text
|
||||
|
||||
header:
|
||||
db '‘Š€�ŠŽ„› Š‹€‚ˆ€’“�›'
|
||||
.len = $ - header
|
||||
else
|
||||
text:
|
||||
db 'READING RAW SCANCODE DATA'
|
||||
.len = $ - text
|
||||
|
||||
header:
|
||||
db 'KEYBOARD SCANCODES'
|
||||
.len = $ - header
|
||||
end if
|
||||
|
||||
ext db 0x0
|
||||
ext2 db 0x0
|
||||
|
||||
pos dd 0x0
|
||||
|
||||
I_END:
|
||||
|
||||
sc system_colors
|
||||
|
||||
scan_codes: times 16 db ?
|
||||
|
||||
key_codes: times 16 dd ?,?,?
|
||||
|
||||
keymap:
|
||||
Reference in New Issue
Block a user