mirror of
https://github.com/edeproject/ede.git
synced 2023-08-10 21:13:03 +03:00
Fully functional Directory Tree! Also: we don't update the invisible view cause it's slow on some old machines
This commit is contained in:
parent
6caac376c9
commit
0fc70e80bd
@ -1,5 +1,5 @@
|
|||||||
|
|
||||||
CPPFILES = efiler.cpp ../edelib2/MimeType.cpp ../edelib2/Run.cpp ../edelib2/process.cpp ../edelib2/pty.cpp ../edelib2/Config.cpp ../edelib2/Icon.cpp ../edelib2/Util.cpp ../edelib2/about_dialog.cpp
|
CPPFILES = efiler.cpp EDE_FileBrowser.cpp EDE_DirTree.cpp ../edelib2/MimeType.cpp ../edelib2/Run.cpp ../edelib2/process.cpp ../edelib2/pty.cpp ../edelib2/Config.cpp ../edelib2/Icon.cpp ../edelib2/Util.cpp ../edelib2/about_dialog.cpp
|
||||||
TARGET = efiler
|
TARGET = efiler
|
||||||
|
|
||||||
include ../makeinclude
|
include ../makeinclude
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include <fltk/Divider.h>
|
#include <fltk/Divider.h>
|
||||||
#include <fltk/file_chooser.h>
|
#include <fltk/file_chooser.h>
|
||||||
//#include <fltk/FileBrowser.h>
|
//#include <fltk/FileBrowser.h>
|
||||||
|
#include <fltk/TiledGroup.h>
|
||||||
|
|
||||||
#include "../edelib2/about_dialog.h"
|
#include "../edelib2/about_dialog.h"
|
||||||
#include "../edelib2/Icon.h"
|
#include "../edelib2/Icon.h"
|
||||||
@ -32,6 +33,7 @@
|
|||||||
#include "../edelib2/Util.h"
|
#include "../edelib2/Util.h"
|
||||||
|
|
||||||
#include "EDE_FileBrowser.h"
|
#include "EDE_FileBrowser.h"
|
||||||
|
#include "EDE_DirTree.h"
|
||||||
|
|
||||||
|
|
||||||
#define DEFAULT_ICON "misc-vedran"
|
#define DEFAULT_ICON "misc-vedran"
|
||||||
@ -43,11 +45,14 @@ using namespace edelib;
|
|||||||
|
|
||||||
|
|
||||||
Window *win;
|
Window *win;
|
||||||
|
TiledGroup* tile;
|
||||||
ScrollGroup* sgroup;
|
ScrollGroup* sgroup;
|
||||||
FileBrowser* fbrowser;
|
FileBrowser* fbrowser;
|
||||||
|
DirTree* dirtree;
|
||||||
char current_dir[PATH_MAX];
|
char current_dir[PATH_MAX];
|
||||||
static bool semaphore=false;
|
static bool semaphore=false;
|
||||||
bool showhidden = false;
|
bool showhidden = false;
|
||||||
|
bool showtree = false;
|
||||||
|
|
||||||
char **cut_copy_buffer = 0;
|
char **cut_copy_buffer = 0;
|
||||||
bool operation_is_copy = false;
|
bool operation_is_copy = false;
|
||||||
@ -108,11 +113,14 @@ void loaddir(const char *path) {
|
|||||||
if (current_dir[strlen(current_dir)-1] != '/') strcat(current_dir,"/");
|
if (current_dir[strlen(current_dir)-1] != '/') strcat(current_dir,"/");
|
||||||
fprintf (stderr, "loaddir(%s) = (%s)\n",path,current_dir);
|
fprintf (stderr, "loaddir(%s) = (%s)\n",path,current_dir);
|
||||||
|
|
||||||
|
// Update directory tree
|
||||||
|
dirtree->set_current(current_dir);
|
||||||
|
|
||||||
// set window label
|
// set window label
|
||||||
win->label(tasprintf(_("%s - File manager"), current_dir));
|
win->label(tasprintf(_("%s - File manager"), current_dir));
|
||||||
|
|
||||||
// Update file browser...
|
// Update file browser...
|
||||||
fbrowser->load(current_dir);
|
if (fbrowser->visible()) { fbrowser->load(current_dir); semaphore=false; return; }
|
||||||
|
|
||||||
// some constants - TODO: move to configuration
|
// some constants - TODO: move to configuration
|
||||||
int startx=0, starty=0;
|
int startx=0, starty=0;
|
||||||
@ -240,6 +248,13 @@ fprintf(stderr,"Adding: %s (%s), cmd: '%s'\n", fullpath, m->id(), m->command());
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Directory tree callback
|
||||||
|
void dirtree_cb(Widget* w, void*) {
|
||||||
|
if (!event_clicks() && event_key() != ReturnKey) return;
|
||||||
|
char *d = (char*) dirtree->item()->user_data();
|
||||||
|
if (d && strlen(d)>0) loaddir(d);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// List view
|
// List view
|
||||||
// Currently using fltk::FileBrowser which is quite ugly (so only callback is here)
|
// Currently using fltk::FileBrowser which is quite ugly (so only callback is here)
|
||||||
@ -387,15 +402,10 @@ void iconsview_cb(Widget*,void*) {
|
|||||||
fbrowser->hide();
|
fbrowser->hide();
|
||||||
sgroup->take_focus();
|
sgroup->take_focus();
|
||||||
}
|
}
|
||||||
|
// We update the inactive view only when it's shown i.e. now
|
||||||
|
loaddir(current_dir);
|
||||||
}
|
}
|
||||||
void listview_cb(Widget*,void*) { sgroup->hide(); fbrowser->show(); }
|
void listview_cb(Widget*,void*) { sgroup->hide(); fbrowser->show(); }
|
||||||
void refresh_cb(Widget*,void*) {
|
|
||||||
if(sgroup->visible()) loaddir(current_dir);
|
|
||||||
else fbrowser->load(current_dir);
|
|
||||||
}
|
|
||||||
void case_cb(Widget*,void*) {
|
|
||||||
fprintf(stderr,"Not implemented yet...\n");
|
|
||||||
}
|
|
||||||
void showhidden_cb(Widget* w, void*) {
|
void showhidden_cb(Widget* w, void*) {
|
||||||
Item *i = (Item*)w;
|
Item *i = (Item*)w;
|
||||||
if (showhidden) {
|
if (showhidden) {
|
||||||
@ -409,6 +419,21 @@ void showhidden_cb(Widget* w, void*) {
|
|||||||
//fbrowser->redraw();
|
//fbrowser->redraw();
|
||||||
loaddir(current_dir);
|
loaddir(current_dir);
|
||||||
}
|
}
|
||||||
|
void showtree_cb(Widget*,void*) {
|
||||||
|
if (!showtree) {
|
||||||
|
tile->position(1,0,150,0);
|
||||||
|
showtree=true;
|
||||||
|
} else {
|
||||||
|
tile->position(150,0,0,0);
|
||||||
|
showtree=false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void refresh_cb(Widget*,void*) {
|
||||||
|
loaddir(current_dir);
|
||||||
|
}
|
||||||
|
void case_cb(Widget*,void*) {
|
||||||
|
fprintf(stderr,"Not implemented yet...\n");
|
||||||
|
}
|
||||||
|
|
||||||
// Help menu
|
// Help menu
|
||||||
void about_cb(Widget*, void*) { about_dialog("EFiler", "0.1", _("EDE File Manager"));}
|
void about_cb(Widget*, void*) { about_dialog("EFiler", "0.1", _("EDE File Manager"));}
|
||||||
@ -496,6 +521,7 @@ int main (int argc, char **argv) {
|
|||||||
{Item *o = new Item(_("Directory &Tree"));
|
{Item *o = new Item(_("Directory &Tree"));
|
||||||
o->type(Item::TOGGLE);
|
o->type(Item::TOGGLE);
|
||||||
o->shortcut(F9Key);
|
o->shortcut(F9Key);
|
||||||
|
o->callback(showtree_cb);
|
||||||
}
|
}
|
||||||
new Divider();
|
new Divider();
|
||||||
{Item *o = new Item(_("&Refresh"));
|
{Item *o = new Item(_("&Refresh"));
|
||||||
@ -508,7 +534,6 @@ int main (int argc, char **argv) {
|
|||||||
{Item *o = new Item(_("&Case sensitive"));
|
{Item *o = new Item(_("&Case sensitive"));
|
||||||
//o->type();
|
//o->type();
|
||||||
o->callback(case_cb);
|
o->callback(case_cb);
|
||||||
o->shortcut(F5Key);
|
|
||||||
}
|
}
|
||||||
o->end();
|
o->end();
|
||||||
}
|
}
|
||||||
@ -525,8 +550,22 @@ int main (int argc, char **argv) {
|
|||||||
m->end();
|
m->end();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Main tiled group
|
||||||
|
{tile = new TiledGroup(0, 25, 600, 375);
|
||||||
|
tile->color(WHITE);
|
||||||
|
tile->begin();
|
||||||
|
|
||||||
|
// Directory tree
|
||||||
|
{dirtree = new DirTree(0, 0, 150, 375);
|
||||||
|
dirtree->box(DOWN_BOX);
|
||||||
|
dirtree->color(WHITE);
|
||||||
|
dirtree->load();
|
||||||
|
dirtree->callback(dirtree_cb);
|
||||||
|
dirtree->when(WHEN_CHANGED|WHEN_ENTER_KEY);
|
||||||
|
}
|
||||||
|
|
||||||
// Icon view
|
// Icon view
|
||||||
{sgroup = new ScrollGroup(0, 25, 600, 375);
|
{sgroup = new ScrollGroup(150, 0, 450, 375);
|
||||||
sgroup->box(DOWN_BOX);
|
sgroup->box(DOWN_BOX);
|
||||||
sgroup->color(WHITE);
|
sgroup->color(WHITE);
|
||||||
// sgroup->highlight_color(WHITE);
|
// sgroup->highlight_color(WHITE);
|
||||||
@ -536,7 +575,7 @@ int main (int argc, char **argv) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// List view
|
// List view
|
||||||
{fbrowser = new FileBrowser(0, 25, 600, 375);
|
{fbrowser = new FileBrowser(150, 0, 450, 375);
|
||||||
fbrowser->box(DOWN_BOX);
|
fbrowser->box(DOWN_BOX);
|
||||||
fbrowser->color(WHITE);
|
fbrowser->color(WHITE);
|
||||||
fbrowser->callback(fbrowser_cb);
|
fbrowser->callback(fbrowser_cb);
|
||||||
@ -547,9 +586,14 @@ int main (int argc, char **argv) {
|
|||||||
fbrowser->type(Browser::MULTI);
|
fbrowser->type(Browser::MULTI);
|
||||||
fbrowser->hide();
|
fbrowser->hide();
|
||||||
}
|
}
|
||||||
|
tile->end();
|
||||||
|
}
|
||||||
|
|
||||||
|
// We hide dirtree and browser expands to fill space
|
||||||
|
tile->position(150,0,1,0);
|
||||||
|
|
||||||
win->end();
|
win->end();
|
||||||
win->resizable(sgroup);
|
win->resizable(tile);
|
||||||
win->icon(Icon::get("folder",Icon::TINY));
|
win->icon(Icon::get("folder",Icon::TINY));
|
||||||
win->show();
|
win->show();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user