forked from KolibriOS/kolibrios
Eolite 0.97.1
git-svn-id: svn://kolibrios.org@937 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
ff699eaffc
commit
75110b9fa0
@ -4,57 +4,63 @@
|
|||||||
#include "lib\kolibri.h--"
|
#include "lib\kolibri.h--"
|
||||||
#include "lib\memory.h--"
|
#include "lib\memory.h--"
|
||||||
#include "lib\edit_box_lib.h--"
|
#include "lib\edit_box_lib.h--"
|
||||||
#include "include\run_file.h--"
|
#include "lib\file_system.h--"
|
||||||
#include "imgs\toolbar.txt"
|
#include "imgs\toolbar.txt"
|
||||||
#include "imgs\left_p.cpp"
|
#include "imgs\left_p.txt"
|
||||||
|
|
||||||
//ëîêàëèçàöèÿ è íàñòðîéêè
|
//ëîêàëèçàöèÿ è íàñòðîéêè
|
||||||
byte header[27] = "Eolite File Manager v0.97";
|
#define header "Eolite File Manager v0.97.1";
|
||||||
#define videlenie 0x94AECE; //öâåò âûäåëåííîãî ýëåìåíòà èç ñïèñêà ôàéëîâ
|
#define videlenie 0xFEA4B7; //0x94AECE,,0x8BCDFF,0x9EACCA,0xB8C9B8}; //öâåò âûäåëåííîãî ýëåìåíòà èç ñïèñêà ôàéëîâ
|
||||||
byte toolbar_buttons_x[6]={14,51,90,139,172,208};
|
byte toolbar_buttons_x[6]={14,51,90,139,172,208};
|
||||||
//
|
//
|
||||||
dword but_num=0, kolichestvo=0, curbtn=0, za_kadrom=0;
|
dword but_num, kolichestvo, za_kadrom, curbtn, razm_scrl;
|
||||||
byte cut_active, rename_active, del_active;
|
byte cut_active, rename_active, del_active;
|
||||||
byte show_actions=1, show_preview=0, sort_num=1, isdir;
|
byte show_actions=1, show_preview=0, sort_num=1, isdir;
|
||||||
dword razm_scrl; //äëÿ ñêðîëà
|
char path[256]="/rd/1/", edit_path[256], PathHistory[2560], temp[256]; //äëÿ ïóòåé
|
||||||
byte path[256]="/rd/1/", edit_path[256], PathHistory[2560], temp[256]; //äëÿ ïóòåé
|
char file_path[256], file_name[256]; //äëÿ ôàéëîâ
|
||||||
byte file_path[256], file_name[256]; //äëÿ ôàéëîâ
|
char copyfile[256],copy_name[256]; //êîïèðîâàíèå
|
||||||
byte copyfile[256],copy_name[256]; //êîïèðîâàíèå
|
|
||||||
dword i; //äëÿ öèêëîâ
|
|
||||||
dword file_mas[6898]; //ñïèñîê ôàéëîâ
|
dword file_mas[6898]; //ñïèñîê ôàéëîâ
|
||||||
int temp_int, j;
|
int temp_int, j, i;
|
||||||
dword stak[100]=0; //îêíî About
|
dword stak[100]=0; //îêíî About
|
||||||
|
|
||||||
edit_box edit1= {250,252,17,0xffffff,0x94AECE,0xD3DDEB,0xffffff,0,248,#edit_path,64,6,6};
|
edit_box edit1= {250,252,17,0xffffff,0x94AECE,0xD3DDEB,0xffffff,0,248,#edit_path,64,6,6};
|
||||||
edit_box edit2= {250,218,80,0xFFFFCC,0x94AECE,0xFFFFCC,0xffffff,0,248,#file_name,64,6,6};
|
edit_box edit2= {250,218,80,0xFFFFCC,0x94AECE,0xFFFFCC,0xffffff,0,248,#file_name,64,6,6};
|
||||||
|
|
||||||
proc_info Form;
|
proc_info Form;
|
||||||
f70 open_dir_70;
|
|
||||||
dword buf=0, off; //äëÿ òåêñòà è áóôåðà
|
dword buf=0, off; //äëÿ òåêñòà è áóôåðà
|
||||||
dword devbuf=0, dev_num;
|
dword devbuf=0, dev_num;
|
||||||
#include "include\LVabout.c--"
|
#include "include\LVabout.c--"
|
||||||
#include "include\icons_f.h--"
|
#include "include\icons_f.h--"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//IPC
|
||||||
|
/*#include "lib\Nable_lib.h--"
|
||||||
|
#include "lib\ipc.h--"
|
||||||
|
|
||||||
|
int pLoadedImage;
|
||||||
|
void GetImage(dword ipath)
|
||||||
|
{
|
||||||
|
IF (pLoadedImage) free(pLoadedImage);
|
||||||
|
pLoadedImage=loadimage_viaIPC(ipath, #CurrentImage);
|
||||||
|
SetEventMask(100111b); //restore normal event mask
|
||||||
|
}*/
|
||||||
|
|
||||||
|
|
||||||
void main()
|
void main()
|
||||||
byte pressed, key, id;
|
byte pressed, key, id;
|
||||||
mouse m;
|
mouse m;
|
||||||
|
int pressed_y;
|
||||||
{
|
{
|
||||||
devbuf= malloc(3112); //áóôåð ãäå-òî íà 10 äåâàéñîâ â ëåâîé ïàíåëè
|
devbuf= malloc(3112); //áóôåð ãäå-òî íà 10 äåâàéñîâ â ëåâîé ïàíåëè
|
||||||
open_dir_70.func = 1;
|
ReadDir(10, devbuf, "/");
|
||||||
open_dir_70.param1 = 0;
|
|
||||||
open_dir_70.param2 = 0;
|
|
||||||
open_dir_70.param3 = 10;
|
|
||||||
open_dir_70.param4 = devbuf;
|
|
||||||
open_dir_70.rezerv = 0;
|
|
||||||
open_dir_70.name = "/";
|
|
||||||
$mov eax,70
|
|
||||||
$mov ebx,#open_dir_70.func
|
|
||||||
$int 0x40
|
|
||||||
dev_num=EBX;
|
dev_num=EBX;
|
||||||
load_dll(); //ïîäãðóæàåò ëèáó ñ åäèò_áîêñîì
|
load_dll(); //ïîäãðóæàåò ëèáó ñ åäèò_áîêñîì
|
||||||
IF (param[0]<>'') {copystr(#param,#edit_path); Goto_edit_path();}
|
IF (param[0]<>'') {copystr(#param,#edit_path); Goto_edit_path();}
|
||||||
Open_Dir(#path,2);
|
Open_Dir(#path,2);
|
||||||
//SetEventMask(100111b);
|
//GetImage("/sys/wallpaper.gif");
|
||||||
|
//DrawImage(#CurrentImage, 0*65536+0);
|
||||||
|
//SetEventMask(100111b);
|
||||||
loop()
|
loop()
|
||||||
{
|
{
|
||||||
switch(WaitEvent())
|
switch(WaitEvent())
|
||||||
@ -68,15 +74,16 @@ mouse m;
|
|||||||
IF (vert==1) IF (curbtn==but_num-1) FileList_ReDraw(3); ELSE FileList_ReDraw(1);
|
IF (vert==1) IF (curbtn==but_num-1) FileList_ReDraw(3); ELSE FileList_ReDraw(1);
|
||||||
//âûäåëåíèå èñïîëüçóÿ ÏÊÌ
|
//âûäåëåíèå èñïîëüçóÿ ÏÊÌ
|
||||||
//IF (m.pkm==1) && (m.x>197) && (m.x<Form.width-22) && (m.y-skin_width>56)
|
//IF (m.pkm==1) && (m.x>197) && (m.x<Form.width-22) && (m.y-skin_width>56)
|
||||||
// IF (m.y-skin_width-56/18<>curbtn) FileList_ReDraw(m.y-skin_width-56/18-curbtn);
|
// && (m.y-skin_width-56/18<>curbtn) FileList_ReDraw(m.y-skin_width-56/18-curbtn);
|
||||||
//ñêðîëë
|
//ñêðîëë
|
||||||
IF (m.y>Form.width) || (57+razm_scrl>m.y) m.y=57+razm_scrl; //åñëè êóðñîð íàä îêíîì
|
IF (m.y>Form.width) || (razm_scrl/2+57>m.y) m.y=razm_scrl/2+57; //åñëè êóðñîð íàä îêíîì
|
||||||
IF (m.lkm==0) pressed=0; ELSE
|
IF (m.lkm==0) pressed=0; ELSE
|
||||||
IF (m.x>=Form.width-21) && (m.x<=Form.width-6) pressed=1;
|
IF (m.x>=Form.width-21) && (m.x<=Form.width-6) pressed=1;
|
||||||
IF (pressed==1)
|
IF (pressed==1)
|
||||||
{
|
{
|
||||||
temp_int=za_kadrom; //ñîõðàíÿåì ñòàðîå êîëè÷åñòâî
|
temp_int=za_kadrom; //ñîõðàíÿåì ñòàðîå êîëè÷åñòâî
|
||||||
za_kadrom = m.y -57-razm_scrl * kolichestvo / onTop(22,57);
|
j= razm_scrl/2;
|
||||||
|
za_kadrom = m.y -j -57 * kolichestvo / onTop(22,57);
|
||||||
IF (but_num+za_kadrom>kolichestvo) za_kadrom=kolichestvo-but_num;
|
IF (but_num+za_kadrom>kolichestvo) za_kadrom=kolichestvo-but_num;
|
||||||
IF (temp_int<>za_kadrom) List_ReDraw(); //÷òîá ëèøíèé ðàç íå ïåðåðèñîâûâàòü
|
IF (temp_int<>za_kadrom) List_ReDraw(); //÷òîá ëèøíèé ðàç íå ïåðåðèñîâûâàòü
|
||||||
}
|
}
|
||||||
@ -110,45 +117,56 @@ mouse m;
|
|||||||
break;
|
break;
|
||||||
case 50: //ñòðåëêà ââåðõ íà ñêðîëå
|
case 50: //ñòðåëêà ââåðõ íà ñêðîëå
|
||||||
FileList_ReDraw(-1);
|
FileList_ReDraw(-1);
|
||||||
BREAK;
|
break;
|
||||||
case 51: //ñòðåëêà âíèç íà ñêðîëå
|
case 51: //ñòðåëêà âíèç íà ñêðîëå
|
||||||
FileList_ReDraw(1);
|
FileList_ReDraw(1);
|
||||||
BREAK;
|
break;
|
||||||
case 78: //preview
|
case 78: //preview
|
||||||
IF (show_preview==1) show_preview=0; ELSE show_preview=1;
|
IF (show_preview==1) show_preview=0; ELSE show_preview=1;
|
||||||
Preview();
|
Preview();
|
||||||
BREAK;
|
break;
|
||||||
case 77: //actions
|
case 77: //actions
|
||||||
IF (show_actions==1) show_actions=0; ELSE show_actions=1;
|
IF (show_actions==1) show_actions=0; ELSE show_actions=1;
|
||||||
Actions(); Preview();
|
Actions(); Preview();
|
||||||
BREAK;
|
break;
|
||||||
case 80: goto REN_MARK; //rename
|
case 80: //rename
|
||||||
case 81: Del_Form(); BREAK;//Delete file
|
goto REN_MARK;
|
||||||
}
|
case 81: //Delete file
|
||||||
if (id>200) //êíîïêè èç ñïèñêà ôàéëîâ
|
Del_Form();
|
||||||
{
|
break;
|
||||||
IF (curbtn!=id-201) {FileList_ReDraw(id-201-curbtn); break;}
|
case 82: //create folder
|
||||||
else OPEN_MARK:
|
NEW_FOLDER_MARK:
|
||||||
if (!isdir) Run_File(#file_path); else
|
copystr(#path, #temp);
|
||||||
if (strcmp(za_kadrom+curbtn+1*304 + buf+72,"..")==0) Dir_Up(); else
|
copystr("New folder", #temp+strlen(#temp));
|
||||||
{ OPEN_DEV:
|
CreateFolder(#temp);
|
||||||
copystr(#file_path, #path);
|
za_kadrom=curbtn=0;
|
||||||
copystr("/", #path+strlen(#path));
|
Open_Dir(#path,1);
|
||||||
DrawBar(197,curbtn*18+57,onLeft(22,197),18,0xFFFFFF); //çàêðàøèâàåì ñòàðîå âûäåëåíèå
|
FOR (i=0; i<kolichestvo; i++)
|
||||||
za_kadrom=curbtn=0;
|
IF (strcmp("New folder",file_mas[i]*304+buf+72)==0) {IF(!strcmp("..",buf+72+304))i--; FileList_ReDraw(i); break;}
|
||||||
Open_Dir(#path,1);
|
goto REN_MARK;
|
||||||
}
|
case 100...120:
|
||||||
break;
|
DEVICE_MARK:
|
||||||
}
|
copystr(id-100*304+ devbuf+72, #path);
|
||||||
if (id>=100) && (id<130) //ïîäêëþ÷¸ííûå íîñèòåëè èíôîðìàöèè
|
IF (path[0]=='r') copystr("/rd/1",#file_path);
|
||||||
{ DEVICE_MARK:
|
ELSE {
|
||||||
copystr(id-100*304+ devbuf+72, #path);
|
copystr("/", #file_path);
|
||||||
IF (strcmp(#path,"rd")==0) copystr("/rd/1",#file_path);
|
copystr(#path, #file_path+strlen(#file_path));
|
||||||
ELSE {
|
}
|
||||||
copystr("/", #file_path);
|
goto OPEN_DEV;
|
||||||
copystr(#path, #file_path+strlen(#file_path));
|
default:
|
||||||
|
if (id<200) break; //êíîïêè èç ñïèñêà ôàéëîâ
|
||||||
|
IF (curbtn!=id-201) {FileList_ReDraw(id-201-curbtn); break;}
|
||||||
|
else OPEN_MARK:
|
||||||
|
if (!isdir) Run_File(#file_path); else
|
||||||
|
if (strcmp(za_kadrom+curbtn+1*304 + buf+72,"..")==0) Dir_Up(); else
|
||||||
|
{ OPEN_DEV:
|
||||||
|
copystr(#file_path, #path);
|
||||||
|
copystr("/", #path+strlen(#path));
|
||||||
|
DrawBar(197,curbtn*18+57,onLeft(22,197),18,0xFFFFFF); //çàêðàøèâàåì ñòàðîå âûäåëåíèå
|
||||||
|
za_kadrom=curbtn=0;
|
||||||
|
Open_Dir(#path,1);
|
||||||
}
|
}
|
||||||
GOTO OPEN_DEV;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
//Key pressed-----------------------------------------------------------------------------
|
//Key pressed-----------------------------------------------------------------------------
|
||||||
@ -166,7 +184,7 @@ mouse m;
|
|||||||
{
|
{
|
||||||
case 209...217: id=key-109; IF(dev_num>id-100)GOTO DEVICE_MARK; break;
|
case 209...217: id=key-109; IF(dev_num>id-100)GOTO DEVICE_MARK; break;
|
||||||
case 8: GoBack(); break; //Íàçàä
|
case 8: GoBack(); break; //Íàçàä
|
||||||
case 014: MoveSize(80,80,OLD,OLD); Run_Program("/sys/File Managers/Eolite", #path); break; //íîâîå îêíî
|
case 014: MoveSize(80,80,OLD,OLD); RunProgram("/sys/File Managers/Eolite", #path); break; //íîâîå îêíî
|
||||||
case 024: //Ctrl+X cut
|
case 024: //Ctrl+X cut
|
||||||
case 089: //Ctrl+Ins copy
|
case 089: //Ctrl+Ins copy
|
||||||
case 003: //Ctrl+C copy
|
case 003: //Ctrl+C copy
|
||||||
@ -178,13 +196,15 @@ mouse m;
|
|||||||
break;
|
break;
|
||||||
case 022: Paste(); break;//Ctrl+V paste
|
case 022: Paste(); break;//Ctrl+V paste
|
||||||
case 027: //Esc
|
case 027: //Esc
|
||||||
IF (rename_active==1) Line_ReDraw(videlenie, 100);
|
IF (rename_active==1) {Line_ReDraw(videlenie, 100);}
|
||||||
break;
|
break;
|
||||||
case 013: //Enter
|
case 013: //Enter
|
||||||
IF (rename_active==1) {Line_ReDraw(videlenie, curbtn); break;}
|
IF (rename_active==1) {Line_ReDraw(videlenie, curbtn); break;}
|
||||||
IF (strcmp(#path,#edit_path)<>0) Goto_edit_path();
|
IF (strcmp(#path,#edit_path)<>0) Goto_edit_path();
|
||||||
ELSE GOTO OPEN_MARK;
|
ELSE GOTO OPEN_MARK;
|
||||||
break;
|
break;
|
||||||
|
case 55: //F6 - new folder
|
||||||
|
goto NEW_FOLDER_MARK;
|
||||||
case 56: //IF (rename_active==1) break;//up
|
case 56: //IF (rename_active==1) break;//up
|
||||||
case 178: //up
|
case 178: //up
|
||||||
FileList_ReDraw(-1);
|
FileList_ReDraw(-1);
|
||||||
@ -205,19 +225,19 @@ mouse m;
|
|||||||
FileList_ReDraw(-but_num+1);
|
FileList_ReDraw(-but_num+1);
|
||||||
break;
|
break;
|
||||||
case 051: //Íàæàòà F2
|
case 051: //Íàæàòà F2
|
||||||
REN_MARK:
|
REN_MARK:
|
||||||
IF (isdir==1) break; //ïàïêè ïîêà ÷òî êîïèðîâàòü íå óìååì
|
//IF (isdir==1) break; //ïàïêè ïîêà ÷òî êîïèðîâàòü íå óìååì
|
||||||
edit2.flags=66; //äåëàåì êîìïîíåíò àêòèâíûì
|
edit2.flags=66; //äåëàåì êîìïîíåíò àêòèâíûì
|
||||||
DeleteButton(curbtn+201); //ýòî ÷òîá ìîæíî áûëî âûäåëÿòü ìûøüþ
|
DeleteButton(curbtn+201); //ýòî ÷òîá ìîæíî áûëî âûäåëÿòü ìûøüþ
|
||||||
edit2.width=onLeft(24,217);
|
edit2.width=onLeft(24,217);
|
||||||
edit2.top=curbtn*18+59+skin_width;
|
edit2.top=curbtn*18+59+skin_width;
|
||||||
edit2.size=strlen(#file_name); edit2.pos=strlen(#file_name);
|
edit2.size=strlen(#file_name); edit2.pos=strlen(#file_name);
|
||||||
edit_box_draw stdcall (#edit2);
|
edit_box_draw stdcall (#edit2);
|
||||||
DrawBar(218,curbtn*18+58,edit2.width+1,1,0xFFFFCC); //ïîëîñà æåëòàÿ ñâåðõó äëÿ îäèíàêîâîñòè
|
DrawBar(218,curbtn*18+58,edit2.width+1,1,0xFFFFCC); //ïîëîñà æåëòàÿ ñâåðõó äëÿ îäèíàêîâîñòè
|
||||||
rename_active=1;
|
rename_active=1;
|
||||||
break;
|
break;
|
||||||
case 052: //Íàæàòà F3
|
case 052: //Íàæàòà F3
|
||||||
IF (isdir==false) Run_Program("/sys/tinypad", #file_path); break;
|
IF (isdir==false) RunProgram("/sys/tinypad", #file_path); break;
|
||||||
case 054: Open_Dir(#path,1); break; //ïåðåðèñîâàòü îêíî F5
|
case 054: Open_Dir(#path,1); break; //ïåðåðèñîâàòü îêíî F5
|
||||||
case 182: Del_Form(); break; //delete file
|
case 182: Del_Form(); break; //delete file
|
||||||
default:
|
default:
|
||||||
@ -244,8 +264,8 @@ inline fastcall void draw_window()
|
|||||||
{
|
{
|
||||||
WindowRedrawStatus(1);
|
WindowRedrawStatus(1);
|
||||||
skin_width = GetSkinWidth();
|
skin_width = GetSkinWidth();
|
||||||
DefineAndDrawWindow(100,100,600,410,0x43,0x10E4DFE1,0,0,#header);
|
DefineAndDrawWindow(100,100,600,410,0x43,0x10E4DFE1,0,0,header);
|
||||||
Form.getme();
|
Form.GetInfo(SelfInfo);
|
||||||
IF (Form.height==skin_width+3) {WindowRedrawStatus(2); return;} //ýòî çà÷¸ò!
|
IF (Form.height==skin_width+3) {WindowRedrawStatus(2); return;} //ýòî çà÷¸ò!
|
||||||
IF (Form.height<280) MoveSize(OLD,OLD,OLD,280);
|
IF (Form.height<280) MoveSize(OLD,OLD,OLD,280);
|
||||||
IF (Form.width<480) MoveSize(OLD,OLD,480,OLD);
|
IF (Form.width<480) MoveSize(OLD,OLD,480,OLD);
|
||||||
@ -261,7 +281,7 @@ inline fastcall void draw_window()
|
|||||||
DrawBar(251,29,onLeft(251,60),10,0xE4DFE1); //ôîí ïîä ïîëîñîé àäðåñà
|
DrawBar(251,29,onLeft(251,60),10,0xE4DFE1); //ôîí ïîä ïîëîñîé àäðåñà
|
||||||
DefineButton(onLeft(34,0),6,27,28,30+BT_HIDE+BT_NOFRAME,0xE4DFE1); //about
|
DefineButton(onLeft(34,0),6,27,28,30+BT_HIDE+BT_NOFRAME,0xE4DFE1); //about
|
||||||
DefineButton(onLeft(61,0),12,18,16,27+BT_HIDE,0xE4DFE1); //êíîïêà ïåðåõîäà
|
DefineButton(onLeft(61,0),12,18,16,27+BT_HIDE,0xE4DFE1); //êíîïêà ïåðåõîäà
|
||||||
PutImage(#goto_about,56,40,onLeft(60,0),0);
|
PutPaletteImage(#goto_about,56,40,Form.width-60,0,#goto_about_pal);
|
||||||
//ïðÿìîóãîëüíèêè âíóòðè
|
//ïðÿìîóãîëüíèêè âíóòðè
|
||||||
DrawRegion(6,40,Form.width-12,Form.height-skin_width-46,0x94AECE); //ñèíèé îáîäîê
|
DrawRegion(6,40,Form.width-12,Form.height-skin_width-46,0x94AECE); //ñèíèé îáîäîê
|
||||||
DrawRegion(5,39,Form.width-10,Form.height-skin_width-44,0xE4DFE1); //ôîí
|
DrawRegion(5,39,Form.width-10,Form.height-skin_width-44,0xE4DFE1); //ôîí
|
||||||
@ -361,35 +381,31 @@ void List_ReDraw()
|
|||||||
TVScroll();
|
TVScroll();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*void List_ReDraw()
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for (j=0; j<5; j++;) for (i=0; i<6; i++;)
|
|
||||||
{
|
|
||||||
PutImage(#def_file,48,48,i*64+197,j*64+57);
|
|
||||||
off=file_mas[i+j+za_kadrom]*304 + buf+72;
|
|
||||||
DrawBar(i*64+197,j*64+57+50,10*6,9,0xFFFFFF); //çàëèâêà áåëûì
|
|
||||||
WriteText(i*64+197,j*64+57+50,0,0,off,10);
|
|
||||||
}
|
|
||||||
TVScroll();
|
|
||||||
}*/
|
|
||||||
|
|
||||||
|
|
||||||
void Line_ReDraw(dword color, filenum){
|
void Line_ReDraw(dword color, filenum){
|
||||||
dword y=filenum*18+57; //ïîëîæåíèå òåêñòà ïî Y;
|
dword y;//ïîëîæåíèå òåêñòà ïî Y;
|
||||||
if (rename_active==1)
|
if (rename_active==1)
|
||||||
{
|
{
|
||||||
rename_active=0;
|
rename_active=0;
|
||||||
edit2.flags=64;
|
edit2.flags=64;
|
||||||
DefineButton(197,curbtn*18+57,onLeft(22,197),18,curbtn+201+BT_HIDE+BT_NOFRAME,0xFFFFFF);
|
DefineButton(197,curbtn*18+57,onLeft(22,197),18,curbtn+201+BT_HIDE+BT_NOFRAME,0xFFFFFF);
|
||||||
IF (filenum==100) filenum=curbtn; ELSE
|
IF (filenum==100) filenum=curbtn; else
|
||||||
{
|
{
|
||||||
copystr(#path,#temp);
|
copystr(#path,#temp);
|
||||||
copystr(#file_name,#temp+strlen(#temp));
|
copystr(#file_name,#temp+strlen(#temp));
|
||||||
IF (strcmp(#file_path,#temp)<>0) && (strlen(#file_name)>0)
|
if (strcmp(#file_path,#temp)<>0) && (strlen(#file_name)>0)
|
||||||
{ CopyFile(#file_path,#temp); Del_File(true); }
|
IF (isdir)
|
||||||
|
{
|
||||||
|
//Del_File(true);
|
||||||
|
DeleleFile(#file_path);
|
||||||
|
IF (EAX<>0) {DrawFlatButton(Form.width-200+197/2,160,200,80,0,0xFFB6B5, "Error. Folder isn't empty."); Pause(200);}
|
||||||
|
ELSE CreateFolder(#temp);
|
||||||
|
Open_Dir(#path,1);
|
||||||
|
}
|
||||||
|
ELSE { CopyFile(#file_path,#temp); Del_File(true); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
y=filenum*18+57;
|
||||||
//äà, ÿ íå ñïîðþ ÷òî èçâðàò, íî ïåðåðèñîâêà çàòî ìàëåíüêàÿ
|
//äà, ÿ íå ñïîðþ ÷òî èçâðàò, íî ïåðåðèñîâêà çàòî ìàëåíüêàÿ
|
||||||
DrawBar(197,y,3,18,color);
|
DrawBar(197,y,3,18,color);
|
||||||
DrawBar(200,y,16,2,color);
|
DrawBar(200,y,16,2,color);
|
||||||
@ -400,15 +416,15 @@ void Line_ReDraw(dword color, filenum){
|
|||||||
EAX=ESDWORD[off-40];
|
EAX=ESDWORD[off-40];
|
||||||
$shr eax,4
|
$shr eax,4
|
||||||
$and eax,1
|
$and eax,1
|
||||||
IF (color==videlenie) isdir=EAX; //íàäî îáüåäèíèòü ñ òåì øî ñíèçó
|
IF (color==videlenie) isdir=EAX;
|
||||||
if (!EAX)
|
if (!EAX)
|
||||||
{
|
{
|
||||||
temp_int = Put_icon(off+strlen(off)-4, y+2);
|
temp_int = Put_icon(off+strlen(off)-4, y+2);
|
||||||
WriteText(7-strlen(ConvertSize(ESDWORD[off-8]))*6+onLeft(75,0),y+6,0x80,0,ConvertSize(ESDWORD[off-8]),0); //size
|
WriteText(7-strlen(ConvertSize(ESDWORD[off-8]))*6+onLeft(75,0),y+6,0x80,0,ConvertSize(ESDWORD[off-8]),0); //size
|
||||||
} ELSE IF (strcmp("..",off)==0) temp_int=Put_icon("..", y+2); ELSE temp_int=Put_icon("<DIR>", y+2);
|
} ELSE IF (!strcmp("..",off)) temp_int=Put_icon("..", y+2); ELSE temp_int=Put_icon("<DIR>", y+2);
|
||||||
IF (color==videlenie)
|
IF (color==videlenie)
|
||||||
{
|
{
|
||||||
IconFairing(temp_int, y+2, videlenie); //çàêðàøèâàåì èêîíêó
|
IconFairing(temp_int, y+2); //çàêðàøèâàåì èêîíêó
|
||||||
copystr(#path,#file_path);
|
copystr(#path,#file_path);
|
||||||
copystr(off,#file_name);
|
copystr(off,#file_name);
|
||||||
copystr(off,#file_path+strlen(#file_path)); //èòàê, file_path=ôàéëó, ò.ê. ïî-óìîë÷àíèþ ýòî ïðîãà
|
copystr(off,#file_path+strlen(#file_path)); //èòàê, file_path=ôàéëó, ò.ê. ïî-óìîë÷àíèþ ýòî ïðîãà
|
||||||
@ -424,13 +440,8 @@ void Line_ReDraw(dword color, filenum){
|
|||||||
|
|
||||||
void Open_Dir(dword path_,redraw){
|
void Open_Dir(dword path_,redraw){
|
||||||
IF (buf) free(buf);
|
IF (buf) free(buf);
|
||||||
open_dir_70.param3 = 6898; //filenum
|
|
||||||
buf = malloc(2097152);
|
buf = malloc(2097152);
|
||||||
open_dir_70.param4 = buf;
|
ReadDir(6898, buf, path_);
|
||||||
open_dir_70.name = path_;
|
|
||||||
$mov eax,70
|
|
||||||
$mov ebx,#open_dir_70.func
|
|
||||||
$int 0x40
|
|
||||||
kolichestvo=EBX;
|
kolichestvo=EBX;
|
||||||
//
|
//
|
||||||
if (kolichestvo<>-1) && (redraw>0)
|
if (kolichestvo<>-1) && (redraw>0)
|
||||||
@ -496,20 +507,19 @@ dword onTop(dword down,up) {return Form.height-skin_width-down-up;}
|
|||||||
|
|
||||||
void Del_Form()
|
void Del_Form()
|
||||||
{
|
{
|
||||||
IF (isdir==true) return; //ïàïêè ïîêà ÷òî óäàëÿòü íå óìååì
|
|
||||||
temp_int=Form.width-200+197/2;
|
temp_int=Form.width-200+197/2;
|
||||||
//òèïà îêíî
|
//òèïà îêíî
|
||||||
FOR (i=5;i<11;i++) DeleteButton(201+i); //óäàëÿåì êíîïêè ïîä ôîðìîé
|
FOR (i=5;i<11;i++) DeleteButton(201+i); //óäàëÿåì êíîïêè ïîä ôîðìîé
|
||||||
DrawFlatButton(temp_int,160,200,80,0,0xE4DFE1, ""); //ôîðìà
|
DrawFlatButton(temp_int,160,200,80,0,0xE4DFE1, ""); //ôîðìà
|
||||||
WriteText(temp_int+19,175,0x80,0,"Do you really want to delete",28);
|
WriteText(temp_int+19,175,0x80,0,"Do you really want to delete",0);
|
||||||
IF (strlen(#file_name)<28)
|
IF (strlen(#file_name)<28)
|
||||||
{
|
{
|
||||||
WriteText(strlen(#file_name)*6+temp_int+20,190,0x80,0,"?",1);
|
WriteText(strlen(#file_name)*6+temp_int+20,190,0x80,0,"?",0);
|
||||||
WriteText(temp_int+20,190,0x80,0,#file_name,24); //ïèøåì èìÿ
|
WriteText(temp_int+20,190,0x80,0,#file_name,0); //ïèøåì èìÿ
|
||||||
}
|
}
|
||||||
ELSE
|
ELSE
|
||||||
{
|
{
|
||||||
WriteText(164+temp_int,190,0x80,0,"...?",4);
|
WriteText(164+temp_int,190,0x80,0,"...?",0);
|
||||||
WriteText(temp_int+20,190,0,0,#file_name,24); //ïèøåì èìÿ
|
WriteText(temp_int+20,190,0,0,#file_name,24); //ïèøåì èìÿ
|
||||||
}
|
}
|
||||||
//êíîïî÷êè
|
//êíîïî÷êè
|
||||||
@ -518,24 +528,18 @@ void Del_Form()
|
|||||||
del_active=1;
|
del_active=1;
|
||||||
}
|
}
|
||||||
|
|
||||||
f70 del_file_70;
|
//f70 del_file_70;
|
||||||
void Del_File(byte dodel)
|
void Del_File(byte dodel)
|
||||||
{
|
{
|
||||||
IF (dodel==true){
|
IF (dodel==true)
|
||||||
del_file_70.func = 8;
|
{
|
||||||
del_file_70.param1 = 0;
|
DeleleFile(#file_path);
|
||||||
del_file_70.param2 = 0;
|
IF (EAX<>0) && (isdir==true) {DrawFlatButton(temp_int,160,200,80,0,0xFFB6B5, "Error. Folder isn't empty."); Pause(200);}
|
||||||
del_file_70.param3 = 0;
|
}
|
||||||
del_file_70.param4 = 0;
|
del_active=0;
|
||||||
del_file_70.rezerv = 0;
|
DeleteButton(301); DeleteButton(302); //óäàëÿåì êíîïî÷êè Yes/No
|
||||||
del_file_70.name = #file_path;
|
Open_Dir(#path,1);
|
||||||
$mov eax,70
|
}
|
||||||
$mov ebx,#del_file_70.func
|
|
||||||
$int 0x40}
|
|
||||||
del_active=0;
|
|
||||||
DeleteButton(301); DeleteButton(302); //óäàëÿåì êíîïî÷êè Yes/No
|
|
||||||
Open_Dir(#path,1);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Paste()
|
void Paste()
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#include "imgs\logo.txt"
|
#include "imgs\logo.txt"
|
||||||
|
|
||||||
void authors()
|
void authors()
|
||||||
{
|
{
|
||||||
loop()
|
loop()
|
||||||
{
|
{
|
||||||
switch(WaitEvent())
|
switch(WaitEvent())
|
||||||
@ -12,12 +12,11 @@ void authors()
|
|||||||
WindowRedrawStatus(1);
|
WindowRedrawStatus(1);
|
||||||
DefineAndDrawWindow(500,200,181,256,0x04,0x10EFEBEF,0,0,"About Eolite");
|
DefineAndDrawWindow(500,200,181,256,0x04,0x10EFEBEF,0,0,"About Eolite");
|
||||||
DrawBar(5,0,172,50,0x8494C4); //ãîëóáîå ñçàäè
|
DrawBar(5,0,172,50,0x8494C4); //ãîëóáîå ñçàäè
|
||||||
//PutImage(#logo,85,85,48,7);
|
|
||||||
PutPaletteImage(#logo,85,85,48,7,#logo_pal);
|
PutPaletteImage(#logo,85,85,48,7,#logo_pal);
|
||||||
WriteText(38,100,0x80,0xBF40BF,"Eolite v0.97 beta7",0);
|
WriteText(32,100,0x80,0xBF40BF,"Eolite v0.97.1 beta7",0);
|
||||||
WriteText(68,120,0x80,0,"Authors:",0);
|
WriteText(60,120,0x80,0,"Developers:",0);
|
||||||
WriteText(44,130,0x80,0,"Leency & Veliant",0);
|
WriteText(44,130,0x80,0,"Leency & Veliant",0);
|
||||||
WriteText(50,140,0x80,0,"KolibriOS Team",0);
|
WriteText(35,140,0x80,0,"Lrz, Diamond, Nable",0);
|
||||||
WriteText(26,160,0x80,0,"Made using C-- in 2008",0);
|
WriteText(26,160,0x80,0,"Made using C-- in 2008",0);
|
||||||
WriteText(23,170,0x80,0,"Visit www.kolibrios.org",0);
|
WriteText(23,170,0x80,0,"Visit www.kolibrios.org",0);
|
||||||
DrawFlatButton(90,190,70,22,2,0xE4DFE1, "Close");
|
DrawFlatButton(90,190,70,22,2,0xE4DFE1, "Close");
|
||||||
@ -29,7 +28,7 @@ void authors()
|
|||||||
|
|
||||||
dword ConvertSize(dword bytes)
|
dword ConvertSize(dword bytes)
|
||||||
{
|
{
|
||||||
byte size_prefix[7], temp[3];
|
char size_prefix[7], temp[3];
|
||||||
IF (bytes>=1073741824) copystr(" Gb",#temp);
|
IF (bytes>=1073741824) copystr(" Gb",#temp);
|
||||||
ELSE IF (bytes>=1048576) copystr(" Mb",#temp);
|
ELSE IF (bytes>=1048576) copystr(" Mb",#temp);
|
||||||
ELSE IF (bytes>=1024) copystr(" Kb",#temp);
|
ELSE IF (bytes>=1024) copystr(" Kb",#temp);
|
||||||
|
@ -1,55 +1,36 @@
|
|||||||
void IconFairing(dword filenum, y, videlenie)
|
void IconFairing(int filenum, y)
|
||||||
{
|
{
|
||||||
if (filenum<5) //ôàéëèê
|
switch(filenum)
|
||||||
{
|
{
|
||||||
DrawBar(200,y,2,15,videlenie);
|
case 0...4: //ôàéëèê
|
||||||
DrawBar(214,y,2,15,videlenie);
|
DrawBar(200,y,2,15,videlenie);
|
||||||
DrawBar(210,y,4,1,videlenie);//ëå
|
DrawBar(214,y,2,15,videlenie);
|
||||||
DrawBar(211,y+1,3,1,videlenie);//ñåí
|
DrawBar(210,y,4,1,videlenie);
|
||||||
DrawBar(212,y+2,2,1,videlenie);//êà
|
DrawBar(211,y+1,3,1,videlenie);
|
||||||
DrawBar(213,y+3,1,1,videlenie);//
|
DrawBar(212,y+2,2,1,videlenie);
|
||||||
}
|
PutPixel(213,y+3,videlenie);
|
||||||
if (filenum==16) || (filenum==17) //ïàïêà
|
return;
|
||||||
{
|
case 16...17: //ïàïêà
|
||||||
DrawBar(200,y,1,15,videlenie); //ñëåâà ëèíèÿ
|
DrawBar(200,y,1,15,videlenie);
|
||||||
DrawBar(208,y,8,2,videlenie); //ñâåðõó ñïðàâà ëèíèÿ
|
DrawBar(208,y,8,2,videlenie);
|
||||||
IF (filenum==17) DrawBar(211,y+1,1,1,0x1A7B17); //çåë¸íàÿ òî÷êà ñòðåëêè
|
IF (filenum==17) PutPixel(211,y+1,0x1A7B17); //çåë¸íàÿ òî÷êà ñòðåëêè
|
||||||
DrawBar(201,y+13,15,2,videlenie); //ñíèçó ëèíèÿ
|
DrawBar(201,y+13,15,2,videlenie);
|
||||||
//.òî÷êè
|
PutPixel(201,y,videlenie); //.òî÷êè
|
||||||
PutPixel(201,y,videlenie); //ñâåðõó ñëåâà òî÷êà
|
PutPixel(207,y,videlenie);
|
||||||
PutPixel(207,y,videlenie); //ñâåðõó ñïðàâà òî÷êà
|
PutPixel(215,y+2,videlenie);
|
||||||
PutPixel(215,y+2,videlenie); //êàêàÿ ðàçíèöà ãäå
|
PutPixel(201,y+12,videlenie);
|
||||||
PutPixel(201,y+12,videlenie); //ñëåâà ñíèçó òî÷êà
|
PutPixel(215,y+12,videlenie);
|
||||||
PutPixel(215,y+12,videlenie); //ñïðàâà ñíèçó òî÷êà
|
return;
|
||||||
}
|
case 13: //skin
|
||||||
IF (filenum==13) PutPixel(215,y,videlenie); //skin
|
PutPixel(215,y,videlenie);
|
||||||
IF (filenum==20) //êàðòðèäæ
|
return;
|
||||||
{
|
case 11: //asm
|
||||||
DrawBar(200,y,16,2,videlenie);
|
DrawBar(201,y,1,15,videlenie);
|
||||||
DrawBar(200,y+11,1,2,videlenie);
|
case 14: //video
|
||||||
DrawBar(215,y+11,1,2,videlenie);
|
DrawBar(200,y,1,15,videlenie);
|
||||||
DrawBar(200,y+13,16,2,videlenie);
|
DrawBar(215,y,1,15,videlenie);
|
||||||
}
|
return;
|
||||||
IF (filenum==14) //video
|
case 15: //àðõèâ
|
||||||
{DrawBar(200,y,1,15,videlenie); DrawBar(215,y,1,15,videlenie);}
|
|
||||||
IF (filenum==21) //äèñêåòà
|
|
||||||
{ PutPixel(200,y,videlenie); PutPixel(215,y,videlenie); }
|
|
||||||
IF (filenum==19) //èçîáðàæåíèå
|
|
||||||
DrawBar(200,y+14,16,1,videlenie);
|
|
||||||
if (filenum==22) //áèáëèîòåêà
|
|
||||||
{
|
|
||||||
DrawBar(200,y,16,1,videlenie); //ñâåðõó ñëåâà
|
|
||||||
DrawBar(200,y+1,3,1,videlenie);
|
|
||||||
DrawBar(200,y+2,2,1,videlenie);
|
|
||||||
PutPixel(200,y+3,videlenie);
|
|
||||||
//
|
|
||||||
PutPixel(215,y+11,videlenie); //ñïðàâà ñïðàâà
|
|
||||||
DrawBar(214,y+12,2,1,videlenie);
|
|
||||||
DrawBar(213,y+13,3,1,videlenie);
|
|
||||||
DrawBar(212,y+14,4,1,videlenie);
|
|
||||||
}
|
|
||||||
if (filenum==15) //àðõèâ
|
|
||||||
{
|
|
||||||
PutPixel(200,y,videlenie); //ñïðàâà ñïðàâà
|
PutPixel(200,y,videlenie); //ñïðàâà ñïðàâà
|
||||||
DrawBar(213,y,3,1,videlenie);
|
DrawBar(213,y,3,1,videlenie);
|
||||||
DrawBar(214,y+1,2,1,videlenie);
|
DrawBar(214,y+1,2,1,videlenie);
|
||||||
@ -58,9 +39,34 @@ void IconFairing(dword filenum, y, videlenie)
|
|||||||
DrawBar(200,y+12,2,1,videlenie);
|
DrawBar(200,y+12,2,1,videlenie);
|
||||||
DrawBar(200,y+13,3,1,videlenie);
|
DrawBar(200,y+13,3,1,videlenie);
|
||||||
DrawBar(200,y+14,4,1,videlenie);
|
DrawBar(200,y+14,4,1,videlenie);
|
||||||
}
|
return;
|
||||||
|
case 19: //èçîáðàæåíèå
|
||||||
|
DrawBar(200,y+14,16,1,videlenie);
|
||||||
|
return;
|
||||||
|
case 20: //êàðòðèäæ
|
||||||
|
DrawBar(200,y,16,2,videlenie);
|
||||||
|
DrawBar(200,y+11,1,2,videlenie);
|
||||||
|
DrawBar(215,y+11,1,2,videlenie);
|
||||||
|
DrawBar(200,y+13,16,2,videlenie);
|
||||||
|
return;
|
||||||
|
case 21: //äèñêåòà
|
||||||
|
PutPixel(200,y,videlenie);
|
||||||
|
PutPixel(215,y,videlenie);
|
||||||
|
return;
|
||||||
|
case 22: //áèáëèîòåêà
|
||||||
|
DrawBar(200,y,16,1,videlenie); //ñâåðõó ñëåâà
|
||||||
|
DrawBar(200,y+1,3,1,videlenie);
|
||||||
|
DrawBar(200,y+2,2,1,videlenie);
|
||||||
|
PutPixel(200,y+3,videlenie);
|
||||||
|
PutPixel(215,y+11,videlenie); //ñïðàâà ñïðàâà
|
||||||
|
DrawBar(214,y+12,2,1,videlenie);
|
||||||
|
DrawBar(213,y+13,3,1,videlenie);
|
||||||
|
DrawBar(212,y+14,4,1,videlenie);
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#include "imgs\icons.txt"
|
#include "imgs\icons.txt"
|
||||||
dword Put_icon(dword extension, yy)
|
dword Put_icon(dword extension, yy)
|
||||||
{
|
{
|
||||||
|
@ -19,7 +19,6 @@ char param[256]="";
|
|||||||
#define evButton 3
|
#define evButton 3
|
||||||
#define evKey 2
|
#define evKey 2
|
||||||
#define evReDraw 1
|
#define evReDraw 1
|
||||||
#define evNet 8
|
|
||||||
|
|
||||||
//Button options
|
//Button options
|
||||||
#define BT_DEL 0x80000000
|
#define BT_DEL 0x80000000
|
||||||
@ -34,7 +33,7 @@ char param[256]="";
|
|||||||
|
|
||||||
int vert;
|
int vert;
|
||||||
struct mouse{
|
struct mouse{
|
||||||
dword x,y,lkm,pkm;
|
int x,y,lkm,pkm;
|
||||||
void get();
|
void get();
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -47,7 +46,7 @@ void mouse::get()
|
|||||||
$shr eax, 16
|
$shr eax, 16
|
||||||
$and ebx,0x0000FFFF
|
$and ebx,0x0000FFFF
|
||||||
x = EAX;
|
x = EAX;
|
||||||
y = EBX;
|
y = EBX-skin_width;
|
||||||
EAX = 37;
|
EAX = 37;
|
||||||
EBX = 2;
|
EBX = 2;
|
||||||
$int 0x40
|
$int 0x40
|
||||||
@ -67,17 +66,6 @@ void mouse::get()
|
|||||||
vert = EBX;
|
vert = EBX;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
struct f70{
|
|
||||||
dword func;
|
|
||||||
dword param1;
|
|
||||||
dword param2;
|
|
||||||
dword param3;
|
|
||||||
dword param4;
|
|
||||||
char rezerv;
|
|
||||||
dword name;
|
|
||||||
};
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
struct BDVK{
|
struct BDVK{
|
||||||
dword attr;
|
dword attr;
|
||||||
@ -103,15 +91,15 @@ struct proc_info{
|
|||||||
word status_slot,rezerv3;
|
word status_slot,rezerv3;
|
||||||
dword work_left,work_top,work_width,work_height;
|
dword work_left,work_top,work_width,work_height;
|
||||||
char status_window;
|
char status_window;
|
||||||
void getme();
|
void GetInfo(dword ECX);
|
||||||
|
#define SelfInfo -1
|
||||||
};
|
};
|
||||||
|
|
||||||
void proc_info::getme()
|
void proc_info::GetInfo(dword ECX)
|
||||||
{
|
{
|
||||||
EAX = 9;
|
EAX = 9;
|
||||||
EBX = #use_cpu;
|
EBX = #use_cpu;
|
||||||
ECX = -1;
|
$int 0x40
|
||||||
$int 0x40
|
|
||||||
}
|
}
|
||||||
//-------------------------------------------------------------------------------
|
//-------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -120,11 +108,11 @@ inline fastcall dword WaitEvent(){
|
|||||||
$int 0x40
|
$int 0x40
|
||||||
}
|
}
|
||||||
|
|
||||||
/*inline fastcall void SetEventMask(dword EBX){
|
/*inline fastcall void SetEventMask(dword EBX)
|
||||||
$mov eax,40
|
{
|
||||||
//$mov ebx,100111b
|
EAX = 40;
|
||||||
$int 0x40
|
$int 0x40
|
||||||
}*/
|
} */
|
||||||
|
|
||||||
inline fastcall word GetKey(){
|
inline fastcall word GetKey(){
|
||||||
EAX = 2; // just read this key from buffer
|
EAX = 2; // just read this key from buffer
|
||||||
@ -143,11 +131,10 @@ inline fastcall void ExitProcess(){
|
|||||||
$int 0x40
|
$int 0x40
|
||||||
}
|
}
|
||||||
|
|
||||||
/*void Pause(dword EBX)
|
void Pause(dword EBX){
|
||||||
{ //<2F> 㧠, ¢ á®âëå ¤®«ïå ᥪã¤ë EBX = value
|
$mov eax, 5 //<2F> 㧠, ¢ á®âëå ¤®«ïå ᥪã¤ë
|
||||||
$mov eax, 5
|
|
||||||
$int 0x40
|
$int 0x40
|
||||||
}*/
|
}
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
void DefineAndDrawWindow(dword x,y,sizeX,sizeY,byte mainAreaType,dword
|
void DefineAndDrawWindow(dword x,y,sizeX,sizeY,byte mainAreaType,dword
|
||||||
@ -344,51 +331,3 @@ void PutPaletteImage(dword EBX,w,h,x,y, EDI)
|
|||||||
$int 0x40
|
$int 0x40
|
||||||
}
|
}
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
f70 CopyFile_f;
|
|
||||||
BDVK CopyFile_atr;
|
|
||||||
inline fastcall dword CopyFile(dword EBX,ECX)
|
|
||||||
{
|
|
||||||
dword s=EBX, d=ECX, cBufer=0;
|
|
||||||
CopyFile_f.func = 5;
|
|
||||||
CopyFile_f.param1 = 0;
|
|
||||||
CopyFile_f.param2 = 0;
|
|
||||||
CopyFile_f.param3 = 0;
|
|
||||||
CopyFile_f.param4 = #CopyFile_atr;
|
|
||||||
CopyFile_f.rezerv = 0;
|
|
||||||
CopyFile_f.name = s;
|
|
||||||
$mov eax, 70
|
|
||||||
$mov ebx, #CopyFile_f
|
|
||||||
$int 0x40
|
|
||||||
|
|
||||||
if (!EAX)
|
|
||||||
{
|
|
||||||
cBufer = malloc(CopyFile_atr.sizelo);
|
|
||||||
CopyFile_f.func = 0;
|
|
||||||
CopyFile_f.param1 = 0;
|
|
||||||
CopyFile_f.param2 = 0;
|
|
||||||
CopyFile_f.param3 = CopyFile_atr.sizelo;
|
|
||||||
CopyFile_f.param4 = cBufer;
|
|
||||||
CopyFile_f.rezerv = 0;
|
|
||||||
CopyFile_f.name = s;
|
|
||||||
$mov eax, 70
|
|
||||||
$mov ebx, #CopyFile_f
|
|
||||||
$int 0x40
|
|
||||||
|
|
||||||
IF (!EAX)
|
|
||||||
{
|
|
||||||
CopyFile_f.func = 2;
|
|
||||||
CopyFile_f.param1 = 0;
|
|
||||||
CopyFile_f.param2 = 0;
|
|
||||||
CopyFile_f.param3 = CopyFile_atr.sizelo;
|
|
||||||
CopyFile_f.param4 = cBufer;
|
|
||||||
CopyFile_f.rezerv = 0;
|
|
||||||
CopyFile_f.name = d;
|
|
||||||
$mov eax, 70
|
|
||||||
$mov ebx, #CopyFile_f
|
|
||||||
$int 0x40
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user