Subversion Repositories Kolibri OS

Rev

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

Rev Author Line No. Line
5598 pavelyakov 1
#ifndef INCLUDE_FILESYSTEM_H
2
#define INCLUDE_FILESYSTEM_H
7219 leency 3
#print "[include ]\n"
5598 pavelyakov 4
 
5640 pavelyakov 5
#ifndef INCLUDE_DATE_H
6
#include "../lib/date.h"
5598 pavelyakov 7
#endif
8
 
7369 leency 9
//===================================================//
10
//                                                   //
11
//              Basic System Functions               //
12
//                                                   //
13
//===================================================//
14
 
5487 leency 15
:struct f70{
3067 leency 16
	dword	func;
17
	dword	param1;
18
	dword	param2;
19
	dword	param3;
20
	dword	param4;
21
	char	rezerv;
22
	dword	name;
23
};
24
 
5487 leency 25
:struct BDVK {
26
	dword	readonly:1, hidden:1, system:1, volume_label:1, isfolder:1, notarchived:1, :0;
3067 leency 27
	byte	type_name;
4898 leency 28
	byte	rez1, rez2, selected;
5487 leency 29
	dword   timecreate;
30
	date 	datecreate;
3067 leency 31
	dword	timelastaccess;
5487 leency 32
	date	datelastaccess;
3067 leency 33
	dword	timelastedit;
5487 leency 34
	date	datelastedit;
3067 leency 35
	dword	sizelo;
36
	dword	sizehi;
37
	char	name[518];
38
};
39
 
40
 
5487 leency 41
 
5472 leency 42
:f70 getinfo_file_70;
3440 leency 43
:dword GetFileInfo(dword file_path, bdvk_struct)
44
{
45
    getinfo_file_70.func = 5;
46
    getinfo_file_70.param1 =
47
    getinfo_file_70.param2 =
48
    getinfo_file_70.param3 = 0;
49
    getinfo_file_70.param4 = bdvk_struct;
50
    getinfo_file_70.rezerv = 0;
51
    getinfo_file_70.name = file_path;
52
    $mov eax,70
53
    $mov ebx,#getinfo_file_70.func
3444 leency 54
    $int 0x40
3440 leency 55
}
56
 
5554 punk_joker 57
:f70 setinfo_file_70;
58
:dword SetFileInfo(dword file_path, bdvk_struct)
59
{
60
    setinfo_file_70.func = 6;
61
    setinfo_file_70.param1 =
62
    setinfo_file_70.param2 =
63
    setinfo_file_70.param3 = 0;
64
    setinfo_file_70.param4 = bdvk_struct;
65
    setinfo_file_70.rezerv = 0;
66
    setinfo_file_70.name = file_path;
67
    $mov eax,70
68
    $mov ebx,#setinfo_file_70.func
69
    $int 0x40
70
}
71
 
5472 leency 72
:f70 run_file_70;
73
:signed int RunProgram(dword run_path, run_param)
3067 leency 74
{
75
    run_file_70.func = 7;
76
    run_file_70.param1 =
77
    run_file_70.param3 =
78
    run_file_70.param4 =
79
    run_file_70.rezerv = 0;
80
    run_file_70.param2 = run_param;
81
    run_file_70.name = run_path;
82
    $mov eax,70
83
    $mov ebx,#run_file_70.func
84
    $int 0x40
85
}
86
 
5472 leency 87
:f70 create_dir_70;
3067 leency 88
:int CreateDir(dword new_folder_path)
89
{
90
	create_dir_70.func = 9;
91
	create_dir_70.param1 =
92
	create_dir_70.param2 =
93
	create_dir_70.param3 =
94
	create_dir_70.param4 =
95
	create_dir_70.rezerv = 0;
96
	create_dir_70.name = new_folder_path;
97
	$mov eax,70
98
	$mov ebx,#create_dir_70.func
99
	$int 0x40
100
}
101
 
5472 leency 102
:f70 del_file_70;
3067 leency 103
:int DeleteFile(dword del_file_path)
104
{
105
	del_file_70.func = 8;
106
	del_file_70.param1 =
107
	del_file_70.param2 =
108
	del_file_70.param3 =
109
	del_file_70.param4 =
110
	del_file_70.rezerv = 0;
111
	del_file_70.name = del_file_path;
112
	$mov eax,70
113
	$mov ebx,#del_file_70.func
114
	$int 0x40
115
}
116
 
5472 leency 117
:f70 read_file_70;
7210 leency 118
:int ReadFile(dword offset, data_size, buffer, file_path)
3067 leency 119
{
120
	read_file_70.func = 0;
7210 leency 121
	read_file_70.param1 = offset;
3067 leency 122
	read_file_70.param2 = 0;
7210 leency 123
	read_file_70.param3 = data_size;
124
	read_file_70.param4 = buffer;
3067 leency 125
	read_file_70.rezerv = 0;
7210 leency 126
	read_file_70.name = file_path;
3067 leency 127
	$mov eax,70
128
	$mov ebx,#read_file_70.func
129
	$int 0x40
130
}
131
 
5472 leency 132
:f70 write_file_70;
7227 leency 133
:int CreateFile(dword data_size, buffer, file_path)
3067 leency 134
{
135
	write_file_70.func = 2;
136
	write_file_70.param1 = 0;
137
	write_file_70.param2 = 0;
7210 leency 138
	write_file_70.param3 = data_size;
139
	write_file_70.param4 = buffer;
3067 leency 140
	write_file_70.rezerv = 0;
7210 leency 141
	write_file_70.name = file_path;
3067 leency 142
	$mov eax,70
143
	$mov ebx,#write_file_70.func
144
	$int 0x40
5542 leency 145
}
3067 leency 146
 
5640 pavelyakov 147
  ////////////////////////////////////////
148
 //     WriteInFileThatAlredyExists    //
149
////////////////////////////////////////
5542 leency 150
:f70 write_file_offset_70;
7227 leency 151
:int WriteFile(dword offset, data_size, buffer, file_path)
5542 leency 152
{
153
	write_file_offset_70.func = 3;
154
	write_file_offset_70.param1 = offset;
155
	write_file_offset_70.param2 = 0;
7210 leency 156
	write_file_offset_70.param3 = data_size;
157
	write_file_offset_70.param4 = buffer;
5542 leency 158
	write_file_offset_70.rezerv = 0;
7210 leency 159
	write_file_offset_70.name = file_path;
5542 leency 160
	$mov eax,70
161
	$mov ebx,#write_file_offset_70.func
162
	$int 0x40
7210 leency 163
}
5542 leency 164
 
5472 leency 165
:f70 read_dir_70;
3067 leency 166
:int ReadDir(dword file_count, read_buffer, dir_path)
3363 leency 167
{
3067 leency 168
	read_dir_70.func = 1;
169
	read_dir_70.param1 =
170
	read_dir_70.param2 =
171
	read_dir_70.rezerv = 0;
172
	read_dir_70.param3 = file_count;
173
	read_dir_70.param4 = read_buffer;
174
	read_dir_70.name = dir_path;
175
	$mov eax,70
176
	$mov ebx,#read_dir_70.func
177
	$int 0x40
178
}
179
 
7369 leency 180
//===================================================//
181
//                                                   //
182
//                        Misc                       //
183
//                                                   //
184
//===================================================//
185
 
7202 leency 186
:bool dir_exists(dword fpath)
3440 leency 187
{
7219 leency 188
	char buf[32];
189
	if (!ReadDir(0, #buf, fpath)) return true;
190
	return false;
191
}
192
 
193
/*
194
// This implementation of dir_exists() is faster than
195
// previous but here virtual folders like
196
// '/' and '/tmp' are not recognised as FOLDERS
197
// by GetFileInfo() => BDVK.isfolder attribute :(
198
 
199
:bool dir_exists(dword fpath)
200
{
3440 leency 201
	BDVK fpath_atr;
6930 leency 202
	if (GetFileInfo(fpath, #fpath_atr) != 0) return false;
5487 leency 203
	return fpath_atr.isfolder;
3440 leency 204
}
7219 leency 205
*/
206
 
7202 leency 207
:bool file_exists(dword fpath)
6251 leency 208
{
209
	BDVK ReadFile_atr;
210
	if (! GetFileInfo(fpath, #ReadFile_atr)) return true;
211
	return false;
212
}
3877 leency 213
 
3444 leency 214
enum
3363 leency 215
{
3444 leency 216
	DIRS_ALL,
217
	DIRS_NOROOT,
218
	DIRS_ONLYREAL
219
};
220
:int GetDir(dword dir_buf, file_count, path, doptions)
221
{
3363 leency 222
	dword buf, fcount, error;
223
	buf = malloc(32);
224
	error = ReadDir(0, buf, path);
225
	if (!error)
226
	{
227
		fcount = ESDWORD[buf+8];
228
		buf = realloc(buf, fcount+1*304+32);
229
		ReadDir(fcount, buf, path);
3440 leency 230
		//fcount=EBX;
3444 leency 231
 
232
		if (doptions == DIRS_ONLYREAL)
233
		{
234
			if (!strcmp(".",buf+72)) {fcount--; memmov(buf,buf+304,fcount*304);}
235
			if (!strcmp("..",buf+72)) {fcount--; memmov(buf,buf+304,fcount*304);}
236
		}
237
		if (doptions == DIRS_NOROOT)
238
		{
239
			if (!strcmp(".",buf+72)) {fcount--; memmov(buf,buf+304,fcount*304);}
240
		}
241
 
3363 leency 242
		ESDWORD[dir_buf] = buf;
243
		ESDWORD[file_count] = fcount;
244
	}
3440 leency 245
	else
3067 leency 246
	{
7362 leency 247
		ESDWORD[dir_buf] = free(buf);
3440 leency 248
		ESDWORD[file_count] = 0;
3067 leency 249
	}
3440 leency 250
	return error;
3067 leency 251
}
252
 
3432 leency 253
:dword abspath(dword relative_path) //GetAbsolutePathFromRelative()
254
{
255
	char absolute_path[4096];
4137 leency 256
	if (ESBYTE[relative_path]=='/')
257
	{
258
		strcpy(#absolute_path, relative_path);
259
	}
260
	else
261
	{
6735 leency 262
		strcpy(#absolute_path, I_Path);
4137 leency 263
		absolute_path[strrchr(#absolute_path, '/')] = '\0';
264
		strcat(#absolute_path, relative_path);
265
	}
3432 leency 266
	return #absolute_path;
267
}
5483 leency 268
 
7202 leency 269
:dword GetIni(dword ini_path, ini_name) //search it on /kolibrios/ then on /sys/
7197 leency 270
{
7202 leency 271
	strcpy(ini_path, "/kolibrios/settings/");
272
	strcat(ini_path, ini_name);
273
	if (!file_exists(ini_path)) {
7213 leency 274
		strcpy(ini_path, "/sys/SETTINGS/");
7202 leency 275
		strcat(ini_path, ini_name);
7197 leency 276
	}
7202 leency 277
	return ini_path;
7197 leency 278
}
279
 
7369 leency 280
:dword notify(dword notify_param)
281
{
282
	return RunProgram("/sys/@notify", notify_param);
283
}
284
 
285
:void die(dword _last_msg)
286
{
287
	notify(_last_msg);
288
	ExitProcess();
289
}
290
 
291
//===================================================//
292
//                                                   //
293
//                   Convert Size                    //
294
//                                                   //
295
//===================================================//
296
 
5591 pavelyakov 297
:byte ConvertSize_size_prefix[8];
5576 pavelyakov 298
:dword ConvertSize(dword bytes)
5483 leency 299
{
5591 pavelyakov 300
  byte size_nm[4];
5803 leency 301
  if (bytes>=1073741824) strlcpy(#size_nm, "Gb",2);
302
  else if (bytes>=1048576) strlcpy(#size_nm, "Mb",2);
303
  else if (bytes>=1024) strlcpy(#size_nm, "Kb",2);
304
  else strlcpy(#size_nm, "b ",2);
6989 leency 305
  while (bytes>1023) bytes >>= 10;
5591 pavelyakov 306
  sprintf(#ConvertSize_size_prefix,"%d %s",bytes,#size_nm);
307
  return #ConvertSize_size_prefix;
5493 leency 308
}
7219 leency 309
 
6988 leency 310
:dword ConvertSize64(dword bytes_lo, bytes_hi)
311
{
312
  if (bytes_hi > 0) {
6989 leency 313
	if (bytes_lo>=1073741824) bytes_lo >>= 30; else bytes_lo = 0;
314
	sprintf(#ConvertSize_size_prefix,"%d Gb",bytes_hi<<2 + bytes_lo);
6988 leency 315
	return #ConvertSize_size_prefix;
316
  }
317
  else return ConvertSize(bytes_lo);
318
}
7219 leency 319
 
7369 leency 320
:unsigned char size[25];
5493 leency 321
:dword ConvertSizeToKb(unsigned int bytes)
322
{
323
	unsigned int kb;
324
	dword kb_line;
325
 
6568 leency 326
	if (bytes >= 1024)
327
	{
328
		kb_line = itoa(bytes / 1024);
329
		strcpy(#size, kb_line);
330
		strcat(#size, " Kb");
331
	}
332
	else {
333
		kb_line = itoa(bytes);
334
		strcpy(#size, kb_line);
335
		strcat(#size, " b");
336
	}
5493 leency 337
 
338
	return #size;
5598 pavelyakov 339
}
7210 leency 340
 
7369 leency 341
//===================================================//
342
//                                                   //
343
//                      Copy                         //
344
//                                                   //
345
//===================================================//
346
 
7210 leency 347
:int CopyFileAtOnce(dword size, copyFrom, copyTo)
348
dword cbuf;
349
int error;
350
{
351
	cbuf = malloc(size);
352
	if (error = ReadFile(0, size, cbuf, copyFrom))
353
	{
354
		debugln("Error: CopyFileAtOnce->ReadFile");
355
	}
356
	else
357
	{
7227 leency 358
		if (error = CreateFile(size, cbuf, copyTo)) debugln("Error: CopyFileAtOnce->CreateFile");
7210 leency 359
	}
360
	free(cbuf);
361
	return error;
362
}
363
 
364
:int CopyFileByBlocks(dword size, copyFrom, copyTo)
365
dword cbuf;
366
int error=-1;
367
dword offpos=0;
7227 leency 368
int block_size=1024*1024*4; //copy by 4 MiB
7210 leency 369
{
7227 leency 370
	if (GetFreeRAM()>1024*78) {
371
		//Set block size 32 MiB
372
		block_size <<= 3;
373
	}
7210 leency 374
	cbuf = malloc(block_size);
7227 leency 375
	if (error = CreateFile(0, 0, copyTo))
376
	{
377
		debugln("Error: CopyFileByBlocks->CreateFile");
378
		size = -1;
379
	}
7210 leency 380
	while(offpos < size)
381
	{
382
		error = ReadFile(offpos, block_size, cbuf, copyFrom);
383
		if (error = 6) { //File ended before last byte was readed
384
			block_size = EBX;
7227 leency 385
			if (block_size+offpos>=size) error=0;
7210 leency 386
		}
387
		else
7227 leency 388
			if (error!=0) {
389
				debugln("Error: CopyFileByBlocks->ReadFile");
390
				break;
391
			}
392
		if (error = WriteFile(offpos, block_size, cbuf, copyTo)) {
393
			debugln("Error: CopyFileByBlocks->WriteFile");
394
			break;
395
		}
7210 leency 396
		offpos += block_size;
397
	}
398
	free(cbuf);
399
	return error;
400
}
401
 
7369 leency 402
//===================================================//
403
//                                                   //
404
//                  Directory Size                   //
405
//                                                   //
406
//===================================================//
7210 leency 407
 
7369 leency 408
:struct _dir_size
409
{
410
	BDVK dir_info;
411
	dword folders;
412
	dword files;
413
	dword bytes;
414
	void get();
415
	void calculate_loop();
416
} dir_size;
417
 
418
:void _dir_size::get(dword way)
419
{
420
	folders = files = bytes = 0;
421
	if (way) calculate_loop(way);
422
}
423
 
424
:void _dir_size::calculate_loop(dword way)
425
{
426
	dword dirbuf, fcount, i, filename;
427
	dword cur_file;
428
	if (dir_exists(way))
429
	{
430
		cur_file = malloc(4096);
431
		// In the process of recursive descent, memory must be allocated dynamically,
432
		// because the static memory -> was a bug !!! But unfortunately pass away to sacrifice speed.
433
		GetDir(#dirbuf, #fcount, way, DIRS_ONLYREAL);
434
		for (i=0; i
435
		{
436
			filename = i*304+dirbuf+72;
437
			sprintf(cur_file,"%s/%s",way,filename);
438
 
439
			if (TestBit(ESDWORD[filename-40], 4) )
440
			{
441
				folders++;
442
				calculate_loop(cur_file);
443
			}
444
			else
445
			{
446
				GetFileInfo(cur_file, #dir_info);
447
				bytes += dir_info.sizelo;
448
				files++;
449
			}
450
		}
451
		free(cur_file);
452
		free(dirbuf);
453
	}
454
}
455
 
5598 pavelyakov 456
#endif