Subversion Repositories Kolibri OS

Rev

Rev 6759 | Rev 6771 | 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
 
6651 leency 29
#define bool      int
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
 
6751 leency 69
inline fastcall dword calc(EAX) { return EAX; }
6742 leency 70
 
5477 leency 71
:struct raw_image {
72
	dword w, h, data;
73
};
74
 
3067 leency 75
//------------------------------------------------------------------------------
5582 pavelyakov 76
:dword wait_event_code;
3067 leency 77
inline fastcall dword WaitEvent()
78
{
79
	$mov eax,10
80
	$int 0x40
5576 pavelyakov 81
	wait_event_code = EAX;
5591 pavelyakov 82
	//if(wait_event_code==evMouse) MOUSE.get();
83
	//return wait_event_code;
3067 leency 84
}
85
 
86
inline fastcall dword CheckEvent()
87
{
88
	$mov eax,11
89
	$int 0x40
90
}
91
 
5576 pavelyakov 92
inline fastcall dword WaitEventTimeout(EBX)
3067 leency 93
{
94
	$mov eax,23
95
	$int 0x40
96
}
97
 
5576 pavelyakov 98
inline fastcall SetEventMask(EBX)
3067 leency 99
{
100
	$mov eax,40
101
	$int 0x40
102
}
103
 
104
 
5576 pavelyakov 105
inline fastcall pause(EBX)
3067 leency 106
{
107
	$mov eax, 5
108
	$int 0x40
109
}
110
 
111
inline fastcall word GetButtonID()
112
{
113
	$mov eax,17
114
	$int  0x40
115
	$shr eax,8
116
}
117
 
118
inline fastcall dword GetFreeRAM()
119
{
120
	$mov eax, 18
121
	$mov ebx, 16
122
	$int 0x40
123
	//return eax = размер свободной памяти в килобайтах
124
}
125
 
5576 pavelyakov 126
inline fastcall dword LoadDriver(ECX) //ECX - имя драйвера
3067 leency 127
{
128
	$mov eax, 68
129
	$mov ebx, 16
130
	$int 0x40
131
	//return 0 - неудача, иначе eax = хэндл драйвера
132
}
133
 
5576 pavelyakov 134
inline fastcall dword RuleDriver(ECX) //указатель на управляющую структуру
3067 leency 135
{
136
	$mov eax, 68
137
	$mov ebx, 17
138
	$int 0x40
139
	//return eax = определяется драйвером
140
}
141
 
142
struct proc_info
143
{
144
	#define SelfInfo -1
145
	dword	use_cpu;
146
	word	pos_in_stack,num_slot,rezerv1;
4137 leency 147
	unsigned char name[11];
3067 leency 148
	char	rezerv2;
149
	dword	adress,use_memory,ID,left,top,width,height;
150
	word	status_slot,rezerv3;
151
	dword	work_left,work_top,work_width,work_height;
152
	char	status_window;
3107 leency 153
	dword   cwidth,cheight;
154
	byte    reserved[1024-71-8];
3067 leency 155
};
156
 
5576 pavelyakov 157
inline fastcall void GetProcessInfo(EBX, ECX)
3067 leency 158
{
159
	$mov eax,9;
160
	$int  0x40
3107 leency 161
	DSDWORD[EBX+71] = DSDWORD[EBX+42] - 9; //set cwidth
162
	DSDWORD[EBX+75] = DSDWORD[EBX+46] - GetSkinHeight() - 4; //set cheight
3067 leency 163
}
164
 
165
inline fastcall int GetPointOwner( EBX, ECX) //ebx=m.x, ecx=m.y
166
{
167
	$mov eax,34
168
	$int 0x40
169
}
170
 
171
inline fastcall int GetProcessSlot( ECX)
172
{
173
	EAX = 18;
174
	EBX = 21;
175
	$int 0x40
176
}
177
 
178
inline fastcall int GetActiveProcess()
179
{
180
	EAX = 18;
181
	EBX = 7;
182
	$int 0x40
183
}
184
 
4081 leency 185
:int CheckActiveProcess(int Form_ID)
186
{
4166 leency 187
	int id9=GetProcessSlot(Form_ID);
188
	if (id9==GetActiveProcess()) return 1;
4081 leency 189
	return 0;
190
}
191
 
3114 leency 192
inline fastcall void ActivateWindow( ECX)
193
{
194
	EAX = 18;
195
	EBX = 3;
196
	$int 0x40
197
}
198
 
5421 leency 199
inline fastcall int MinimizeWindow()
200
{
201
	EAX = 18;
202
	EBX = 10;
203
	$int 0x40
204
}
205
 
5576 pavelyakov 206
inline fastcall int CreateThread(ECX,EDX)
3067 leency 207
{
208
	$mov eax,51
209
	$mov ebx,1
210
	$int 0x40
211
}
212
 
213
inline fastcall void SwitchToAnotherThread()
214
{
215
	$mov eax,68
216
	$mov ebx,1
217
	$int 0x40
218
}
219
 
3458 leency 220
inline fastcall int SendWindowMessage( ECX, EDX)
3444 leency 221
{
222
	$mov eax, 72
223
	$mov ebx, 1
224
	$int 0x40
225
}
226
 
3067 leency 227
inline fastcall int KillProcess( ECX)
228