Subversion Repositories Kolibri OS

Compare Revisions

No changes between revisions

Regard whitespace Rev 485 → Rev 132

/programs/network/rccs/trunk/rccs.asm
25,7 → 25,7
dd 0x0 , 0x0 ; I_Param , I_Icon
include 'lang.inc'
include '..\..\..\macros.inc'
include 'macros.inc'
remote_ip db 192,168,0,1
36,11 → 36,10
mov ecx, 0x6100 ; local port
mov edx, 0x6000 ; remote port
mov esi, dword [remote_ip] ; remote IP
mcall
int 0x40
mov [socket],eax
mov [0],eax ; save for remote code
 
red:
call draw_window ; at first, draw the window
still:
47,7 → 46,7
mov eax,23 ; wait here for event
mov ebx,1
mcall
int 0x40
cmp eax,1 ; redraw request ?
jz red
59,7 → 58,7
mov eax,53 ; data from cluster terminal ?
mov ebx,2
mov ecx,[socket]
mcall
int 0x40
cmp eax,0
jne data_arrived
66,9 → 65,13
jmp still
red:
call draw_window
jmp still
key:
mov eax,2
mcall
int 0x40
jmp still
button:
76,9 → 79,9
mov eax,53
mov ebx,1
mov ecx,[socket]
mcall
or eax,-1
mcall
int 0x40
mov eax,-1
int 0x40
data_arrived:
85,7 → 88,7
mov eax,5 ; wait a second for everything to arrive
mov ebx,10
mcall
int 0x40
mov edi,I_END
94,7 → 97,7
mov eax,53
mov ebx,3
mov ecx,[socket]
mcall
int 0x40
mov [edi],bl
inc edi
102,7 → 105,7
mov eax,53
mov ebx,2
mov ecx,[socket]
mcall
int 0x40
cmp eax,0
jne get_data
115,7 → 118,7
mov ecx,0x000000
mov edx,inp_con
mov esi,inp_con.len
mcall
int 0x40
add [y],10
 
jmp still
129,13 → 132,13
mov ecx,0x000000
mov edx,inp_shut
mov esi,inp_shut.len
mcall
int 0x40
add [y],10
 
mov eax,18
mov ebx,9
mov ecx,2
mcall
int 0x40
 
jmp still
 
148,13 → 151,13
mov ecx,0x000000
mov edx,inp_reb
mov esi,inp_reb.len
mcall
int 0x40
add [y],10
 
mov eax,18
mov ebx,9
mov ecx,3
mcall
int 0x40
jmp still
 
no_reb:
166,13 → 169,13
mov ecx,0x000000
mov edx,inp_savefi
mov esi,inp_savefi.len
mcall
int 0x40
add [y],10
 
mov eax,18
mov ebx,9
mov ecx,1
mcall
int 0x40
jmp still
 
no_savefi:
184,13 → 187,13
mov ecx,0x000000
mov edx,inp_savehi
mov esi,inp_savehi.len
mcall
int 0x40
add [y],10
 
mov eax,18
mov ebx,6
mov ecx,2
mcall
int 0x40
 
jmp still
 
203,13 → 206,13
mov ecx,0x000000
mov edx,inp_hotreb
mov esi,inp_hotreb.len
mcall
int 0x40
add [y],10
 
mov eax,18
mov ebx,9
mov ecx,4
mcall
int 0x40
jmp still
 
no_hotreb:
221,7 → 224,7
mov ecx,0x000000
mov edx,inp_exit
mov esi,inp_exit.len
mcall
int 0x40
add [y],10
call button
234,7 → 237,7
mov ecx,0x000000
mov edx,inp_com
mov esi,inp_com.len
mcall
int 0x40
add [y],10
 
jmp still
248,26 → 251,41
mov eax,12 ; function 12:tell os about windowdraw
mov ebx,1 ; 1, start of draw
mcall
int 0x40
; DRAW WINDOW
mov eax,0 ; function 0 : define and draw window
mov ebx,100*65536+300 ; [x start] *65536 + [x size]
mov ecx,100*65536+330 ; [y start] *65536 + [y size]
mov edx,0x13ffffff ; color of work area RRGGBB
mov edi,title ; WINDOW LABEL
mcall
mov edx,0x03ffffff ; color of work area RRGGBB
mov esi,0x80aabbcc ; color of grab bar RRGGBB,8->color gl
mov edi,0x00aabbcc ; color of frames RRGGBB
int 0x40
mov eax,8
mov ebx,(286-19)*65536+12
mov ecx,4*65536+12
mov edx,1
mov esi,0xaabbcc
; 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,0x00ffffff ; color of text RRGGBB
mov edx,labeltext ; pointer to text beginning
mov esi,lte-labeltext ; text length
int 0x40
; Re-draw the screen text
cld
mov eax,4
mov ebx,10*65536+30 ; draw info text with function 4
mov ecx,0x000000
mov edx,text
mov esi,40
newline:
mcall
mov eax,4
int 0x40
add ebx,16
add edx,40
cmp [edx],byte 'x'
276,7 → 294,7
mov eax,12 ; function 12:tell os about windowdraw
mov ebx,2 ; 2, end of draw
mcall
int 0x40
ret
297,7 → 315,8
db 'x' ; <- END MARKER, DONT DELETE
end if
title db 'Remote Control Center(Server)',0
labeltext: db 'Remote Control Center(Server)'
lte:
socket dd 0x0
y dd 0x10
/programs/network/rccs/trunk/build_en.bat
1,5 → 1,4
@erase lang.inc
@echo lang fix en >lang.inc
@fasm rccs.asm rccs
@erase lang.inc
@pause
/programs/network/rccs/trunk/build_ru.bat
1,5 → 1,4
@erase lang.inc
@echo lang fix ru >lang.inc
@fasm rccs.asm rccs
@erase lang.inc
@pause
/programs/network/rccs/trunk/macros.inc
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
Property changes:
Added: svn:eol-style
+native
\ No newline at end of property