Rev 7031 | Rev 7773 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
5640 | pavelyakov | 1 | //IO library |
5660 | pavelyakov | 2 | |
3 | /* |
||
4 | class IO: |
||
6021 | leency | 5 | io.count(path) - path |
6 | io.size(path) - (/) path |
||
7 | io.run(path,param) - path param |
||
8 | io.write(size,data,path) - data path |
||
9 | io.read(path) - path |
||
10 | io.move(path1,path2) - (/) path1 path2 |
||
11 | io.copy(path1,path2) - (/) path1 path2 |
||
12 | io.set(path,attribute) - (/) |
||
13 | io.del(path) - (/) |
||
5660 | pavelyakov | 14 | |
6021 | leency | 15 | io.dir.load(path) - path ( free!!!) |
16 | io.dir.position(number) - number |
||
17 | io.dir.make(path) - path |
||
5660 | pavelyakov | 18 | |
6021 | leency | 19 | io.dir.buffer - - (io.dir.load) |
20 | io.dir.count - - (io.count) |
||
5660 | pavelyakov | 21 | */ |
22 | |||
5640 | pavelyakov | 23 | #ifndef INCLUDE_IO_H |
24 | #define INCLUDE_IO_H |
||
25 | |||
26 | #ifndef INCLUDE_DATE_H |
||
27 | #include "../lib/date.h" |
||
28 | #endif |
||
29 | |||
30 | #ifdef LANG_RUS |
||
31 | #define __T__GB "" |
||
32 | #define __T__MB "" |
||
33 | #define __T__KB "" |
||
34 | #define __T___B "" |
||
35 | #else |
||
36 | #define __T__GB "Gb" |
||
37 | #define __T__MB "Mb" |
||
38 | #define __T__KB "Kb" |
||
39 | #define __T___B "B" |
||
40 | #endif |
||
41 | |||
42 | #define ATR_READONLY 000001b |
||
43 | #define ATR_HIDDEN 000100b |
||
44 | #define ATR_SYSTEM 010000b |
||
45 | |||
46 | #define ATR_NOREADONLY 000010b |
||
47 | #define ATR_NOHIDDEN 001000b |
||
48 | #define ATR_NOSYSTEM 100000b |
||
49 | |||
50 | :enum |
||
51 | { |
||
52 | DIR_ALL, |
||
53 | DIR_NOROOT, |
||
54 | DIR_ONLYREAL |
||
55 | }; |
||
56 | |||
57 | :struct ___f70{ |
||
58 | dword func; |
||
59 | dword param1; |
||
60 | dword param2; |
||
61 | dword param3; |
||
62 | dword param4; |
||
63 | char rezerv; |
||
64 | dword name; |
||
65 | }__file_F70; |
||
66 | |||
67 | :int ___ReadDir(dword file_count, read_buffer, dir_path) |
||
68 | { |
||
69 | __file_F70.func = 1; |
||
70 | __file_F70.param1 = |
||
71 | __file_F70.param2 = |
||
72 | __file_F70.rezerv = 0; |
||
73 | __file_F70.param3 = file_count; |
||
74 | __file_F70.param4 = read_buffer; |
||
5646 | pavelyakov | 75 | __file_F70.name = io.path.path(dir_path); |
5640 | pavelyakov | 76 | $mov eax,70 |
77 | $mov ebx,#__file_F70.func |
||
78 | $int 0x40 |
||
79 | } |
||
80 | |||
81 | :dword ___GetFileInfo(dword file_path, bdvk_struct) |
||
82 | { |
||
83 | __file_F70.func = 5; |
||
84 | __file_F70.param1 = |
||
85 | __file_F70.param2 = |
||
86 | __file_F70.param3 = 0; |
||
87 | __file_F70.param4 = bdvk_struct; |
||
88 | __file_F70.rezerv = 0; |
||
5646 | pavelyakov | 89 | __file_F70.name = io.path.path(file_path); |
5640 | pavelyakov | 90 | $mov eax,70 |
91 | $mov ebx,#__file_F70.func |
||
92 | $int 0x40 |
||
93 | } |
||
94 | |||
95 | :struct ____BDVK { |
||
96 | dword readonly:1, hidden:1, system:1, volume_label:1, isfolder:1, notarchived:1, :0; |
||
97 | byte type_name; |
||
98 | byte rez1, rez2, selected; |
||
99 | dword timecreate; |
||
100 | date datecreate; |
||
101 | dword timelastaccess; |
||
102 | date datelastaccess; |
||
103 | dword timelastedit; |
||
104 | date datelastedit; |
||
105 | dword sizelo; |
||
106 | dword sizehi; |
||
107 | char name[518]; |
||
108 | }; |
||
109 | |||
110 | :struct __FILE |
||
111 | { |
||
112 | dword count; |
||
113 | int del(...); |
||
114 | int read(...); |
||
115 | int write(...); |
||
116 | dword set(...); |
||
117 | }; |
||
118 | :dword __FILE::set(dword file_path) |
||
119 | { |
||
120 | __file_F70.func = 6; |
||
121 | __file_F70.param1 = |
||
122 | __file_F70.param2 = |
||
123 | __file_F70.param3 = 0; |
||
124 | __file_F70.param4 = #io.BDVK; |
||
125 | __file_F70.rezerv = 0; |
||
5646 | pavelyakov | 126 | __file_F70.name = io.path.path(file_path); |
5640 | pavelyakov | 127 | $mov eax,70 |
128 | $mov ebx,#__file_F70.func |
||
129 | $int 0x40 |
||
130 | } |
||
131 | :int __FILE::del(dword PATH) |
||
132 | { |
||
133 | __file_F70.func = 8; |
||
134 | __file_F70.param1 = |
||
135 | __file_F70.param2 = |
||
136 | __file_F70.param3 = |
||
137 | __file_F70.param4 = |
||
138 | __file_F70.rezerv = 0; |
||
5646 | pavelyakov | 139 | __file_F70.name = io.path.path(PATH); |
5640 | pavelyakov | 140 | $mov eax,70 |
141 | $mov ebx,#__file_F70.func |
||
142 | $int 0x40 |
||
143 | } |
||
144 | :int __FILE::read(dword read_pos, read_file_size, read_buffer, read_file_path) |
||
145 | { |
||
146 | __file_F70.func = 0; |
||
147 | __file_F70.param1 = read_pos; |
||
148 | __file_F70.param2 = 0; |
||
149 | __file_F70.param3 = read_file_size; |
||
150 | __file_F70.param4 = read_buffer; |
||
151 | __file_F70.rezerv = 0; |
||
5646 | pavelyakov | 152 | __file_F70.name = io.path.path(read_file_path); |
5640 | pavelyakov | 153 | $mov eax,70 |
154 | $mov ebx,#__file_F70.func |
||
155 | $int 0x40 |
||
156 | } |
||
157 | :int __FILE::write(dword write_file_size, write_buffer, write_file_path) |
||
158 | { |
||
159 | __file_F70.func = 2; |
||
160 | __file_F70.param1 = 0; |
||
161 | __file_F70.param2 = 0; |
||
162 | __file_F70.param3 = write_file_size; |
||
163 | __file_F70.param4 = write_buffer; |
||
164 | __file_F70.rezerv = 0; |
||
5646 | pavelyakov | 165 | __file_F70.name = io.path.path(write_file_path); |
5640 | pavelyakov | 166 | $mov eax,70 |
167 | $mov ebx,#__file_F70.func |
||
168 | $int 0x40 |
||
169 | } |
||
170 | :struct __DIR |
||
171 | { |
||
172 | int make(dword name); |
||
5648 | pavelyakov | 173 | dword load(...); |
5646 | pavelyakov | 174 | dword position(dword i); |
5640 | pavelyakov | 175 | dword buffer; |
176 | signed count; |
||
177 | }; |
||
5646 | pavelyakov | 178 | :dword __DIR::position(dword i) |
179 | { |
||
180 | return i*304+buffer+72; |
||
181 | } |
||
5640 | pavelyakov | 182 | :int __DIR::make(dword new_folder_path) |
183 | { |
||
184 | __file_F70.func = 9; |
||
185 | __file_F70.param1 = |
||
186 | __file_F70.param2 = |
||
187 | __file_F70.param3 = |
||
188 | __file_F70.param4 = |
||
189 | __file_F70.rezerv = 0; |
||
5646 | pavelyakov | 190 | __file_F70.name = io.path.path(new_folder_path); |
5640 | pavelyakov | 191 | $mov eax,70 |
192 | $mov ebx,#__file_F70.func |
||
193 | $int 0x40 |
||
194 | } |
||
195 | |||
5648 | pavelyakov | 196 | :dword __DIR::load(dword PATH;byte options) |
197 | { |
||
198 | io.count(PATH); |
||
199 | if(count!=-1) |
||
200 | { |
||
201 | buffer = malloc(count+1*304+32); |
||
202 | ___ReadDir(count, buffer, PATH); |
||
203 | if (options == DIR_ONLYREAL) |
||
204 | { |
||
205 | if (!strcmp(".",buffer+72)){count--; memmov(buffer,buffer+304,count*304);} |
||
206 | if (!strcmp("..",buffer+72)){count--; memmov(buffer,buffer+304,count*304);} |
||
207 | return buffer; |
||
208 | } |
||
209 | if (options == DIR_NOROOT) |
||
210 | { |
||
211 | if (!strcmp(".",buffer+72)) memmov(buffer,buffer+304,count*304-304); |
||
212 | return buffer; |
||
213 | } |
||
214 | return buffer; |
||
215 | } |
||
216 | return NULL; |
||
217 | } |
||
218 | |||
5640 | pavelyakov | 219 | :struct __PATH |
220 | { |
||
221 | dword file(...); |
||
222 | dword path(...); |
||
223 | }; |
||
5646 | pavelyakov | 224 | |
5640 | pavelyakov | 225 | :char __PATH_NEW[4096]; |
226 | :dword __PATH::path(dword PATH) |
||
227 | { |
||
5648 | pavelyakov | 228 | dword pos; |
229 | if(!PATH) return self.dir; |
||
230 | pos = PATH; |
||
6759 | leency | 231 | if(DSBYTE[pos]=='/') || (!strncmp(PATH,"./",2)) |
5640 | pavelyakov | 232 | { |
6759 | leency | 233 | return PATH; |
5640 | pavelyakov | 234 | } |
7768 | leency | 235 | strcpy(#__PATH_NEW, self.dir); |
236 | chrcat(#__PATH_NEW, '/'); |
||
237 | strcpy(#__PATH_NEW, PATH); |
||
5646 | pavelyakov | 238 | return #__PATH_NEW; |
5640 | pavelyakov | 239 | } |
240 | |||
241 | :dword __PATH::file(dword name) |
||
242 | { |
||
243 | dword ret; |
||
244 | ret = name; |
||
245 | while(DSBYTE[name]) |
||
246 | { |
||
247 | if(DSBYTE[name]=='/')ret = name+1; |
||
248 | name++; |
||
249 | } |
||
250 | return ret; |
||
251 | } |
||
252 | |||
253 | :struct IO |
||
254 | { |
||
255 | dword buffer_data; |
||
256 | dword size_dir; |
||
257 | dword count_dirs,count_files; |
||
258 | signed FILES_SIZE; |
||
259 | dword file_name; |
||
260 | double size(...); |
||
261 | dword get_size_dir(dword name); |
||
262 | signed count(dword path); |
||
263 | signed int run(dword path,param); |
||
264 | byte del(...); |
||
265 | dword read(...); |
||
266 | int write(...); |
||
267 | byte copy(...); |
||
268 | byte move(...); |
||
269 | dword set(...); |
||
5730 | pavelyakov | 270 | dword readKPACK(dword path1); |
5640 | pavelyakov | 271 | dword convert_size(); |
272 | __DIR dir; |
||
273 | __PATH path; |
||
274 | __FILE file; |
||
275 | ____BDVK BDVK; |
||
276 | }io; |
||
277 | :byte __ConvertSize_size_prefix[8]; |
||
278 | :dword IO::convert_size() |
||
279 | { |
||
280 | byte size_nm[3]; |
||
281 | dword bytes; |
||
282 | bytes = FILES_SIZE; |
||
5646 | pavelyakov | 283 | if (bytes>=1073741824) strlcpy(#size_nm, __T__GB,2); |
284 | else if (bytes>=1048576) strlcpy(#size_nm, __T__MB,2); |
||
285 | else if (bytes>=1024) strlcpy(#size_nm, __T__KB,2); |
||
286 | else strlcpy(#size_nm, __T___B,1); |
||
5640 | pavelyakov | 287 | while (bytes>1023) bytes/=1024; |
288 | sprintf(#__ConvertSize_size_prefix,"%d %s",bytes,#size_nm); |
||
289 | return #__ConvertSize_size_prefix; |
||
290 | } |
||
5751 | leency | 291 | :dword IO::readKPACK(dword path1) |
292 | { |
||
293 | EAX = 68; |
||
294 | EBX = 27; |
||
295 | ECX = path1; |
||
296 | $int 0x40; |
||
297 | FILES_SIZE = EDX; |
||
298 | buffer_data = EAX; |
||
299 | return buffer_data; |
||
300 | } |
||
5640 | pavelyakov | 301 | :int IO::write(dword PATH,data) |
302 | { |
||
303 | file.write(0,strlen(data),data,PATH); |
||
304 | } |
||
5800 | pavelyakov | 305 | :char BYTE_HEAD_FILE_KPCK[4]; |
5640 | pavelyakov | 306 | :dword IO::read(dword PATH) |
307 | { |
||
5745 | leency | 308 | int result; |
5640 | pavelyakov | 309 | ___GetFileInfo(PATH, #BDVK); |
5800 | pavelyakov | 310 | if(BDVK.isfolder)return false; |
311 | file.read(0,4,#BYTE_HEAD_FILE_KPCK,PATH); |
||
312 | IF(DSDWORD[#BYTE_HEAD_FILE_KPCK]=='KCPK')return readKPACK(PATH); |
||
5640 | pavelyakov | 313 | FILES_SIZE = BDVK.sizelo; |
314 | buffer_data = malloc(FILES_SIZE+1); |
||
5745 | leency | 315 | result = file.read(0,FILES_SIZE,buffer_data,PATH); |
316 | if (result!=0) buffer_data = free(buffer_data); //file read failed |
||
5751 | leency | 317 | return buffer_data; |
5640 | pavelyakov | 318 | } |
319 | |||
320 | :signed int IO::run(dword rpath,rparam) |
||
321 | { |
||
322 | __file_F70.func = 7; |
||
323 | __file_F70.param1 = |
||
324 | __file_F70.param3 = |
||
325 | __file_F70.param4 = |
||
326 | __file_F70.rezerv = 0; |
||
327 | __file_F70.param2 = rparam; |
||
5646 | pavelyakov | 328 | __file_F70.name = path.path(rpath); |
5640 | pavelyakov | 329 | $mov eax,70 |
330 | $mov ebx,#__file_F70.func |
||
331 | $int 0x40 |
||
332 | } |
||
333 | :signed IO::count(dword PATH) |
||
334 | { |
||
335 | byte buf[32]; |
||
336 | if(!___ReadDir(0, #buf, PATH)) |
||
337 | { |
||
338 | dir.count = ESDWORD[#buf+8]; |
||
339 | return dir.count; |
||
340 | } |
||
341 | return -1; |
||
342 | } |
||
5646 | pavelyakov | 343 | |
5640 | pavelyakov | 344 | :double IO::size(dword PATH) |
345 | { |
||
346 | dword i,tmp_buf,count_dir,count_file; |
||
347 | dword filename; |
||
348 | double size_tmp; |
||
349 | double tmp; |
||
350 | if(!PATH)return 0; |
||
351 | if(___GetFileInfo(PATH, #BDVK))return -1; |
||
352 | if(BDVK.isfolder) |
||
353 | { |
||
5648 | pavelyakov | 354 | tmp_buf = dir.load(PATH,DIR_ONLYREAL); |
5640 | pavelyakov | 355 | if(dir.count<1)return 0; |
356 | count_dir = dir.count; |
||
357 | i = 0; |
||
358 | size_tmp = 0; |
||
359 | count_file = malloc(4096); |
||
360 | while(i |
||
361 | { |
||
362 | filename = i*304+tmp_buf+72; |
||
363 | sprintf(count_file,"%s/%s",PATH,filename); |
||
364 | tmp = size(count_file); |
||
365 | if(tmp==-1)return -1; |
||
366 | size_tmp += tmp; |
||
367 | i++; |
||
368 | if (TestBit(ESDWORD[filename-40], 4))count_dirs++; |
||
369 | else count_files++; |
||
370 | } |
||
371 | |||
372 | free(tmp_buf); |
||
373 | free(count_file); |
||
374 | FILES_SIZE = size_tmp; |
||
375 | return FILES_SIZE; |
||
376 | } |
||
377 | FILES_SIZE = BDVK.sizelo; |
||
378 | count_files++; |
||
379 | return FILES_SIZE; |
||
380 | } |
||
381 | :byte IO::del(dword PATH) |
||
382 | { |
||
383 | dword i,tmp_buf,count_dir,count_file; |
||
384 | if(!PATH)return 0; |
||
385 | if(___GetFileInfo(PATH, #BDVK))return false; |
||
386 | if(BDVK.isfolder) |
||
387 | { |
||
5648 | pavelyakov | 388 | tmp_buf = dir.load(PATH,DIR_ONLYREAL); |
5640 | pavelyakov | 389 | count_dir = dir.count; |
390 | i = 0; |
||
391 | count_file = malloc(4096); |
||
392 | while(i |
||
393 | { |
||
394 | sprintf(count_file,"%s/%s",PATH,i*304+tmp_buf+72); |
||
395 | if(!del(count_file))return false; |
||
396 | i++; |
||
397 | } |
||
398 | free(tmp_buf); |
||
399 | free(count_file); |
||
400 | } |
||
401 | file.del(PATH); |
||
402 | return true; |
||
403 | } |
||
404 | :dword IO::set(dword PATH,atr) |
||
405 | { |
||
406 | dword i,tmp_buf,count_dir,count_file; |
||
407 | byte cmd_read,cmd_hide,cmd_system; |
||
408 | if(!PATH)return 0; |
||
409 | if(___GetFileInfo(PATH, #BDVK))return false; |
||
410 | cmd_read = atr&11b; |
||
411 | atr>>=2; |
||
412 | cmd_hide = atr&11b; |
||
413 | atr>>=2; |
||
414 | cmd_system = atr&11b; |
||
415 | if(BDVK.isfolder) |
||
416 | { |
||
5648 | pavelyakov | 417 | tmp_buf = dir.load(PATH,DIR_ONLYREAL); |
5640 | pavelyakov | 418 | count_dir = dir.count; |
419 | i = 0; |
||
420 | count_file = malloc(4096); |
||
421 | while(i |
||
422 | { |
||
423 | sprintf(count_file,"%s/%s",PATH,i*304+tmp_buf+72); |
||
424 | file.set(PATH,atr); |
||
425 | i++; |
||
426 | } |
||
427 | free(tmp_buf); |
||
428 | free(count_file); |
||
429 | return 0; |
||
430 | } |
||
431 | if(cmd_read) |
||
432 | { |
||
433 | if(cmd_read&01b)BDVK.readonly = true; |
||
434 | else BDVK.readonly = false; |
||
435 | } |
||
436 | if(cmd_hide) |
||
437 | { |
||
438 | if(cmd_hide&01b)BDVK.hidden = true; |
||
439 | else BDVK.hidden = false; |
||
440 | } |
||
441 | if(cmd_system) |
||
442 | { |
||
443 | if(cmd_system&01b)BDVK.system = true; |
||
444 | else BDVK.system = false; |
||
445 | } |
||
446 | file.set(PATH); |
||
447 | } |
||
448 | :byte IO::copy(dword PATH,PATH1) |
||
449 | { |
||
450 | dword i,tmp_buf,count_dir,count_file; |
||
451 | dword _path_; |
||
452 | byte ret; |
||
453 | if(!PATH)return 0; |
||
454 | if(___GetFileInfo(PATH, #BDVK))return false; |
||
455 | _path_ = malloc(4096); |
||
456 | if(BDVK.isfolder) |
||
457 | { |
||
458 | sprintf(_path_,"%s/%s",PATH1,path.file(PATH)); |
||
459 | dir.make(_path_); |
||
5648 | pavelyakov | 460 | tmp_buf = dir.load(PATH,DIR_ONLYREAL); |
5640 | pavelyakov | 461 | count_dir = dir.count; |
462 | i = 0; |
||
463 | count_file = malloc(4096); |
||
464 | while(i |
||
465 | { |
||
466 | sprintf(count_file,"%s/%s",PATH,i*304+tmp_buf+72); |
||
467 | if(!copy(count_file,_path_))return false; |
||
468 | i++; |
||
469 | } |
||
470 | free(tmp_buf); |
||
471 | free(count_file); |
||
472 | free(_path_); |
||
473 | return true; |
||
474 | } |
||
475 | read(PATH); |
||
476 | sprintf(_path_,"%s/%s",PATH1,path.file(PATH)); |
||
477 | ret = file.write(FILES_SIZE,buffer_data,_path_); |
||
478 | free(_path_); |
||
479 | if(!ret)return true; |
||
480 | return false; |
||
481 | } |
||
482 | :byte IO::move(dword PATH,PATH1) |
||
483 | { |
||
484 | if(copy(PATH,PATH1))if(del(PATH))return true; |
||
485 | return false; |
||
486 | } |
||
487 | |||
488 | #endif |