Eolite 1.88: copying in another thread, copying folders

git-svn-id: svn://kolibrios.org@3444 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Kirill Lipatov (Leency) 2013-04-04 17:07:38 +00:00
parent 75a54cbc0f
commit 99555c3bb5
15 changed files with 257 additions and 255 deletions

View File

@ -9,7 +9,7 @@
unsigned char speaker[23*40*3]= FROM "speaker.raw"; unsigned char speaker[23*40*3]= FROM "speaker.raw";
char title[]= "Dictionary v1.3"; char title[]= "Dictionary v1.31";
char direction[] = "Translate direction:"; char direction[] = "Translate direction:";
char translate_caption[] = "Translate"; char translate_caption[] = "Translate";
char dict_not_found[] = "Dictionary not found"; char dict_not_found[] = "Dictionary not found";
@ -62,7 +62,7 @@ void main()
case evButton: case evButton:
id=GetButtonID(); id=GetButtonID();
if (id==1) ExitProcess(); if (id==1) {KillProcess(speaker_id); ExitProcess();}
if (id==10) { Translate(); DrawTranslation(); } if (id==10) { Translate(); DrawTranslation(); }
if (id==11) ShowDictList(); if (id==11) ShowDictList();
if (id==12) DrawWindowContent(); if (id==12) DrawWindowContent();
@ -229,7 +229,7 @@ void ShowDictList()
int j, fcount, error; int j, fcount, error;
free(dir_buf); free(dir_buf);
error = GetDir(#dir_buf, #fcount, #dict_folder); error = GetDir(#dir_buf, #fcount, #dict_folder, DIRS_ONLYREAL);
if (!error) if (!error)
{ {
DefineButton(0,0, Form.width,Form.height, 12+BT_HIDE+BT_NOFRAME, sc.work_button); DefineButton(0,0, Form.width,Form.height, 12+BT_HIDE+BT_NOFRAME, sc.work_button);

View File

@ -19,15 +19,13 @@
#include "imgs\toolbar.txt" #include "imgs\toolbar.txt"
#include "imgs\left_p.txt" #include "imgs\left_p.txt"
//for OpenDir
#define ONLY_SHOW 0
#define WITH_REDRAW 1
#define ONLY_OPEN 2
#define TITLE "Eolite File Manager v1.81" enum {ONLY_SHOW, WITH_REDRAW, ONLY_OPEN}; //OpenDir
#define ABOUT_TITLE "Eolite v1.81"
#define TITLE "Eolite File Manager v1.88"
#define ABOUT_TITLE "Eolite v1.88"
dword col_work = 0xE4DFE1; dword col_work = 0xE4DFE1;
dword col_border = 0x819FC5; dword col_border = 0x9098B0; //A0A0B8; //0x819FC5;
dword col_padding = 0xC8C9C9; dword col_padding = 0xC8C9C9;
dword col_selec = 0x94AECE; dword col_selec = 0x94AECE;
dword col_lpanel = 0x00699C; dword col_lpanel = 0x00699C;
@ -42,10 +40,8 @@ byte
path[4096], path[4096],
file_path[4096], file_path[4096],
file_name[256], file_name[256],
copy_file[4096],
temp[4096]; temp[4096];
byte byte
cut_active=0,
rename_active=0, rename_active=0,
del_active=0, del_active=0,
show_dev_name=1, show_dev_name=1,
@ -71,10 +67,11 @@ PathShow_data FileShow = {0, 56,215, 6, 100, 0, 0, 0x0, 0xFFFfff, #file_name, #t
#include "include\left_panel.h" #include "include\left_panel.h"
#include "include\history.h" #include "include\history.h"
#include "include\file_menu.h" #include "include\file_menu.h"
#include "include\copypaste.h"
void main() void main()
{ {
word key, id, can_show, can_select; word key, id, can_show, can_select, m_selected;
files.line_h=18; files.line_h=18;
mem_Init(); mem_Init();
@ -95,13 +92,14 @@ void main()
case evMouse: case evMouse:
IF (del_active) break; IF (del_active) break;
id=GetProcessSlot(Form.ID); id=GetProcessSlot(Form.ID);
IF (id<>GetActiveProcess()) || (Form.status_window>2) break; IF (id!=GetActiveProcess()) || (Form.status_window>2) break;
IF (rename_active) { edit_box_mouse stdcall(#edit2); break; } IF (rename_active) { edit_box_mouse stdcall(#edit2); break; }
m.get(); m.get();
if (m.x > files.x) && (m.x < files.x + files.w) && (m.y > files.y) && (m.y < files.y+files.h) if (m.x > files.x) && (m.x < files.x + files.w) && (m.y > files.y) && (m.y < files.y+files.h) && (!can_select)
{ {
m_selected = m.y - 57 / files.line_h;
if (m.lkm) can_select = 1; if (m.lkm) can_select = 1;
if (m.pkm) if (m.pkm)
{ {
@ -116,7 +114,8 @@ void main()
can_select = 0; can_select = 0;
if (m.y<57) break; if (m.y<57) break;
id = m.y - 57 / files.line_h; id = m.y - 57 / files.line_h;
if (files.current!=id) FileList_ReDraw(id-files.current); if (id!=m_selected) {can_show=0; break;}
if (files.current!=id) List_Current(id-files.current);
else Open(); else Open();
}; };
// } select/open file // } select/open file
@ -127,7 +126,7 @@ void main()
can_show = 0; can_show = 0;
if (m.y<57) break; if (m.y<57) break;
SwitchToAnotherThread(); SwitchToAnotherThread();
CreateThread(#FileMenu,#stak2); CreateThread(#FileMenu,#menu_stak);
break; break;
} }
// } file menu // } file menu
@ -178,7 +177,7 @@ void main()
files.first = m.y -j -57 * files.count; files.first = m.y -j -57 * files.count;
files.first /= onTop(22,57); files.first /= onTop(22,57);
IF (files.visible+files.first>files.count) files.first=files.count-files.visible; IF (files.visible+files.first>files.count) files.first=files.count-files.visible;
IF (id<>files.first) List_ReDraw(); IF (id!=files.first) List_ReDraw();
} }
break; break;
//Button pressed----------------------------------------------------------------------------- //Button pressed-----------------------------------------------------------------------------
@ -208,11 +207,13 @@ void main()
Dir_Up(); Dir_Up();
break; break;
case 24: //cut case 24: //cut
key=24; Copy(#file_path, NOCUT);
break;
case 25: //copy case 25: //copy
goto CTRLC_MARK; Copy(#file_path, CUT);
break;
case 26: //paste case 26: //paste
Paste(); CreateThread(#Paste,#copy_stak);
break; break;
case 31...33: //sort case 31...33: //sort
IF(sort_num==1) DrawFilledBar(onLeft(192,168)/2+210,42,6,10); IF(sort_num==1) DrawFilledBar(onLeft(192,168)/2+210,42,6,10);
@ -222,16 +223,16 @@ void main()
Open_Dir(#path,WITH_REDRAW); Open_Dir(#path,WITH_REDRAW);
break; break;
case 50...60: //Actions case 50...60: //Actions
ActionsProcess(id-50); FnProcess(id-50);
break; break;
case 100...120: case 100...120:
DEVICE_MARK: DEVICE_MARK:
DrawRectangle3D(17,id-100*16+74,159,16, 0, 0); //auaaeaiea DrawRectangle(17,id-100*16+74,159,16, 0); //auaaeaiea
strcpy(#path, #disk_list[id-100].Item); strcpy(#path, #disk_list[id-100].Item);
files.first=files.current=0; files.first=files.current=0;
Open_Dir(#path,1); Open_Dir(#path,WITH_REDRAW);
pause(5); pause(5);
DrawRectangle3D(17,id-100*16+74,159,16, 0xFFFFFF, 0xFFFFFF); DrawRectangle(17,id-100*16+74,159,16, 0xFFFFFF);
break; break;
case 130...160: case 130...160:
tmp_disk_del_param[1]=disk_list[id-130].Item[4]; tmp_disk_del_param[1]=disk_list[id-130].Item[4];
@ -253,7 +254,7 @@ void main()
IF (key==027) Del_File(false); IF (key==027) Del_File(false);
break; break;
} }
IF (edit2.flags<>64) && (key<>13) && (key<>27) IF (edit2.flags!=64) && (key!=13) && (key!=27)
{ {
EAX=key<<8; EAX=key<<8;
edit_box_key stdcall (#edit2); edit_box_key stdcall (#edit2);
@ -279,14 +280,13 @@ void main()
RunProgram("/sys/File Managers/Eolite", #path); RunProgram("/sys/File Managers/Eolite", #path);
break; break;
case 024: //Ctrl+X case 024: //Ctrl+X
Copy(#file_path, CUT);
break;
case 003: //Ctrl+C case 003: //Ctrl+C
CTRLC_MARK: Copy(#file_path, NOCUT);
IF (itdir) break;
strcpy(#copy_file, #file_path);
IF (key==24) cut_active=1; ELSE cut_active=0;
break; break;
case 022: //Ctrl+V case 022: //Ctrl+V
Paste(); CreateThread(#Paste,#copy_stak);
break; break;
case 027: //Esc case 027: //Esc
IF (rename_active==1) ReName(false); IF (rename_active==1) ReName(false);
@ -296,10 +296,10 @@ void main()
Open(); Open();
break; break;
case 178: //up case 178: //up
FileList_ReDraw(-1); List_Current(-1);
break; break;
case 177: //down case 177: //down
FileList_ReDraw(1); List_Current(1);
break; break;
case 180: //home case 180: //home
files.first=0; files.first=0;
@ -312,16 +312,16 @@ void main()
List_ReDraw(); List_ReDraw();
break; break;
case 183: //Page Down case 183: //Page Down
FileList_ReDraw(files.visible-1); List_Current(files.visible-1);
break; break;
case 184: //Page Up case 184: //Page Up
FileList_ReDraw(-files.visible+1); List_Current(-files.visible+1);
break; break;
case 182: //del case 182: //del
Del_Form(); Del_Form();
break; break;
case 050...059: //F1-F10 case 050...059: //F1-F10
ActionsProcess(key-49); FnProcess(key-49);
break; break;
default: default:
for (i=files.current+files.first+1; i<files.count; i++) for (i=files.current+files.first+1; i<files.count; i++)
@ -329,39 +329,40 @@ void main()
strcpy(#temp, file_mas[i]*304+buf+72); strcpy(#temp, file_mas[i]*304+buf+72);
IF (temp[0]==key) || (temp[0]==key-32) IF (temp[0]==key) || (temp[0]==key-32)
{ {
FileList_ReDraw(i-files.current-files.first); List_Current(i-files.current-files.first);
break; break;
} }
} }
} }
break; break;
case evReDraw: case evReDraw:
DefineAndDrawWindow(40,20,550,500,0x73,col_work,TITLE);
GetProcessInfo(#Form, SelfInfo);
if (Form.status_window>2) break;
files.SetSizes(192, 57, onLeft(192,27), onTop(57,6), disc_num*16+195,files.line_h);
if (Form.height < files.min_h) MoveSize(OLD,OLD,OLD,files.min_h);
if (Form.width<480) MoveSize(OLD,OLD,480,OLD);
GetProcessInfo(#Form, SelfInfo); //if win_size changed
draw_window(); draw_window();
} }
} }
inline fastcall void draw_window() void draw_window()
{ {
//toolbar DefineAndDrawWindow(40,20,550,500,0x73,col_work,TITLE);
GetProcessInfo(#Form, SelfInfo);
if (Form.status_window>2) return;
files.SetSizes(192, 57, onLeft(192,27), onTop(57,6), disc_num*16+195,files.line_h);
if (Form.height < files.min_h) MoveSize(OLD,OLD,OLD,files.min_h);
if (Form.width<480) MoveSize(OLD,OLD,480,OLD);
GetProcessInfo(#Form, SelfInfo); //if win_size changed
PutPaletteImage(#toolbar,246,34,0,0,8,#toolbar_pal); PutPaletteImage(#toolbar,246,34,0,0,8,#toolbar_pal);
DrawBar(127, 8, 1, 25, col_border);
for (j=0; j<3; j++) DefineButton(toolbar_buttons_x[j]+2,5+2,31-5,29-5,21+j+BT_HIDE,col_work); for (j=0; j<3; j++) DefineButton(toolbar_buttons_x[j]+2,5+2,31-5,29-5,21+j+BT_HIDE,col_work);
for (j=3; j<6; j++) DefineButton(toolbar_buttons_x[j],5,31,29,21+j+BT_HIDE,col_work); for (j=3; j<6; j++) DefineButton(toolbar_buttons_x[j],5,31,29,21+j+BT_HIDE,col_work);
DrawBar(246,0,onLeft(246,60),12, col_work); //ôîí íàä ïîëîñîé àäðåñà DrawBar(246,0,onLeft(246,60),12, col_work); //upper editbox
DrawBar(246,29,onLeft(246,60),5,col_work); //ôîí ïîä ïîëîñîé àäðåñà DrawBar(246,29,onLeft(246,60),5,col_work); //under editbox
DrawRectangle3D(246,12,onLeft(66,246),16,col_border,col_border); DrawRectangle(246,12,onLeft(66,246),16,col_border);
DefineButton(onLeft(34,0),6,27,28,51+BT_HIDE+BT_NOFRAME,col_work); //about DefineButton(onLeft(34,0),6,27,28,51+BT_HIDE+BT_NOFRAME,0); //about
PutPaletteImage(#goto_about,56,34,Form.width-65,0,8,#goto_about_pal); PutPaletteImage(#goto_about,56,34,Form.width-65,0,8,#goto_about_pal);
//main rectangles //main rectangles
DrawRectangle3D(1,40,Form.cwidth-3,onTop(46,0),col_border,col_border); DrawRectangle(1,40,Form.cwidth-3,onTop(46,0),col_border);
DrawRectangle3D(0,39,Form.cwidth-1,onTop(44,0),col_palette[4],col_palette[4]); //bg DrawRectangle(0,39,Form.cwidth-1,onTop(44,0),col_palette[4]); //bg
for (i=0; i<5; i++) DrawBar(0, 34+i, Form.cwidth, 1, col_palette[8-i]); for (i=0; i<5; i++) DrawBar(0, 34+i, Form.cwidth, 1, col_palette[8-i]);
DrawLeftPanel(); DrawLeftPanel();
//ListBox //ListBox
@ -373,7 +374,7 @@ inline fastcall void draw_window()
DrawFlatButton(onLeft(27,0),onTop(22,0),16,16,0,col_work,"\x19"); DrawFlatButton(onLeft(27,0),onTop(22,0),16,16,0,col_work,"\x19");
Open_Dir(#path,ONLY_SHOW); Open_Dir(#path,ONLY_SHOW);
if (del_active) Del_Form(); if (del_active) Del_Form();
if (rename_active) ActionsProcess(2); if (rename_active) FnProcess(2);
} }
@ -387,7 +388,7 @@ void KEdit()
} }
void FileList_ReDraw(int cur) void List_Current(int cur)
{ {
if (cur<=0) //up if (cur<=0) //up
{ {
@ -440,8 +441,6 @@ void FileList_ReDraw(int cur)
} }
void List_ReDraw() void List_ReDraw()
{ {
int paint_y; int paint_y;
@ -450,7 +449,7 @@ void List_ReDraw()
if (files.count-files.first<files.visible) || (files.current>files.visible-1) if (files.count-files.first<files.visible) || (files.current>files.visible-1)
{ files.first=files.count-files.visible; files.current=files.visible-1; } { files.first=files.count-files.visible; files.current=files.visible-1; }
for (j=0; j<files.visible; j++) if (files.current<>j) Line_ReDraw(0xFFFFFF, j); else Line_ReDraw(col_selec, files.current); for (j=0; j<files.visible; j++) if (files.current!=j) Line_ReDraw(0xFFFFFF, j); else Line_ReDraw(col_selec, files.current);
//in the bottom //in the bottom
paint_y = j * files.line_h + files.y; paint_y = j * files.line_h + files.y;
DrawBar(files.x,paint_y,files.w,onTop(paint_y,6),0xFFFFFF); DrawBar(files.x,paint_y,files.w,onTop(paint_y,6),0xFFFFFF);
@ -459,6 +458,7 @@ void List_ReDraw()
Scroll(); Scroll();
} }
void Line_ReDraw(dword color, filenum){ void Line_ReDraw(dword color, filenum){
dword text_col=0, name_len=0, y=filenum*files.line_h+57; dword text_col=0, name_len=0, y=filenum*files.line_h+57;
DrawBar(192,y,3,files.line_h,color); DrawBar(192,y,3,files.line_h,color);
@ -480,7 +480,7 @@ void Line_ReDraw(dword color, filenum){
else else
Put_icon("<DIR>", files.line_h/2-7+y, color); Put_icon("<DIR>", files.line_h/2-7+y, color);
if (TestBit(ESDWORD[off-40],1)) || (TestBit(ESDWORD[off-40],2)) text_col=0xA6A6B7; //system or hiden? if (TestBit(ESDWORD[off-40],1)) || (TestBit(ESDWORD[off-40],2)) text_col=0xA6A6B7; //system or hiden?
if (color<>0xFFFfff) if (color!=0xFFFfff)
{ {
itdir=TestBit(ESDWORD[off-40], 4); itdir=TestBit(ESDWORD[off-40], 4);
strcpy(#file_name, off); strcpy(#file_name, off);
@ -502,52 +502,41 @@ void Line_ReDraw(dword color, filenum){
} }
void Open_Dir(dword temp_, redraw){ void Open_Dir(dword dir_path, redraw){
int errornum, count; int errornum, maxcount;
char path_[4096],
somelen=strlen(temp_)-1;
if (redraw<>ONLY_SHOW) if (redraw!=ONLY_SHOW)
{ {
strcpy(#path_, temp_); if (ESBYTE[dir_path+1]!='\0') ESBYTE[dir_path+strlen(dir_path)-1] = '\0';
if (somelen) path_[somelen]=NULL;
if (buf) free(buf); if (buf) free(buf);
buf = malloc(32); errornum = GetDir(#buf, #files.count, dir_path, DIRS_NOROOT);
errornum=ReadDir(0, buf, #path_); if (ESBYTE[dir_path+1]!='\0') chrcat(dir_path, '/');
if (errornum<>0) if (errornum)
{ {
HistoryPath(ADD_NEW_PATH); HistoryPath(ADD_NEW_PATH);
GoBack(); GoBack();
Write_Error(errornum); Write_Error(errornum);
return; return;
} }
files.count = ESDWORD[buf+8]; maxcount = sizeof(file_mas)/sizeof(dword)-1;
buf = realloc(buf, files.count * 304 + 32); if (files.count>maxcount) files.count = maxcount;
ReadDir(files.count, buf, #path_);
files.count=EBX;
count = sizeof(file_mas)/sizeof(dword)-1;
if (files.count>count) files.count=count;
} }
if (files.count<>-1) if (files.count!=-1)
{ {
KEdit(); KEdit();
HistoryPath(ADD_NEW_PATH); HistoryPath(ADD_NEW_PATH);
IF (!strcmp(".",buf+72)) {files.count--; memmov(buf,buf+304,files.count*304);} //oeeuo?oai yeaiaio "." files.visible = files.h / files.line_h;
files.visible=onTop(6,57)/files.line_h;
IF (files.count < files.visible) files.visible = files.count; IF (files.count < files.visible) files.visible = files.count;
IF (sort_num==1) WriteText(Form.width+60/2,45,0x80,0x4E78AC,"\x19"); IF (sort_num==1) WriteText(Form.width+60/2,45,0x80,col_border,"\x19");
IF (sort_num==2) WriteText(Form.width-115,45,0x80,0x4E78AC,"\x19"); IF (sort_num==2) WriteText(Form.width-115,45,0x80,col_border,"\x19");
IF (sort_num==3) WriteText(Form.width-44,45,0x80,0x4E78AC,"\x19"); IF (sort_num==3) WriteText(Form.width-44,45,0x80,col_border,"\x19");
IF (redraw<>ONLY_SHOW) Sorting(); IF (redraw!=ONLY_SHOW) Sorting();
IF (redraw<>ONLY_OPEN) List_ReDraw(); IF (redraw!=ONLY_OPEN) List_ReDraw();
} }
IF (files.count==-1) && (redraw<>ONLY_OPEN) {files.visible=files.count=0; List_ReDraw();} IF (files.count==-1) && (redraw!=ONLY_OPEN) {files.visible=files.count=0; List_ReDraw();}
} }
inline Sorting() inline Sorting()
{ {
dword k=0, l=1; dword k=0, l=1;
@ -577,13 +566,14 @@ inline Sorting()
IF (sort_num==2) Sort_by_Type(k,files.count-1); IF (sort_num==2) Sort_by_Type(k,files.count-1);
IF (sort_num==3) Sort_by_Size(k,files.count-1); IF (sort_num==3) Sort_by_Size(k,files.count-1);
//".." should be first //".." should be first
IF (k>0) && (strcmp(file_mas[0]*304+buf+72,"..")<>0) FOR(k--; k>0; k--;) IF (!strcmp(file_mas[k]*304+buf+72,"..")) file_mas[k]><file_mas[0]; IF (k>0) && (strcmp(file_mas[0]*304+buf+72,"..")!=0)
FOR(k--; k>0; k--;) IF (!strcmp(file_mas[k]*304+buf+72,"..")) {file_mas[k]><file_mas[0]; break;}
} }
void Del_Form() void Del_Form()
{ {
int dform_x=Form.width/2-13; int dform_x = files.w - 200 / 2 + files.x;
//oeia ieii //oeia ieii
if (!files.count) return; if (!files.count) return;
DrawFlatButton(dform_x,160,200,80,0,col_work, ""); //oi?ia DrawFlatButton(dform_x,160,200,80,0,col_work, ""); //oi?ia
@ -599,7 +589,6 @@ void Del_Form()
ESI = 24; ESI = 24;
WriteText(dform_x+20,190,0,0,#file_name); //ieoai eiy WriteText(dform_x+20,190,0,0,#file_name); //ieoai eiy
} }
//eiiii?ee
DrawFlatButton(dform_x+20,208,70,20,301,0xFFB6B5,"Yes"); DrawFlatButton(dform_x+20,208,70,20,301,0xFFB6B5,"Yes");
DrawFlatButton(dform_x+111,208,70,20,302,0xC6DFC6,"No"); DrawFlatButton(dform_x+111,208,70,20,302,0xC6DFC6,"No");
del_active=1; del_active=1;
@ -612,7 +601,7 @@ void Del_File(byte dodel)
IF (dodel==true) IF (dodel==true)
{ {
del_rezult = DeleteFile(#file_path); del_rezult = DeleteFile(#file_path);
IF (del_rezult<>0) IF (del_rezult)
{ {
Write_Error(del_rezult); Write_Error(del_rezult);
IF ( itdir) ShowMessage("Error. Folder isn't empty."); IF ( itdir) ShowMessage("Error. Folder isn't empty.");
@ -621,37 +610,7 @@ void Del_File(byte dodel)
} }
del_active=0; del_active=0;
DeleteButton(301); DeleteButton(302); DeleteButton(301); DeleteButton(302);
Open_Dir(#path,1); Open_Dir(#path,WITH_REDRAW);
}
void Paste()
{
char new_copy_path[4096];
int copy_rezult;
IF (!copy_file) return;
strcpy(#new_copy_path, #path);
strcat(#new_copy_path, #copy_file+strrchr(#copy_file,'/'));
if (!strcmp(#copy_file,#new_copy_path))
{
strcpy(#new_copy_path, #path);
strcat(#new_copy_path, "new_");
strcat(#new_copy_path, #copy_file+strrchr(#copy_file,'/'));
}
copy_rezult = CopyFile(#copy_file,#new_copy_path);
IF (copy_rezult!=0)
{
Write_Error(copy_rezult);
return;
}
IF (cut_active)
{
strcpy(#file_path, #copy_file);
Del_File(true);
copy_file=NULL;
cut_active=false;
}
SelectFile(#new_copy_path+strrchr(#new_copy_path,'/'));
} }
@ -666,18 +625,18 @@ void ReName(byte rename)
strcpy(#temp, #path); strcpy(#temp, #path);
strcpy(#edit_name, #file_name); //save edit name to select it later strcpy(#edit_name, #file_name); //save edit name to select it later
strcat(#temp, #file_name); strcat(#temp, #file_name);
if (strcmp(#file_path,#temp)<>0) && (file_name) if (strcmp(#file_path,#temp)!=0) && (file_name)
IF (itdir) if (itdir)
{ {
del_rezult = DeleteFile(#file_path); del_rezult = DeleteFile(#file_path);
IF (del_rezult!=0) if (del_rezult!=0)
{ {
Write_Error(del_rezult); Write_Error(del_rezult);
ShowMessage("Error. Folder isn't empty."); ShowMessage("Error. Folder isn't empty.");
return; return;
} }
ELSE CreateDir(#temp); ELSE CreateDir(#temp);
Open_Dir(#path,1); Open_Dir(#path,WITH_REDRAW);
} }
ELSE ELSE
{ {
@ -697,7 +656,7 @@ void SelectFile(dword that_file)
strttl(that_file); strttl(that_file);
for (i=files.count-1; i>=0; i--;) for (i=files.count-1; i>=0; i--;)
if (!strcmp(file_mas[i]*304+buf+72,that_file)) break; if (!strcmp(file_mas[i]*304+buf+72,that_file)) break;
FileList_ReDraw(i); List_Current(i);
List_ReDraw(); List_ReDraw();
} }
@ -716,6 +675,7 @@ void Dir_Up()
void Open() void Open()
{ {
if (!files.count) return;
if (!itdir) if (!itdir)
{ {
GetIni(0); GetIni(0);
@ -726,7 +686,7 @@ void Open()
strcpy(#path, #file_path); strcpy(#path, #file_path);
if (path[strlen(#path)-1]!='/') chrcat(#path, '/'); //need "/" in the end if (path[strlen(#path)-1]!='/') chrcat(#path, '/'); //need "/" in the end
files.first=files.current=0; files.first=files.current=0;
Open_Dir(#path,1); Open_Dir(#path,WITH_REDRAW);
} }
} }
@ -738,13 +698,13 @@ inline fastcall void GoBack()
if (HistoryPath(GO_BACK)) SelectFile(#cur_folder); if (HistoryPath(GO_BACK)) SelectFile(#cur_folder);
} }
void ActionsProcess(char N) void FnProcess(char N)
{ {
switch(N) switch(N)
{ {
case 1: case 1:
SwitchToAnotherThread(); SwitchToAnotherThread();
CreateThread(#about_dialog,#stak1); CreateThread(#about_dialog,#about_stak);
break; break;
case 2: case 2:
if (!files.count) break; if (!files.count) break;
@ -768,7 +728,7 @@ void ActionsProcess(char N)
pause(10); pause(10);
GetIni(1); GetIni(1);
SystemDiscsGet(); SystemDiscsGet();
Open_Dir(#path,1); Open_Dir(#path,WITH_REDRAW);
DrawLeftPanel(); DrawLeftPanel();
break; break;
case 6: case 6:
@ -777,7 +737,7 @@ void ActionsProcess(char N)
CreateDir(#temp); CreateDir(#temp);
if (!EAX){ if (!EAX){
SelectFile("New folder"); SelectFile("New folder");
ActionsProcess(2); FnProcess(2);
} }
else else
{ {
@ -791,7 +751,7 @@ void ActionsProcess(char N)
WriteFile(0, 0, #temp); WriteFile(0, 0, #temp);
if (!EAX){ if (!EAX){
SelectFile("New file"); SelectFile("New file");
ActionsProcess(2); FnProcess(2);
} }
else else
{ {
@ -805,11 +765,9 @@ void ActionsProcess(char N)
} }
} }
void copyf_Action() {
return;
}
stop: stop:
char stak1[512]; char about_stak[512];
char stak2[512]; char menu_stak[512];
char copy_stak[4096];

View File

@ -0,0 +1,61 @@
//Leency 2008-2013
byte copy_from[4096], cut_active=0;
enum {NOCUT, CUT};
#define WIN_W 300
#define WIN_H 20
void Copy(dword pcth, char cut)
{
strcpy(#copy_from, pcth);
cut_active = cut;
}
void copyf_Action(dword filename) {
DefineAndDrawWindow(5000,0,WIN_W,WIN_H-1,0x01,col_work,0);
DrawBar(WIN_W, 0, 1, WIN_H, 0x333333);
DrawBar(0, 0, WIN_W, WIN_H, 0xDDDddd);
WriteText(5,6, 0x80, 0, "Copying file:");
WriteText(90,6, 0x80, 0, filename);
pause(20);
}
void Paste()
{
char copy_to[4096], copy_rezult;
if (!copy_from) ExitProcess();
strcpy(#copy_to, #path);
strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
if (!strcmp(#copy_from,#copy_to))
{
strcpy(#copy_to, #path);
strcat(#copy_to, "new_");
strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
}
if (strstr(#copy_to, #copy_from))
{
notify("Copy directory into itself is a bad idea...");
ExitProcess();
}
copy_rezult = copyf(#copy_from,#copy_to);
if (copy_rezult)
{
Write_Error(copy_rezult);
ExitProcess();
}
if (cut_active)
{
strcpy(#file_path, #copy_from);
Del_File(true);
copy_from=NULL;
cut_active=false;
}
ActivateWindow(GetProcessSlot(Form.ID));
SendWindowMessage(evKey, 54);
SelectFile(#copy_to+strrchr(#copy_to,'/'));
ExitProcess();
}

View File

@ -45,11 +45,11 @@ void FileMenu()
id=GetButtonID(); id=GetButtonID();
if (id==100) Open(); if (id==100) Open();
if (id==101) notify("Not compleated yet"); if (id==101) notify("Not compleated yet");
if (id==102) ActionsProcess(3); if (id==102) FnProcess(3);
if (id==103) ActionsProcess(4); if (id==103) FnProcess(4);
if (id==104) ActionsProcess(2); if (id==104) FnProcess(2);
if (id==105) Del_Form(); if (id==105) Del_Form();
if (id==106) ActionsProcess(5); if (id==106) FnProcess(5);
ExitProcess(); ExitProcess();
break; break;
@ -58,13 +58,15 @@ void FileMenu()
break; break;
case evReDraw: _MENU_DRAW: case evReDraw: _MENU_DRAW:
DefineAndDrawWindow(m.x+Form.left+5,m.y+Form.top+GetSkinHeight(),linew+2,ccount*lineh+5,0x01, 0, 0, 0x01fffFFF); DefineAndDrawWindow(m.x+Form.left+5,m.y+Form.top+GetSkinHeight(),linew+3,ccount*lineh+6,0x01, 0, 0, 0x01fffFFF);
GetProcessInfo(#MenuForm, SelfInfo); GetProcessInfo(#MenuForm, SelfInfo);
/* _PutImage(1,23, 16,44, #factions); //èêîíêè */ /* _PutImage(1,23, 16,44, #factions); //èêîíêè */
DrawRectangle(0,0,linew+1,ccount*lineh+2,col_border); DrawRectangle(0,0,linew+1,ccount*lineh+2,col_border);
DrawBar(1,1,linew,1,0xFFFfff); DrawBar(1,1,linew,1,0xFFFfff);
PutShadow(linew+2,1,1,ccount*lineh+2,0,1); PutShadow(linew+2,1,1,ccount*lineh+2,0,2);
PutShadow(1,ccount*lineh+3,linew+2,1,0,1); PutShadow(linew+3,2,1,ccount*lineh+2,0,1);
PutShadow(1,ccount*lineh+3,linew+2,1,0,2);
PutShadow(2,ccount*lineh+4,linew+1,1,0,1);
_ITEMS_DRAW: _ITEMS_DRAW:
for (i=0; captions[i*2]!=0; i++) for (i=0; captions[i*2]!=0; i++)

View File

@ -6,9 +6,9 @@ void Tip(int y, dword caption, id, arrow)
DrawBar(17,y,160,1,0xEFEDEE); DrawBar(17,y,160,1,0xEFEDEE);
DrawFilledBar(17, y+1, 160, 16); DrawFilledBar(17, y+1, 160, 16);
WriteText(25,y+5,0x80,0,caption); WriteText(25,y+5,0x80,0,caption);
IF (id<>0) DefineButton(159,y+1,16,16,id+BT_HIDE+BT_NOFRAME,0xE4DFE1); //êíîïà äëÿ ñòðåëêè IF (id<>0) DefineButton(159,y+1,16,16,id+BT_HIDE+BT_NOFRAME,0); //êíîïà äëÿ ñòðåëêè
WriteText(165,y+5,0x80,0,arrow); //ñòðåëêà âíèç WriteText(165,y+5,0x80,0,arrow); //ñòðåëêà âíèç
DrawBar(17,y+17,160,1,0x94AECE); //ïîä÷¸ðêèâàíèå DrawBar(17,y+17,160,1,col_border); //ïîä÷¸ðêèâàíèå
} }
@ -132,7 +132,7 @@ void LeftPanelBgDraw()
int start_y = actions_y+156; int start_y = actions_y+156;
DrawBar(2,41,190,15,col_lpanel); //ñèíèé ïðÿìîóãîëüíèê - íàä äåâàéñàìè DrawBar(2,41,190,15,col_lpanel); //ñèíèé ïðÿìîóãîëüíèê - íàä äåâàéñàìè
DrawBar(17,actions_y+75,160,15,col_lpanel); //ñèíèé ïðÿìîóãîëüíèê - ïîä äåâàéñàìè DrawBar(17,actions_y+75,160,15,col_lpanel); //ñèíèé ïðÿìîóãîëüíèê - ïîä äåâàéñàìè
PutShadow(17,actions_y+75,160,1,1,2); PutShadow(17,actions_y+75,160,1,1,4);
PutShadow(18,actions_y+75+1,158,1,1,1); PutShadow(18,actions_y+75+1,158,1,1,1);
DrawBar(2,56,15,actions_y+103,col_lpanel); //ñèíèé ïðÿìîóãîëüíèê - ñëåâà DrawBar(2,56,15,actions_y+103,col_lpanel); //ñèíèé ïðÿìîóãîëüíèê - ñëåâà
DrawBar(177,56,15,actions_y+103,col_lpanel); //ñèíèé ïðÿìîóãîëüíèê - ñïðàâà DrawBar(177,56,15,actions_y+103,col_lpanel); //ñèíèé ïðÿìîóãîëüíèê - ñïðàâà
@ -143,7 +143,7 @@ void LeftPanelBgDraw()
DrawBar(2,start_y,190,onTop(start_y,6+268),col_lpanel); DrawBar(2,start_y,190,onTop(start_y,6+268),col_lpanel);
PutPaletteImage(#blue_hl, 190, 268, 2, onTop(268,6), 8, #blue_hl_pal); PutPaletteImage(#blue_hl, 190, 268, 2, onTop(268,6), 8, #blue_hl_pal);
} }
PutShadow(17,start_y,160,1,1,2); PutShadow(17,start_y,160,1,1,4);
PutShadow(18,start_y+1,158,1,1,1); PutShadow(18,start_y+1,158,1,1,1);
} }

View File

@ -1,3 +1,8 @@
04.05.13 -- v1.88
- копирование через поток;
- копирование папок;
- небольшие изменения в GUI.
01.05.13 -- v1.8 01.05.13 -- v1.8
- исправлено падение при изменении размера окна (нашёл 0CodErr); - исправлено падение при изменении размера окна (нашёл 0CodErr);
- меню файлов; - меню файлов;

View File

@ -58,7 +58,7 @@ void Install()
ShowProgress("Copying files..."); ShowProgress("Copying files...");
copyf("/sys/docpack", "/tmp9/1/docpack"); copyf("/sys/docpack", "/tmp9/1/docpack");
DeleteFile("/sys/docpack"); DeleteFile("/sys/docpack");
copyf(abspath("sys"), "/sys"); copyf(abspath("sys"), "/rd/1");
copyf(abspath("tmp"), "/tmp9/1"); copyf(abspath("tmp"), "/tmp9/1");
ShowProgress("Post install actions..."); ShowProgress("Post install actions...");
RunProgram("/sys/launcher", NULL); RunProgram("/sys/launcher", NULL);

View File

@ -14,7 +14,7 @@ void main()
signed int result; signed int result;
mem_Init(); mem_Init();
GetDir(#dirbuf, #fcount, "/"); GetDir(#dirbuf, #fcount, "/", DIRS_ONLYREAL);
for (i=0; i<fcount; i++) for (i=0; i<fcount; i++)
{ {
@ -24,7 +24,7 @@ void main()
strcpy(#cd_path, "/"); strcpy(#cd_path, "/");
strcat(#cd_path, filename); strcat(#cd_path, filename);
free(dirbuf2); free(dirbuf2);
GetDir(#dirbuf2, #fcount2, #cd_path); GetDir(#dirbuf2, #fcount2, #cd_path, DIRS_ONLYREAL);
for (j=0; j<fcount2; j++) for (j=0; j<fcount2; j++)
{ {

View File

@ -1,93 +1,95 @@
// универсальность добавления / //copyf - copy file or folder with content
:int copyf(dword from1, in1)
:void copyf(dword from1, in1)
{ {
dword error; dword error;
BDVK CopyFile_atr1; BDVK CopyFile_atr1;
if (!from1) || (!in1) { notify("Error: too less copyf params!"); notify(from1); notify(in1); return; } if (!from1) || (!in1)
error = GetFileInfo(from1, #CopyFile_atr1); {
if (error) notify("Error: too less copyf params!");
notify(from1);
notify(in1);
return;
}
if (error = GetFileInfo(from1, #CopyFile_atr1))
{
debug("Error: copyf->GetFileInfo"); debug("Error: copyf->GetFileInfo");
return error;
}
if (isdir(from1))
return CopyFolder(from1, in1);
else else
if (isdir(from1)) CopyFolder(from1, in1); else CopyFile(from1, in1); return CopyFile(from1, in1);
} }
:int CopyFile(dword copy_from3, copy_in3) :int CopyFile(dword copy_from3, copy_in3)
{ {
BDVK CopyFile_atr; BDVK CopyFile_atr;
dword error, cbuf; dword error, cbuf;
debug(copy_from3); if (error = GetFileInfo(copy_from3, #CopyFile_atr))
error = GetFileInfo(copy_from3, #CopyFile_atr); debug("Error: CopyFile->GetFileInfo");
if (error)
{debug("Error: CopyFile->GetFileInfo"); debug(copy_from3);}
else else
{ {
cbuf = malloc(CopyFile_atr.sizelo); cbuf = malloc(CopyFile_atr.sizelo);
error = ReadFile(0, CopyFile_atr.sizelo, cbuf, copy_from3); if (error = ReadFile(0, CopyFile_atr.sizelo, cbuf, copy_from3))
if (error)
debug("Error: CopyFile->ReadFile"); debug("Error: CopyFile->ReadFile");
else else
{ {
error = WriteFile(CopyFile_atr.sizelo, cbuf, copy_in3); if (error = WriteFile(CopyFile_atr.sizelo, cbuf, copy_in3)) debug("Error: CopyFile->WriteFile");
if (error) debug("Error: CopyFile->WriteFile");
} }
} }
free(cbuf); free(cbuf);
if (error) debug(copy_from3); if (error) debug_error(copy_from3, error);
return error; return error;
} }
:void CopyFolder(dword from2, in2) :int CopyFolder(dword from2, in2)
{ {
dword dirbuf, fcount, filename; dword dirbuf, fcount, i, filename;
int i, error, isdir; char copy_from2[4096], copy_in2[4096], error;
char copy_from2[4096], copy_in2[4096];
error = GetDir(#dirbuf, #fcount, from2); if (error = GetDir(#dirbuf, #fcount, from2, DIRS_ONLYREAL))
if (error)
{ {
debug("Error: CopyFolder->GetDir"); debug("Error: CopyFolder->GetDir");
debug_error(from2, error); debug_error(from2, error);
debug_error(in2, error);
free(dirbuf); free(dirbuf);
return; return error;
} }
if ((strcmp(in2, "/sys")!=0) && (strcmp(in2, "/tmp9/1")!=0)) if (chrnum(in2, '/')>2) && (error = CreateDir(in2))
{ {
error = CreateDir(in2); debug("Error: CopyFolder->CreateDir");
if (error) debug_error(in2, error); debug_error(in2, error);
free(dirbuf);
return error;
} }
chrcat(in2, '/');
chrcat(from2, '/');
for (i=0; i<fcount; i++) for (i=0; i<fcount; i++)
{ {
filename = i*304+dirbuf+72; filename = i*304+dirbuf+72;
isdir = TestBit(ESDWORD[filename-40], 4);
if (isdir)
{
if ( (!strcmp(filename, ".")) || (!strcmp(filename, "..")) ) continue;
strcpy(#copy_from2, from2); strcpy(#copy_from2, from2);
strcpy(#copy_in2, in2); chrcat(#copy_from2, '/');
strcat(#copy_from2, filename); strcat(#copy_from2, filename);
strcpy(#copy_in2, in2);
chrcat(#copy_in2, '/');
strcat(#copy_in2, filename); strcat(#copy_in2, filename);
if ( TestBit(ESDWORD[filename-40], 4) ) //isdir?
{
if ( (!strcmp(filename, ".")) || (!strcmp(filename, "..")) ) continue;
CopyFolder(#copy_from2, #copy_in2); CopyFolder(#copy_from2, #copy_in2);
} }
else else
{ {
strcpy(#copy_from2, from2);
strcat(#copy_from2, filename);
strcpy(#copy_in2, in2);
strcat(#copy_in2, filename);
copyf_Action(filename); copyf_Action(filename);
if (error=CopyFile(#copy_from2, #copy_in2))
if (CopyFile(#copy_from2, #copy_in2)!=0) CopyFile(#copy_from2, #copy_in2); // #2 :) {
if (fabs(error)==8) { debug("Stop copying."); break;} //TODO: may be need grobal var like stop_all
error=CopyFile(#copy_from2, #copy_in2); // #2 :)
}
} }
} }
free(dirbuf); free(dirbuf);
return error;
} }

View File

@ -1,49 +0,0 @@
//BOX_LIB
dword boxlib = #aEdit_box_lib; //Asper
char aEdit_box_lib[22]="/sys/lib/box_lib.obj\0"; //Asper
dword edit_box_draw = #aEdit_box_draw;
dword edit_box_key = #aEdit_box_key;
dword edit_box_mouse = #aEdit_box_mouse;
dword version_ed = #aVersion_ed;
dword am__ = 0x0;
dword bm__ = 0x0;
char aEdit_box_draw[9] = "edit_box\0";
char aEdit_box_key[13] = "edit_box_key\0";
char aEdit_box_mouse[15] = "edit_box_mouse\0";
char aVersion_ed[11] = "version_ed\0";
char aCheck_box_draw [15] = "check_box_draw\0";
char aCheck_box_mouse [16] = "check_box_mouse\0";
char aVersion_ch [11] = "version_ch\0";
char aOption_box_draw [16] = "option_box_draw\0";
char aOption_box_mouse[17] = "option_box_mouse\0";
char aVersion_op [11] = "version_op\0" ;
struct edit_box{
dword width, left, top, color, shift_color, focus_border_color, blur_border_color,
text_color, max, text, mouse_variable, flags, size, pos, offset, cl_curs_x, cl_curs_y, shift, shift_old;
};
//ed_width equ [edi] ;è¨à¨­  ª®¬¯®­¥­â 
//ed_left equ [edi+4] ;¯®«®¦¥­¨¥ ¯® ®á¨ å
//ed_top equ [edi+8] ;¯®«®¦¥­¨¥ ¯® ®á¨ ã
//ed_color equ [edi+12] ;梥â ä®­  ª®¬¯®­¥­â 
//shift_color equ [edi+16] ;=0x6a9480
//ed_focus_border_color equ [edi+20] ;梥â à ¬ª¨ ª®¬¯®­¥­â 
//ed_blur_border_color equ [edi+24] ;梥⠭¥  ªâ¨¢­®£® ª®¬¯®­¥­â 
//ed_text_color equ [edi+28] ;梥â ⥪áâ 
//ed_max equ [edi+32] ;ª®«-¢® ᨬ¢®«®¢ ª®â®àë¥ ¬®¦­® ¬ ªá¨¬ «ì­® ¢¢¥áâ¨
//ed_text equ [edi+36] ;㪠§ â¥«ì ­  ¡ãä¥à
//ed_flags equ [edi+40] ;ä« £¨
//ed_size equ [edi+42] ;ª®«-¢® ᨬ¢®«®¢
//ed_pos equ [edi+46] ;¯®§¨æ¨ï ªãàá®à 
//ed_offset equ [edi+50] ;ᬥ饭¨¥
//cl_curs_x equ [edi+54] ;¯à¥¤ë¤ãé ï ª®®à¤¨­ â  ªãàá®à  ¯® å
//cl_curs_y equ [edi+58] ;¯à¥¤ë¤ãé ï ª®®à¤¨­ â  ªãàá®à  ¯® ã
//ed_shift_pos equ [edi+62] ;¯®«®¦¥­¨¥ ªãàá®à 
//ed_shift_pos_old equ [edi+66] ;áâ à®¥ ¯®«®¦¥­¨¥ ªãàá®à 

View File

@ -187,7 +187,13 @@ char isdir(dword fpath)
return 0; return 0;
} }
:int GetDir(dword dir_buf, file_count, path) enum
{
DIRS_ALL,
DIRS_NOROOT,
DIRS_ONLYREAL
};
:int GetDir(dword dir_buf, file_count, path, doptions)
{ {
dword buf, fcount, error; dword buf, fcount, error;
buf = malloc(32); buf = malloc(32);
@ -198,8 +204,17 @@ char isdir(dword fpath)
buf = realloc(buf, fcount+1*304+32); buf = realloc(buf, fcount+1*304+32);
ReadDir(fcount, buf, path); ReadDir(fcount, buf, path);
//fcount=EBX; //fcount=EBX;
if (doptions == DIRS_ONLYREAL)
{
if (!strcmp(".",buf+72)) {fcount--; memmov(buf,buf+304,fcount*304);} if (!strcmp(".",buf+72)) {fcount--; memmov(buf,buf+304,fcount*304);}
if (!strcmp("..",buf+72)) {fcount--; memmov(buf,buf+304,fcount*304);} if (!strcmp("..",buf+72)) {fcount--; memmov(buf,buf+304,fcount*304);}
}
if (doptions == DIRS_NOROOT)
{
if (!strcmp(".",buf+72)) {fcount--; memmov(buf,buf+304,fcount*304);}
}
ESDWORD[dir_buf] = buf; ESDWORD[dir_buf] = buf;
ESDWORD[file_count] = fcount; ESDWORD[file_count] = fcount;
} }

View File

@ -240,6 +240,13 @@ inline fastcall void SwitchToAnotherThread()
$int 0x40 $int 0x40
} }
inline fastcall void SendWindowMessage( ECX, EDX)
{
$mov eax, 72
$mov ebx, 1
$int 0x40
}
inline fastcall int KillProcess( ECX) inline fastcall int KillProcess( ECX)
{ {
$mov eax,18; $mov eax,18;

View File

@ -21,7 +21,7 @@ inline fastcall int StatusSocket( ECX)
$int 0x40 $int 0x40
} }
inline fastcall dword ReadSocket( ECX) //ecx - handle inline fastcall dword ReadSocket( ECX)
{ {
$mov eax,53 $mov eax,53
$mov ebx,3 $mov ebx,3

View File

@ -12,6 +12,7 @@
// strlwr( ESI) --- kyrillic symbols may not work // strlwr( ESI) --- kyrillic symbols may not work
// strttl( EDX) // strttl( EDX)
// strtok( ESI) // strtok( ESI)
// chrnum(dword searchin, char symbol)
// strcpyb(dword searchin, copyin, startstr, endstr) --- copy string between strings // strcpyb(dword searchin, copyin, startstr, endstr) --- copy string between strings
// strnumb(dword searchin, startstr, endstr) --- get number between strings // strnumb(dword searchin, startstr, endstr) --- get number between strings
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------

View File

@ -4,13 +4,13 @@
#define MEMSIZE 0xA0000 #define MEMSIZE 0xA0000
#include "..\lib\kolibri.h" #include "..\lib\kolibri.h"
#include "..\lib\strings.h" #include "..\lib\strings.h"
#include "..\lib\encoding.h"
#include "..\lib\file_system.h"
#include "..\lib\figures.h"
#include "..\lib\list_box.h"
#include "..\lib\socket.h"
#include "..\lib\mem.h" #include "..\lib\mem.h"
#include "..\lib\dll.h" #include "..\lib\dll.h"
#include "..\lib\encoding.h"
#include "..\lib\figures.h"
#include "..\lib\file_system.h"
#include "..\lib\list_box.h"
#include "..\lib\socket.h"
//*.obj libraries //*.obj libraries
#include "..\lib\lib.obj\box_lib.h" #include "..\lib\lib.obj\box_lib.h"
#include "..\lib\lib.obj\network.h" #include "..\lib\lib.obj\network.h"