(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
#define TITLE "Eolite File Manager v2.0.4"
#define ABOUT_TITLE "Eolite v2.0.4"
#define TITLE "Eolite File Manager v2.15"
#define ABOUT_TITLE "Eolite v2.15"
dword col_padding, col_selec, col_lpanel;
int toolbar_buttons_x[7]={9,46,85,134,167,203};
@ -103,6 +103,7 @@ byte
rename_active=0,
del_active=0,
show_dev_name=1,
real_files_names_case=0,
sort_num=2,
itdir;
@ -310,6 +311,13 @@ void main()
case 26: //paste
CreateThread(#Paste,#copy_stak+4092);
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
IF(sort_num==1) 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);
break;
case 173: //Ctrl+Enter
if (!itdir)
{
SwitchToAnotherThread();
CreateThread(#OpenWith,#open_with_stak+4092);
}
if (!itdir) ShowOpenWithDialog();
break;
case 178: //up
List_Current(-1);
@ -444,6 +448,8 @@ void main()
}
}
void menu_action(dword id)
{
if (id==COPY_PASTE_END)
@ -452,11 +458,7 @@ void menu_action(dword id)
SelectFile(#copy_to+strrchr(#copy_to,'/'));
}
if (id==100) Open();
if (id==201)
{
SwitchToAnotherThread();
CreateThread(#OpenWith,#open_with_stak+4092);
}
if (id==201) ShowOpenWithDialog();
if (id==202) FnProcess(3); //F3
if (id==203) FnProcess(4); //F4
if (id==104) Copy(#file_path, NOCUT);
@ -470,7 +472,7 @@ void menu_action(dword id)
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);
if (Form.status_window>2) return;
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;
if (files.count>maxcount) files.count = maxcount;
DrawRamDiskSpace();
}
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
{
strttl(off+40);
if (!real_files_names_case) strttl(off+40);
if (TestBit(ESDWORD[off],4)) //directory?
{
file_mas[k]=j;
@ -823,7 +826,7 @@ void SelectFile(dword that_file)
{
files.first=files.current=0;
Open_Dir(#path,ONLY_OPEN);
strttl(that_file);
if (!real_files_names_case) strttl(that_file);
for (i=files.count-1; i>=0; i--;)
if (!strcmp(file_mas[i]*304+buf+72,that_file)) break;
List_Current(i);

View File

@ -1,6 +1,6 @@
char *ext[]={
"..", 17,
"<DIR>",16,
"<dir>",16, "<DIR>",16,
"txt", 1, "doc", 1, "rtf", 1, "odt", 1, "log", 1, "docx",1,
"htm", 2, "html",2, "mht", 2,
"ini", 3, "js", 3, "conf",3, "inf", 3,
@ -30,10 +30,18 @@ char *ext[]={
#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;
for (i=0; ext[i]!=0; i+=2;) if (!strcmp(extension, ext[i])) { icon_n = ext[i+1]; break; }
int i;
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;
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,"LineHeight")) files.line_h = 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)
{
errornum=RunProgram(#option,#file_path);
IF (errornum<0) Write_Error(errornum);
errornum = RunProgram(#option,#file_path);
if (errornum<0)
{
if (errornum==-5) ShowOpenWithDialog(); else Write_Error(errornum);
}
return;
}
parametr=option=NULL;
@ -50,7 +54,7 @@ void GetIni(byte 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);
return;
}

View File

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

View File

@ -1,5 +1,11 @@
//Leency 2013
void ShowOpenWithDialog()
{
SwitchToAnotherThread();
CreateThread(#OpenWith,#open_with_stak+4092);
}
llist app_list;
struct app_list_string { char item[1024]; char ext[5]; };
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]);
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;
}