(From Leency) Eolite 2.15: RealFileNamesCase support; show OpenWithDialog if associated program not found; add ram disk free space bar; small fix;

git-svn-id: svn://kolibrios.org@4225 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Serhii Sakhno 2013-11-14 00:22:55 +00:00
parent 4a605f1fb2
commit 31165f9b8d
6 changed files with 126 additions and 59 deletions

View File

@ -79,8 +79,8 @@
enum {ONLY_SHOW, WITH_REDRAW, ONLY_OPEN}; //OpenDir enum {ONLY_SHOW, WITH_REDRAW, ONLY_OPEN}; //OpenDir
#define TITLE "Eolite File Manager v2.0.4" #define TITLE "Eolite File Manager v2.15"
#define ABOUT_TITLE "Eolite v2.0.4" #define ABOUT_TITLE "Eolite v2.15"
dword col_padding, col_selec, col_lpanel; dword col_padding, col_selec, col_lpanel;
int toolbar_buttons_x[7]={9,46,85,134,167,203}; int toolbar_buttons_x[7]={9,46,85,134,167,203};
@ -103,6 +103,7 @@ byte
rename_active=0, rename_active=0,
del_active=0, del_active=0,
show_dev_name=1, show_dev_name=1,
real_files_names_case=0,
sort_num=2, sort_num=2,
itdir; itdir;
@ -310,6 +311,13 @@ void main()
case 26: //paste case 26: //paste
CreateThread(#Paste,#copy_stak+4092); CreateThread(#Paste,#copy_stak+4092);
break; break;
case 27:
strcpy(#temp, "Ram Disk free space: ");
i = GetFreeRamDiskClusters() / 2;
itoa_(#temp+21, i);
strcat(#temp, "Kb");
notify(#temp);
break;
case 31...33: //sort case 31...33: //sort
IF(sort_num==1) DrawFilledBar(sorting_arrow_x,42,6,10); IF(sort_num==1) DrawFilledBar(sorting_arrow_x,42,6,10);
IF(sort_num==2) DrawFilledBar(sorting_arrow_x,42,6,10); IF(sort_num==2) DrawFilledBar(sorting_arrow_x,42,6,10);
@ -396,11 +404,7 @@ void main()
CreateThread(#FileMenu,#menu_stak+4092); CreateThread(#FileMenu,#menu_stak+4092);
break; break;
case 173: //Ctrl+Enter case 173: //Ctrl+Enter
if (!itdir) if (!itdir) ShowOpenWithDialog();
{
SwitchToAnotherThread();
CreateThread(#OpenWith,#open_with_stak+4092);
}
break; break;
case 178: //up case 178: //up
List_Current(-1); List_Current(-1);
@ -444,6 +448,8 @@ void main()
} }
} }
void menu_action(dword id) void menu_action(dword id)
{ {
if (id==COPY_PASTE_END) if (id==COPY_PASTE_END)
@ -452,11 +458,7 @@ void menu_action(dword id)
SelectFile(#copy_to+strrchr(#copy_to,'/')); SelectFile(#copy_to+strrchr(#copy_to,'/'));
} }
if (id==100) Open(); if (id==100) Open();
if (id==201) if (id==201) ShowOpenWithDialog();
{
SwitchToAnotherThread();
CreateThread(#OpenWith,#open_with_stak+4092);
}
if (id==202) FnProcess(3); //F3 if (id==202) FnProcess(3); //F3
if (id==203) FnProcess(4); //F4 if (id==203) FnProcess(4); //F4
if (id==104) Copy(#file_path, NOCUT); if (id==104) Copy(#file_path, NOCUT);
@ -470,7 +472,7 @@ void menu_action(dword id)
void draw_window() void draw_window()
{ {
DefineAndDrawWindow(40,20,550,500,0x73,sc.work,TITLE); DefineAndDrawWindow(40,20,550,500,0x73,sc.work,TITLE,0);
GetProcessInfo(#Form, SelfInfo); GetProcessInfo(#Form, SelfInfo);
if (Form.status_window>2) return; if (Form.status_window>2) return;
files.SetSizes(192, 57, onLeft(192,27), onTop(57,6), disc_num*16+195,files.line_h); files.SetSizes(192, 57, onLeft(192,27), onTop(57,6), disc_num*16+195,files.line_h);
@ -651,6 +653,7 @@ void Open_Dir(dword dir_path, redraw){
} }
maxcount = sizeof(file_mas)/sizeof(dword)-1; maxcount = sizeof(file_mas)/sizeof(dword)-1;
if (files.count>maxcount) files.count = maxcount; if (files.count>maxcount) files.count = maxcount;
DrawRamDiskSpace();
} }
if (files.count!=-1) if (files.count!=-1)
{ {
@ -680,7 +683,7 @@ inline Sorting()
} }
FOR (j=files.count-1, off=files.count-1*304+buf+32; j>=0; j--, off-=304;) //files | folders FOR (j=files.count-1, off=files.count-1*304+buf+32; j>=0; j--, off-=304;) //files | folders
{ {
strttl(off+40); if (!real_files_names_case) strttl(off+40);
if (TestBit(ESDWORD[off],4)) //directory? if (TestBit(ESDWORD[off],4)) //directory?
{ {
file_mas[k]=j; file_mas[k]=j;
@ -823,7 +826,7 @@ void SelectFile(dword that_file)
{ {
files.first=files.current=0; files.first=files.current=0;
Open_Dir(#path,ONLY_OPEN); Open_Dir(#path,ONLY_OPEN);
strttl(that_file); if (!real_files_names_case) 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;
List_Current(i); List_Current(i);

View File

@ -1,6 +1,6 @@
char *ext[]={ char *ext[]={
"..", 17, "..", 17,
"<DIR>",16, "<dir>",16, "<DIR>",16,
"txt", 1, "doc", 1, "rtf", 1, "odt", 1, "log", 1, "docx",1, "txt", 1, "doc", 1, "rtf", 1, "odt", 1, "log", 1, "docx",1,
"htm", 2, "html",2, "mht", 2, "htm", 2, "html",2, "mht", 2,
"ini", 3, "js", 3, "conf",3, "inf", 3, "ini", 3, "js", 3, "conf",3, "inf", 3,
@ -30,10 +30,18 @@ char *ext[]={
#include "imgs\icons.txt" #include "imgs\icons.txt"
void Put_icon(dword extension, xx, yy, fairing_color, default_icon) void Put_icon(dword extension, xx, yy, fairing_color, icon_n)
{ {
int icon_n=default_icon, i; int i;
for (i=0; ext[i]!=0; i+=2;) if (!strcmp(extension, ext[i])) { icon_n = ext[i+1]; break; }
if (extension) for (i=0; ext[i]!=0; i+=2;)
{
if (strcmpi(extension, ext[i])==0)
{
icon_n = ext[i+1];
break;
}
}
ficons_pal[0] = fairing_color; ficons_pal[0] = fairing_color;
PutPaletteImage(icon_n*16*15+#ficons,16,15,xx,yy,8,#ficons_pal); PutPaletteImage(icon_n*16*15+#ficons,16,15,xx,yy,8,#ficons_pal);

View File

@ -33,11 +33,15 @@ void GetIni(byte onload)
IF (!strcmp(#parametr,"SelectionColor")) edit2.shift_color=col_selec=StrToCol(#option); IF (!strcmp(#parametr,"SelectionColor")) edit2.shift_color=col_selec=StrToCol(#option);
IF (!strcmp(#parametr,"LineHeight")) files.line_h = atoi(#option); IF (!strcmp(#parametr,"LineHeight")) files.line_h = atoi(#option);
IF (!strcmp(#parametr,"ShowDeviceName")) show_dev_name=atoi(#option); IF (!strcmp(#parametr,"ShowDeviceName")) show_dev_name=atoi(#option);
IF (!strcmp(#parametr,"RealFileNamesCase")) real_files_names_case=atoi(#option);
IF (parametr) && (!strcmp(#file_name+strrchr(#file_name,'.'),#parametr)) && (!onload) IF (parametr) && (!strcmp(#file_name+strrchr(#file_name,'.'),#parametr)) && (!onload)
{ {
errornum=RunProgram(#option,#file_path); errornum = RunProgram(#option,#file_path);
IF (errornum<0) Write_Error(errornum); if (errornum<0)
{
if (errornum==-5) ShowOpenWithDialog(); else Write_Error(errornum);
}
return; return;
} }
parametr=option=NULL; parametr=option=NULL;
@ -50,7 +54,7 @@ void GetIni(byte onload)
} }
if (file_path) && (!onload) if (file_path) && (!onload)
{ {
errornum=RunProgram(#file_path,NULL); errornum = RunProgram(#file_path,NULL);
if (errornum==-31) menu_action(201); else if (errornum<0) Write_Error(errornum); if (errornum==-31) menu_action(201); else if (errornum<0) Write_Error(errornum);
return; return;
} }

View File

@ -1,36 +1,32 @@
//Leency 2008-2013 //Leency 2008-2013
#ifdef LANG_RUS #ifdef LANG_RUS
char *actions[] = { ?define T_DEVICES "“áâனá⢠"
?define T_ACTIONS "„¥©á⢨ï"
char *actions[] = {
57, "<EFBFBD>®¢ë© ä ©«", "F7", 57, "<EFBFBD>®¢ë© ä ©«", "F7",
56, "<EFBFBD>®¢ ï ¯ ¯ª ", "F6", 56, "<EFBFBD>®¢ ï ¯ ¯ª ", "F6",
60, "<EFBFBD> áâனª¨", "F10", 60, "<EFBFBD> áâனª¨", "F10",
0,0,0 0,0,0
}; };
?define T_DEVICES "“áâனá⢠"
?define T_ACTIONS "„¥©á⢨ï"
#elif LANG_EST #elif LANG_EST
char *actions[] = { ?define T_DEVICES "Seadmed"
?define T_ACTIONS "Toimingud"
char *actions[] = {
57, "Uus fail", "F7", 57, "Uus fail", "F7",
56, "Uus kataloog", "F6", 56, "Uus kataloog", "F6",
60, "Seaded", "F10", 60, "Seaded", "F10",
0,0,0 0,0,0
}; };
?define T_DEVICES "Seadmed"
?define T_ACTIONS "Toimingud"
#else #else
char *actions[] = { ?define T_DEVICES "Devices"
?define T_ACTIONS "Actions"
char *actions[] = {
57, "New file", "F7", 57, "New file", "F7",
56, "New folder", "F6", 56, "New folder", "F6",
60, "Options", "F10", 60, "Options", "F10",
0,0,0 0,0,0
}; };
?define T_DEVICES "Devices"
?define T_ACTIONS "Actions"
#endif #endif
@ -77,15 +73,30 @@ void SystemDiscsGet()
strcpy(#disk_list[disc_num].Item, #sys_discs); strcpy(#disk_list[disc_num].Item, #sys_discs);
disc_num++; disc_num++;
} }
if (strcmp(#disk_list[disc_num-1].Item, "/rd/1/")==0) if (GetDir(nullbuf, nullbuf, "/kolibrios/", DIRS_ALL)==0) if (strcmp(#disk_list[disc_num-1].Item, "/rd/1/")==0)
{
if (GetDir(nullbuf, nullbuf, "/kolibrios/", DIRS_ALL)==0)
{ {
strcpy(#disk_list[disc_num].Item, "/kolibrios/"); strcpy(#disk_list[disc_num].Item, "/kolibrios/");
kolibrios_drive = true; kolibrios_drive = true;
disc_num++; disc_num++;
} else kolibrios_drive = false; } else kolibrios_drive = false;
} }
}
} }
void DrawRamDiskSpace()
{
int free_rd_space = GetFreeRamDiskClusters() * 49 / ALL_RD_CLUSTERS;
DefineButton(120, 80, 49, 4, 27+BT_HIDE, 0);
if (!free_rd_space)
DrawBar(121, 81, 49-free_rd_space, 3, 0xFF0000);
else
{
DrawBar(121, 81, 49-free_rd_space, 3, 0x7A7F84);
DrawBar(121+49-free_rd_space, 81, free_rd_space, 3, 0xC4C4C4);
}
}
void SystemDiscsDraw() void SystemDiscsDraw()
{ {
@ -109,6 +120,7 @@ void SystemDiscsDraw()
case 'r': case 'r':
dev_icon=0; dev_icon=0;
strcpy(#disc_name, "System "); strcpy(#disc_name, "System ");
DrawRamDiskSpace();
break; break;
case 'c': case 'c':
dev_icon=1; dev_icon=1;
@ -143,8 +155,7 @@ void SystemDiscsDraw()
strcpy(#disc_name, "Unknown "); strcpy(#disc_name, "Unknown ");
} }
strcat(#disc_name, #dev_name); strcat(#disc_name, #dev_name);
if (show_dev_name) WriteText(45,i*16+79,0x80,0,#disc_name); if (show_dev_name) WriteText(45,i*16+79,0x80,0,#disc_name); else WriteText(45,i*16+79,0x80,0,#dev_name);
else WriteText(45,i*16+79,0x80,0,#dev_name);
_PutImage(21,i*16+76, 14,13, dev_icon*14*13*3+#devices); _PutImage(21,i*16+76, 14,13, dev_icon*14*13*3+#devices);
} }
} }

View File

@ -1,5 +1,11 @@
//Leency 2013 //Leency 2013
void ShowOpenWithDialog()
{
SwitchToAnotherThread();
CreateThread(#OpenWith,#open_with_stak+4092);
}
llist app_list; llist app_list;
struct app_list_string { char item[1024]; char ext[5]; }; struct app_list_string { char item[1024]; char ext[5]; };
app_list_string app_paths[100]; app_list_string app_paths[100];

View File

@ -75,3 +75,38 @@ void DrawFilledBar(dword x, y, w, h)
for (i=0; i<fill_h; i++) DrawBar(x, y+i, w, 1, col_palette[14-i]); for (i=0; i<fill_h; i++) DrawBar(x, y+i, w, 1, col_palette[14-i]);
DrawBar(x, y+i, w, h-fill_h, col_palette[14-i]); DrawBar(x, y+i, w, h-fill_h, col_palette[14-i]);
} }
struct rd_info
{
dword function_number, reserved[4];
char path[4];
} rd_info;
#define ALL_RD_CLUSTERS 2847
int GetFreeRamDiskClusters()
{
dword free_size;
static dword old_free_size;
rd_info.function_number = 15;
strcpy(#rd_info.path, "/rd");
$mov eax,58
$mov ebx, #rd_info;
$int 0x40
if (EAX==0)
{
free_size=ECX;
old_free_size = ECX;
}
else
{
debugi(EAX);
free_size = old_free_size;
}
return free_size;
}