Subversion Repositories Kolibri OS

Rev

Rev 6280 | Rev 6504 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
6021 leency 1
//CODED by Veliant, Leency, Nable, Pavelyakov. GNU GPL licence.
2
 
5598 pavelyakov 3
#ifndef INCLUDE_KOLIBRI_H
5582 pavelyakov 4
#define INCLUDE_KOLIBRI_H
5676 pavelyakov 5
#print "[include ]\n"
5576 pavelyakov 6
 
5676 pavelyakov 7
#pragma option OST
8
#pragma option ON
9
#pragma option cri-
10
#pragma option -CPA
11
#initallvar 0
12
#jumptomain FALSE
13
 
3067 leency 14
#startaddress 0
5676 pavelyakov 15
 
3067 leency 16
#code32 TRUE
5676 pavelyakov 17
 
3067 leency 18
char   os_name[8]   = {'M','E','N','U','E','T','0','1'};
19
dword  os_version   = 0x00000001;
5648 pavelyakov 20
dword  start_addr   = #______INIT______;
21
dword  final_addr   = #______STOP______+32;
3363 leency 22
dword  alloc_mem    = MEMSIZE;
23
dword  x86esp_reg   = MEMSIZE;
3067 leency 24
dword  I_Param      = #param;
25
dword  I_Path       = #program_path;
26
char param[4096];
27
char program_path[4096];
28
 
6039 leency 29
#define bool      char
5883 pavelyakov 30
 
3363 leency 31
#define NULL      0
32
#define OLD      -1
33
#define true      1
34
#define false     0
35
 
6039 leency 36
//Process Events
4536 leency 37
#define evReDraw  1
38
#define evKey     2
39
#define evButton  3
5576 pavelyakov 40
#define evDesktop 5
3067 leency 41
#define evMouse   6
5576 pavelyakov 42
#define evIPC     7
4536 leency 43
#define evNetwork 8
5576 pavelyakov 44
#define evDebug   9
3067 leency 45
 
46
//Button options
47
#define BT_DEL      0x80000000
48
#define BT_HIDE     0x40000000
49
#define BT_NOFRAME  0x20000000
50
 
5576 pavelyakov 51
//allow event mask
52
#define EVENT_MASK_REDRAW   000000001b
53
#define EVENT_MASK_KEYBOARD 000000010b
54
#define EVENT_MASK_BUTTONS  000000100b
55
#define EVENT_MASK_DESKTOP  000010000b
56
#define EVENT_MASK_MOUSE    000100000b
57
#define EVENT_MASK_IPC      001000000b
58
#define EVENT_MASK_NETWORK  010000000b
59
#define EVENT_MASK_DEBUG    100000000b
5465 leency 60
 
5576 pavelyakov 61
//ARGS FUNCTION
62
#define END_ARGS 0xFF00FF
3067 leency 63
//-------------------------------------------------------------------------
64
 
5674 pavelyakov 65
#include "../lib/system.h"
66
#include "../lib/mouse.h"
6285 leency 67
#include "../lib/keyboard.h"
5674 pavelyakov 68
 
5477 leency 69
:struct raw_image {
70
	dword w, h, data;
71
};
72
 
3067 leency 73
//------------------------------------------------------------------------------
5582 pavelyakov 74
:dword wait_event_code;
3067 leency 75
inline fastcall dword WaitEvent()
76
{
77
	$mov eax,10
78
	$int 0x40
5576 pavelyakov 79
	wait_event_code = EAX;
5591 pavelyakov 80
	//if(wait_event_code==evMouse) MOUSE.get();
81
	//return wait_event_code;
3067 leency 82
}
83
 
84
inline fastcall dword CheckEvent()
85
{
86
	$mov eax,11
87
	$int 0x40
88
}
89
 
5576 pavelyakov 90
inline fastcall dword WaitEventTimeout(EBX)
3067 leency 91
{
92
	$mov eax,23
93
	$int 0x40
94
}
95
 
5576 pavelyakov 96
inline fastcall SetEventMask(EBX)
3067 leency 97
{
98
	$mov eax,40
99
	$int 0x40
100
}
101
 
102
 
5576 pavelyakov 103
inline fastcall pause(EBX)
3067 leency 104
{
105
	$mov eax, 5
106
	$int 0x40
107
}
108
 
109
inline fastcall word GetButtonID()
110
{
111
	$mov eax,17
112
	$int  0x40
113
	$shr eax,8
114
}
115
 
116
inline fastcall dword GetFreeRAM()
117
{
118
	$mov eax, 18
119
	$mov ebx, 16
120
	$int 0x40
121
	//return eax = размер свободной памяти в килобайтах
122
}
123
 
5576 pavelyakov 124
inline fastcall dword LoadDriver(ECX) //ECX - имя драйвера
3067 leency 125
{
126
	$mov eax, 68
127
	$mov ebx, 16
128
	$int 0x40
129
	//return 0 - неудача, иначе eax = хэндл драйвера
130
}
131
 
5576 pavelyakov 132
inline fastcall dword RuleDriver(ECX) //указатель на управляющую структуру
3067 leency 133
{
134
	$mov eax, 68
135
	$mov ebx, 17
136
	$int 0x40
137
	//return eax = определяется драйвером
138
}
139
 
140
struct proc_info
141
{
142
	#define SelfInfo -1
143
	dword	use_cpu;
144
	word	pos_in_stack,num_slot,rezerv1;
4137 leency 145
	unsigned char name[11];
3067 leency 146
	char	rezerv2;
147
	dword	adress,use_memory,ID,left,top,width,height;
148
	word	status_slot,rezerv3;
149
	dword	work_left,work_top,work_width,work_height;
150
	char	status_window;
3107 leency 151
	dword   cwidth,cheight;
152
	byte    reserved[1024-71-8];
3067 leency 153
};
154
 
5576 pavelyakov 155
inline fastcall void GetProcessInfo(EBX, ECX)
3067 leency 156
{
157
	$mov eax,9;
158
	$int  0x40
3107 leency 159
	DSDWORD[EBX+71] = DSDWORD[EBX+42] - 9; //set cwidth
160
	DSDWORD[EBX+75] = DSDWORD[EBX+46] - GetSkinHeight() - 4; //set cheight
3067 leency 161
}
162
 
163
inline fastcall int GetPointOwner( EBX, ECX) //ebx=m.x, ecx=m.y
164
{
165
	$mov eax,34
166
	$int 0x40
167
}
168
 
169
inline fastcall int GetProcessSlot( ECX)
170
{
171
	EAX = 18;
172
	EBX = 21;
173
	$int 0x40
174
}
175
 
176
inline fastcall int GetActiveProcess()
177
{
178
	EAX = 18;
179
	EBX = 7;
180
	$int 0x40
181
}
182
 
4081 leency 183
:int CheckActiveProcess(int Form_ID)
184
{
4166 leency 185
	int id9=GetProcessSlot(Form_ID);
186
	if (id9==GetActiveProcess()) return 1;
4081 leency 187
	return 0;
188
}
189
 
3114 leency 190
inline fastcall void ActivateWindow( ECX)
191
{
192
	EAX = 18;
193
	EBX = 3;
194
	$int 0x40
195
}
196
 
5421 leency 197
inline fastcall int MinimizeWindow()
198
{
199
	EAX = 18;
200
	EBX = 10;
201
	$int 0x40
202
}
203
 
5576 pavelyakov 204
inline fastcall int CreateThread(ECX,EDX)
3067 leency 205
{
206
	$mov eax,51
207
	$mov ebx,1
208
	$int 0x40
209
}
210
 
211
inline fastcall void SwitchToAnotherThread()
212
{
213
	$mov eax,68
214
	$mov ebx,1
215
	$int 0x40
216
}
217
 
3458 leency 218
inline fastcall int SendWindowMessage( ECX, EDX)
3444 leency 219
{
220
	$mov eax, 72
221
	$mov ebx, 1
222
	$int 0x40
223
}
224
 
3067 leency 225
inline fastcall int KillProcess( ECX)
226
{
227
	$mov eax,18;
228
	$mov ebx,18;
229
	$int 0x40
230