Subversion Repositories Kolibri OS

Compare Revisions

Regard whitespace Rev 8955 → Rev 8956

/programs/cmm/eolite/Eolite.c
4,16 → 4,13
/*
BUGS:
- fix a kfm2 bug with selected files on window deactivation
- back button broken
- bug with going to wrong path (related to prior issue?)
TODO:
- 70.5 - get volume info and label
- click on a path bar dropdown opens breadcrumbs
*/
 
#define ABOUT_TITLE "EOLITE 5 Beta12"
#define TITLE_EOLITE "Eolite File Manager 5 Beta12"
#define TITLE_KFM "Kolibri File Manager 2 Beta12";
#define ABOUT_TITLE "EOLITE 5 RC6"
#define TITLE_EOLITE "Eolite File Manager 5 RC6"
#define TITLE_KFM "Kolibri File Manager 2 RC6";
 
#define MEMSIZE 1024 * 250
#include "../lib/clipboard.h"
60,7 → 57,7
_history history;
 
//Folder data
dword buf;
dword buf, buf_inactive;
collection_int items=0;
int selected_count;
int folder_count;
94,7 → 91,6
 
//Multipanes
int active_panel=0;
int disk_popin_active_on_panel=0;
#define PANES_COUNT 2
dword location[PANES_COUNT];
llist files, files_active, files_inactive;
189,7 → 185,7
handle_param();
 
SystemDiscs.Get();
Open_Dir(path,ONLY_OPEN);
OpenDir(ONLY_OPEN);
llist_copy(#files_inactive, #files);
SetEventMask(EVM_REDRAW+EVM_KEY+EVM_BUTTON+EVM_MOUSE+EVM_MOUSE_FILTER);
loop() switch(@WaitEventTimeout(100))
304,15 → 300,19
}
 
if (active_popin) {
if (POPUP_BTN2==id) { EventClosePopinForm(); break; }
if (POPUP_BTN1==id) { EventPopinClickOkay(); break; }
 
if (POPIN_DISK==active_popin) {
if (id>=100) && (id<=120) {
active_popin = NULL;
EventDriveClick(id);
EventDriveClick(id-100);
}
EventClosePopinForm(); //POPIN_DISK create close btn with POPUP_BTN2
break; }
if (POPUP_BTN2==id) EventClosePopinForm();
if (POPUP_BTN1==id) EventPopinClickOkay();
 
if (POPIN_BREADCR==active_popin) {
EventClosePopinForm();
ClickOnBreadCrumb(id-BREADCRUMB_ID);
}
 
break;
}
 
343,11 → 343,8
FnProcess(id-50);
break;
case 100...120:
EventDriveClick(id);
EventDriveClick(id-100);
break;
case BREADCRUMB_ID...360:
ClickOnBreadCrumb(id-BREADCRUMB_ID);
break;
case KFM_FUNC_ID...KFM_FUNC_ID+10:
FnProcess(id-KFM_FUNC_ID);
break;
366,8 → 363,8
 
if (POPIN_DISK == active_popin) {
if (key_scancode >= SCAN_CODE_1)
&& (key_scancode >= SCAN_CODE_10) {
EventDriveClick(key_scancode-1+100);
&& (key_scancode <= SCAN_CODE_10) {
EventDriveClick(key_scancode-2);
}
} else {
if (key_scancode == SCAN_CODE_ENTER) EventPopinClickOkay();
415,10 → 412,10
key_scancode-=2;
if (key_scancode >= SystemDiscs.list.count) break;
if (!efm) {
DrawRectangle(17,key_scancode*16+74,159,16, 0); //display click
DrawRectangle(17,key_scancode*17+74,159,17, 0); //display click
pause(7);
}
SystemDiscs.Click(key_scancode);
EventDriveClick(key_scancode);
break;
case SCAN_CODE_KEY_X:
CopyFilesListToClipboard(CUT);
582,11 → 579,14
llist_copy(#files_active, #files);
DrawStatusBar();
if (!selected_count) {
Open_Dir(path,ONLY_OPEN); //if there are no selected files -> refresh folder [L001]
OpenDir(ONLY_OPEN); //if there are no selected files -> refresh folder [L001]
}
DrawFilePanels();
disk_popin_active_on_panel = 0;
 
if (files.x!=files_inactive.x) {
if (active_popin) ShowPopinForm(active_popin);
}
}
 
void DrawButtonsAroundList()
{
673,7 → 673,7
files_inactive.x = files.x;
DrawButtonsAroundList();
path = location[active_panel^1];
Open_Dir(path,WITH_REDRAW);
OpenDir(WITH_REDRAW);
if (!selected_count) files_inactive.count = files.count;
llist_copy(#files, #files_active);
 
685,7 → 685,7
 
DrawButtonsAroundList();
path = location[active_panel];
Open_Dir(path,WITH_REDRAW);
OpenDir(WITH_REDRAW);
}
}
 
727,11 → 727,7
DrawBar(files.x+files.w-141,all_lines_h + files.y,1,files.h - all_lines_h, separator_color);
DrawBar(files.x+files.w-68,all_lines_h + files.y,1,files.h - all_lines_h, separator_color);
DrawScroll(scroll_used);
 
if (files.x!=files_inactive.x) {
if (active_popin) ShowPopinForm(active_popin);
}
}
 
void Line_ReDraw(dword bgcol, filenum){
dword text_col=col.list_gb_text,
836,12 → 832,12
}
 
 
void Open_Dir(dword dir_path, redraw){
void OpenDir(char redraw){
int errornum;
 
selected_count = 0;
if (buf) free(buf);
if (errornum = GetDir(#buf, #files.count, dir_path, DIRS_NOROOT))
if (errornum = GetDir(#buf, #files.count, path, DIRS_NOROOT))
{
history.add(path);
EventHistoryGoBack();
850,16 → 846,15
}
if (files.count>0) && (files.cur_y-files.first==-1) files.cur_y=0;
 
history.add(path);
SystemDiscs.Draw();
files.visible = files.h / files.item_h;
if (files.count < files.visible) files.visible = files.count;
if (!strncmp(dir_path, "/rd/1",5)) || (!strncmp(dir_path, "/sys/",4))
files.visible = math.min(files.h / files.item_h, files.count);
if (!strncmp(path, "/rd/1",5)) || (!strncmp(path, "/sys/",4))
dir_at_fat16 = true; else dir_at_fat16 = false;
Sorting();
list_full_redraw = true;
SetCurDir(dir_path);
SetCurDir(path);
if (redraw!=ONLY_OPEN) {
history.add(path);
List_ReDraw();
DrawStatusBar();
DrawPathBar();
914,7 → 909,7
{
int ind;
files.KeyHome();
Open_Dir(path,ONLY_OPEN);
OpenDir(ONLY_OPEN);
if (dir_at_fat16) && (file_name_is_8_3(that_file)) strttl(that_file);
for (ind=files.count-1; ind>=0; ind--;) { if (!strcmpi(items.get(ind)*304+buf+72,that_file)) break; }
files.cur_y = ind - 1;
967,11 → 962,11
if (!strncmp(#file_name,"..",3)) { Dir_Up(); return; }
strcpy(path, #file_path);
files.first=files.cur_y=0;
Open_Dir(path,WITH_REDRAW);
OpenDir(WITH_REDRAW);
}
}
 
inline fastcall void EventHistoryGoBack()
void EventHistoryGoBack()
{
char cur_folder[4096];
strcpy(#cur_folder, path);
978,9 → 973,21
if (history.back()) {
strcpy(path, history.current());
SelectFileByName(#cur_folder+strrchr(#cur_folder,'/'));
DrawPathBar();
}
}
 
void EventHistoryGoForward()
{
if (history.forward()) {
strcpy(path, history.current());
files.KeyHome();
OpenDir(WITH_REDRAW);
DrawPathBar();
}
}
 
 
void ShowOpenWithDialog()
{
byte open_param[4097];
1017,7 → 1024,6
}
}
}
Open_Dir(path,WITH_REDRAW);
SelectFileByName(popin_text.text);
return true;
__FAIL:
1030,7 → 1036,7
switch(active_popin) {
case POPIN_PATH:
strcpy(path, #popin_string);
Open_Dir(path, WITH_REDRAW);
OpenDir(WITH_REDRAW);
break;
case POPIN_DELETE:
CopyFilesListToClipboard(DELETE);
1091,7 → 1097,7
WriteTextCenter(popinx, 192, POPIN_W, sc.work_text, #param);
break;
case POPIN_DISK:
DefineHiddenButton(0,0,5000,3000,9999+BT_NOFRAME);
DefineHiddenButton(0,0,5000,3000,POPUP_BTN2+BT_NOFRAME);
if (active_panel==0) {
SystemDiscs.DrawOptions(1);
} else {
1099,9 → 1105,8
}
break;
case POPIN_BREADCR:
notify("'Not implemented yet' C");
return;
//DrawBreadCrumbs();
DefineHiddenButton(0,0,5000,3000,POPUP_BTN2+BT_NOFRAME);
DrawBreadCrumbs();
break;
}
active_popin = _popin_type;
1229,7 → 1234,7
SystemDiscs.Draw();
}
}
if(GetRealFileCountInFolder(path) != files.count) Open_Dir(path,WITH_REDRAW);
if(GetRealFileCountInFolder(path) != files.count) OpenDir(WITH_REDRAW);
}
 
void EventManualFolderRefresh()
1246,19 → 1251,10
else sort_type = id;
strcpy(#selected_filename, #file_name);
DrawButtonsAroundList();
Open_Dir(path,WITH_REDRAW);
OpenDir(WITH_REDRAW);
SelectFileByName(#selected_filename);
}
 
void EventHistoryGoForward()
{
if (history.forward()) {
strcpy(path, history.current());
files.KeyHome();
Open_Dir(path,WITH_REDRAW);
}
}
 
void EventOpenNewEolite()
{
RunProgram(I_Path, path);
1368,10 → 1364,14
 
void EventDriveClick(int __id)
{
if (__id >= SystemDiscs.list.count) return;
if (efm) {
EventClosePopinForm();
draw_window();
}
SystemDiscs.Click(__id-100);
strcpy(path, SystemDiscs.list.get(__id));
files.KeyHome();
OpenDir(WITH_REDRAW);
}
 
stop:
/programs/cmm/eolite/include/gui.h
178,8 → 178,6
void DrawPathEolite()
{
PathShow.text_pointer = location[0];
PathShow.start_x = 250;
PathShow.start_y = 17;
PathShow.area_size_x = Form.cwidth-300;
DrawBar(PathShow.start_x-3, PathShow.start_y-6, PathShow.area_size_x+3, 19, col.odd_line);
DrawRectangle(PathShow.start_x-4,PathShow.start_y-7,PathShow.area_size_x+4,20,sc.work_graph);
232,13 → 230,14
void DrawBreadCrumbs()
collection_int breadCrumb=0;
char PathShow_path[4096];
block btn;
int btnx;
int i;
unsigned text_line;
{
breadCrumb.drop();
strcpy(#PathShow_path, "/<root>");
if (ESBYTE[path+1]) {
strcat(#PathShow_path, path);
for (i=0; i<50; i++) DeleteButton(i+BREADCRUMB_ID);
breadCrumb.drop();
}
for (i=0; (PathShow_path[i]) && (i<sizeof(PathShow_path)-1); i++)
{
if (PathShow_path[i]=='/') {
247,38 → 246,29
}
}
breadCrumb.add(i+1);
btn.set_size(246,10,NULL,20);
//area_w = Form.cwidth - btn.x - 20;
for (i=0; i<breadCrumb.count-1; i++)
{
text_line = breadCrumb.get(i) + #PathShow_path; ///EDI!
btn.w = strlen(text_line)*8+10;
DrawBreadcrumbButton(btn.x, btn.y, btn.w, btn.h, i+BREADCRUMB_ID, text_line);
btn.y += btn.h;
 
if (!efm) btnx = 250-4;
else btnx = Form.cwidth/2-2*active_panel + DDW + 2;
 
for (i=0; i<breadCrumb.count-1; i++) {
EDI = breadCrumb.get(i) + #PathShow_path;
DrawFlatButtonSmall(btnx, KFM2_DEVH-1*i+SELECTY+KFM2_DEVH,
250, KFM2_DEVH, i+BREADCRUMB_ID, EDI);
}
btn.x++;
DrawBar(btn.x,btn.y-1,Form.cwidth-btn.x-25,btn.h+3,sc.work);
}
 
void ClickOnBreadCrumb(unsigned clickid)
{
int i, slashpos = path;
for (i=0; i!=clickid+2; i++) {
if (!clickid) {
ESBYTE[path+1] = '\0';
} else {
for (i=1; i!=clickid+2; i++) {
slashpos=strchr(slashpos,'/')+1;
}
ESBYTE[slashpos-1] = NULL;
Open_Dir(path,WITH_REDRAW);
ESBYTE[slashpos-1] = '\0';
}
 
void DrawBreadcrumbButton(dword x,y,w,h,id,text)
{
int i;
DrawRectangle(x,y,w,h,sc.work_graph);
for (i=0; (i<h-1) & (i<20); i++) DrawBar(x+1, y+i+1, w-1, 1, col.work_gradient[20-i]);
DrawRectangle3D(x+1,y+1,w-2,h-2,sc.work_light, sc.work_dark);
DefineHiddenButton(x+1,y+1,w-2,h-2,id);
WriteText(-strlen(text)*8+w/2+x,h/2+y-7,0x90,sc.work_text,text);
DrawBar(x, y+h+1, w+1, 1, sc.work_light);
OpenDir(WITH_REDRAW);
}
 
//===================================================//
/programs/cmm/eolite/include/left_panel.h
7,7 → 7,6
void Draw();
void DrawSelect();
void DrawOptions();
void Click();
} SystemDiscs=0;
 
void _SystemDiscs::Get()
149,10 → 148,4
}
}
 
void _SystemDiscs::Click(int n)
{
strcpy(path, list.get(n));
files.KeyHome();
Open_Dir(path,WITH_REDRAW);
}
 
/programs/cmm/eolite/include/properties.h
131,7 → 131,7
}
 
cmd_free=3;
Open_Dir(path,ONLY_OPEN);
OpenDir(ONLY_OPEN);
ExitProcess();
}