fix up dnd with .order files linking etc - make it explicit as to the

behavior (becuase in a normal fm u expect the file to MOVE not link)


SVN revision: 27173
This commit is contained in:
Carsten Haitzler 2006-11-19 03:43:18 +00:00
parent 39742ff70b
commit addf4cffa5
6 changed files with 208 additions and 146 deletions

13
TODO
View File

@ -14,8 +14,6 @@ Some of the things (in very short form) that need to be done to E17...
circumstances. circumstances.
* e_apps wont pick up changes in favorite menu dirs made by the applications * e_apps wont pick up changes in favorite menu dirs made by the applications
config dialog after a while (i think once u get 1 app in it stops listening) config dialog after a while (i think once u get 1 app in it stops listening)
* fm2 will not create a .order file when it needs to, like when DND to an empty
~./e/e/applications/startup directory.
]]] ]]]
[[[ [[[
@ -23,22 +21,21 @@ Some of the things (in very short form) that need to be done to E17...
ESSENTIAL FEATURES ESSENTIAL FEATURES
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
* fm2 needs recursive deletes, moves, etc. that run in the "background"
(idlers, etc.) and might pop up a progress dialog (or display progress in
the fm2 view somehow).
* fm2 needs a right-click file properties dialog * fm2 needs a right-click file properties dialog
* fm2 needs a way to set custom backgrounds and handle scrolling * fm2 needs a way to set custom backgrounds and handle scrolling
* fm2 needs to display symlink info on files somehow * fm2 needs to display symlink info on files somehow
* fm2 needs to display more than 1 file being dragged (if more than 1 is being * fm2 needs to display more than 1 file being dragged (if more than 1 is being
dragged) dragged)
* fm2 needs a way of mapping a mimetype to 1 or more commands to execute or * fm2 needs a way of mapping a internal e actions to do (like add as
internal e actions to do (like add as wallpaper etc.) wallpaper etc.)
* fm2 needs a way to use custom icons per dir/file * fm2 needs a way to use custom icons per dir/file
* fm2 needs a way to bypass thumb gen anim on just a unrealize/realize as well * fm2 needs a way to bypass thumb gen anim on just a unrealize/realize as well
as change state instantly if it already was selected as change state instantly if it already was selected
* fm2 needs a mime filter * fm2 needs a mime filter
* fm2: implement e_fm2_all_icons_update()
* fm2 will pop up tonnes of error dialogs if u try delete a lot of files in a
tree you can't delete - fix to make this a dialog with a log etc.
* dnd needs to do xdnd properly. * dnd needs to do xdnd properly.
* fwin: multi-mime open is too simplisitc. fix in fwin.c line 590 or so.
* fm2 needs icon views (auto-arrange, snap to grid and free placement), for * fm2 needs icon views (auto-arrange, snap to grid and free placement), for
fwin windows and the desktop fwin windows and the desktop
* middle mouse on gadgets as a quick move/resize thing? * middle mouse on gadgets as a quick move/resize thing?

View File

@ -24,7 +24,9 @@ typedef enum _E_Fm2_Action_Type
typedef enum _E_Fm2_Fop_Type typedef enum _E_Fm2_Fop_Type
{ {
FOP_DELETE, FOP_DELETE,
FOP_MOVE FOP_MOVE,
FOP_LINK,
FOP_ADD
} E_Fm2_Fop_Type; } E_Fm2_Fop_Type;
typedef struct _E_Fm2_Smart_Data E_Fm2_Smart_Data; typedef struct _E_Fm2_Smart_Data E_Fm2_Smart_Data;
@ -177,8 +179,12 @@ struct _E_Fm2_Fop_Item
E_Fm2_Fop_Type type; E_Fm2_Fop_Type type;
E_Fm2_Fop *fop; E_Fm2_Fop *fop;
const char *file; const char *file;
const char *file2;
const char *file3;
int after;
DIR *dir; DIR *dir;
unsigned char is_dir : 1; unsigned char is_dir : 1;
unsigned char file_add : 1;
}; };
static const char *_e_fm2_dev_path_map(const char *dev, const char *path); static const char *_e_fm2_dev_path_map(const char *dev, const char *path);
@ -768,7 +774,7 @@ e_fm2_pan_child_size_get(Evas_Object *obj, Evas_Coord *w, Evas_Coord *h)
EAPI void EAPI void
e_fm2_all_icons_update(void) e_fm2_all_icons_update(void)
{ {
/* FIXME: implement - update all icons as config changes */ /* FIXME: implement - update all icons in all fm2's as config changed */
} }
EAPI void EAPI void
@ -812,16 +818,71 @@ e_fm2_fop_delete_add(Evas_Object *obj, E_Fm2_Icon_Info *ici)
// printf("ADD0: %s\n", fi->file); // printf("ADD0: %s\n", fi->file);
} }
/* FIXME: not so easy with .orders etc. */ EAPI void
EAPI void e_fm2_fop_move_add(Evas_Object *obj, const char *src, const char *dst, const char *rel, int after, int file_add)
e_fm2_fop_move_add(Evas_Object *obj, E_Fm2_Icon_Info *ici, Evas_Object *obj2, const char *fname)
{ {
E_Fm2_Smart_Data *sd; E_Fm2_Smart_Data *sd;
E_Fm2_Fop *fop;
E_Fm2_Fop_Item *fi;
sd = evas_object_smart_data_get(obj); sd = evas_object_smart_data_get(obj);
if (!sd) return; // safety if (!sd) return; // safety
if (!evas_object_type_get(obj)) return; // safety if (!evas_object_type_get(obj)) return; // safety
if (strcmp(evas_object_type_get(obj), "e_fm")) return; // safety if (strcmp(evas_object_type_get(obj), "e_fm")) return; // safety
fop = _e_fm2_fop_add(sd);
if (!fop) return;
fi = E_NEW(E_Fm2_Fop_Item, 1);
fi->fop = fop;
fi->type = FOP_MOVE;
fi->file = evas_stringshare_add(src);
fi->file2 = evas_stringshare_add(dst);
if (rel) fi->file3 = evas_stringshare_add(rel);
fi->after = after;
fi->file_add = file_add;
fi->fop->items = evas_list_append(fi->fop->items, fi);
}
EAPI void
e_fm2_fop_link_add(Evas_Object *obj, const char *src, const char *dst)
{
E_Fm2_Smart_Data *sd;
E_Fm2_Fop *fop;
E_Fm2_Fop_Item *fi;
sd = evas_object_smart_data_get(obj);
if (!sd) return; // safety
if (!evas_object_type_get(obj)) return; // safety
if (strcmp(evas_object_type_get(obj), "e_fm")) return; // safety
fop = _e_fm2_fop_add(sd);
if (!fop) return;
fi = E_NEW(E_Fm2_Fop_Item, 1);
fi->fop = fop;
fi->type = FOP_LINK;
fi->file = evas_stringshare_add(src);
fi->file2 = evas_stringshare_add(dst);
fi->fop->items = evas_list_append(fi->fop->items, fi);
}
EAPI void
e_fm2_fop_add_add(Evas_Object *obj, const char *file, const char *rel, int after)
{
E_Fm2_Smart_Data *sd;
E_Fm2_Fop *fop;
E_Fm2_Fop_Item *fi;
sd = evas_object_smart_data_get(obj);
if (!sd) return; // safety
if (!evas_object_type_get(obj)) return; // safety
if (strcmp(evas_object_type_get(obj), "e_fm")) return; // safety
fop = _e_fm2_fop_add(sd);
if (!fop) return;
fi = E_NEW(E_Fm2_Fop_Item, 1);
fi->fop = fop;
fi->type = FOP_ADD;
fi->file = evas_stringshare_add(file);
if (rel) fi->file3 = evas_stringshare_add(rel);
fi->after = after;
fi->fop->items = evas_list_append(fi->fop->items, fi);
} }
/* local subsystem functions */ /* local subsystem functions */
@ -968,8 +1029,6 @@ _e_fm2_file_add(Evas_Object *obj, char *file, int unique, char *file_rel, int af
ic2 = l->data; ic2 = l->data;
if (!strcmp(ic2->info.file, file_rel)) if (!strcmp(ic2->info.file, file_rel))
{ {
// printf("ADD %s rel: %s after=%i\n",
// ic->info.file, ic2->info.file, after);
if (after) if (after)
sd->icons = evas_list_append_relative(sd->icons, ic, ic2); sd->icons = evas_list_append_relative(sd->icons, ic, ic2);
else else
@ -1780,10 +1839,6 @@ _e_fm2_icon_realize(E_Fm2_Icon *ic)
edje_object_freeze(ic->obj); edje_object_freeze(ic->obj);
evas_object_smart_member_add(ic->obj, ic->sd->obj); evas_object_smart_member_add(ic->obj, ic->sd->obj);
evas_object_stack_below(ic->obj, ic->sd->drop); evas_object_stack_below(ic->obj, ic->sd->drop);
// evas_object_stack_below(ic->sd->drop, ic->sd->overlay);
// evas_object_stack_below(ic->sd->drop_in, ic->sd->overlay);
/* FIXME: this is currently a hack just to get a display working - go back
* and do proper icon stuff later */
if (ic->sd->config->view.mode == E_FM2_VIEW_MODE_LIST) if (ic->sd->config->view.mode == E_FM2_VIEW_MODE_LIST)
{ {
if (ic->sd->config->icon.fixed.w) if (ic->sd->config->icon.fixed.w)
@ -1911,13 +1966,6 @@ _e_fm2_icon_icon_direct_set(E_Fm2_Icon *ic, Evas_Object *o, void (*gen_func) (vo
if (ic->info.icon) if (ic->info.icon)
{ {
/* custom icon */ /* custom icon */
/* FIXME:
* if ic->info.icon == blah then use theme icon
* if ic->info.icon == blah/blah2 then use theme icon
* if ic->info.icon == /blah/blah2.xxx then use full path
* if ic->info.icon == blah.xxx then use relative path to icon dirs
* if ic->info.icon == blah/blah2.xxx then use relative path to icon dirs
*/
if (ic->info.icon[0] == '/') if (ic->info.icon[0] == '/')
{ {
/* path to icon file */ /* path to icon file */
@ -1979,29 +2027,12 @@ _e_fm2_icon_icon_direct_set(E_Fm2_Icon *ic, Evas_Object *o, void (*gen_func) (vo
snprintf(buf, sizeof(buf), "%s/%s", ic->info.pseudo_dir, ic->info.file); snprintf(buf, sizeof(buf), "%s/%s", ic->info.pseudo_dir, ic->info.file);
else else
snprintf(buf, sizeof(buf), "%s/%s", ic->sd->realpath, ic->info.file); snprintf(buf, sizeof(buf), "%s/%s", ic->sd->realpath, ic->info.file);
/* FIXME FIXME FIXME: e_app_new() is SLOOOOOOOOOOOOOOOOOOOOOOOOOOOOOW. it can
* be a complete hog. this destroys performance in fm2. :(:(:(
*/
app = e_app_new(buf, 0); app = e_app_new(buf, 0);
if (app) if (app)
{ {
/* FIXME: Actually, I think it's the icon searching that is slowing things down a lot.
* thumbnailing won't work - animated edj icons :)
* need to actually fix the icon searching :) throw in
* a hash cache. they work like a charm - also look
* at improving the search algo :)
*/
oic = e_app_icon_add(evas_object_evas_get(o), app); oic = e_app_icon_add(evas_object_evas_get(o), app);
e_object_unref(E_OBJECT(app)); e_object_unref(E_OBJECT(app));
} }
/* thumbnailing will work only on non-edj animated icons
oic = e_thumb_icon_add(evas_object_evas_get(o));
e_thumb_icon_file_set(oic, buf, e_config->icon_theme);
e_thumb_icon_size_set(oic, 128, 128);
evas_object_smart_callback_add(oic, "e_thumb_gen",
gen_func, data);
_e_fm2_icon_thumb(ic, oic, force_gen);
*/
} }
else if (!strncmp(icon, "e/icons/fileman/mime/", 21)) else if (!strncmp(icon, "e/icons/fileman/mime/", 21))
{ {
@ -2063,29 +2094,12 @@ _e_fm2_icon_icon_direct_set(E_Fm2_Icon *ic, Evas_Object *o, void (*gen_func) (vo
{ {
E_App *app; E_App *app;
/* FIXME FIXME FIXME: e_app_new() is SLOOOOOOOOOOOOOOOOOOOOOOOOOOOOOW. it can
* be a complete hog. this destroys performance in fm2. :(:(:(
*/
app = e_app_new(buf, 0); app = e_app_new(buf, 0);
if (app) if (app)
{ {
/* FIXME: Actually, I think it's the icon searching that is slowing things down a lot.
* thumbnailing won't work - animated edj icons :)
* need to actually fix the icon searching :) throw in
* a hash cache. they work like a charm - also look
* at improving the search algo :)
*/
oic = e_app_icon_add(evas_object_evas_get(o), app); oic = e_app_icon_add(evas_object_evas_get(o), app);
e_object_unref(E_OBJECT(app)); e_object_unref(E_OBJECT(app));
} }
/* thumbnailing will work only on non-edj animated icons
oic = e_thumb_icon_add(evas_object_evas_get(o));
e_thumb_icon_file_set(oic, buf, e_config->icon_theme);
e_thumb_icon_size_set(oic, 128, 96);
evas_object_smart_callback_add(oic, "e_thumb_gen",
gen_func, data);
_e_fm2_icon_thumb(ic, oic, force_gen);
*/
} }
else if (S_ISCHR(ic->info.statinfo.st_mode)) else if (S_ISCHR(ic->info.statinfo.st_mode))
{ {
@ -3026,57 +3040,51 @@ _e_fm2_cb_dnd_drop(void *data, const char *type, void *event)
/* move the file into the subdir */ /* move the file into the subdir */
snprintf(buf, sizeof(buf), "%s/%s", snprintf(buf, sizeof(buf), "%s/%s",
sd->realpath, ecore_file_get_file(ll->data)); sd->realpath, ecore_file_get_file(ll->data));
if (ecore_file_exists(buf)) e_fm2_fop_move_add(sd->obj,
{ ll->data, buf,
/* FIXME: error - file exists */ NULL, 0, 1);
} // if (ecore_file_exists(buf))
else
{
if (ecore_file_mv(ll->data, buf))
_e_fm2_live_file_add(sd->obj,
ecore_file_get_file(ll->data),
NULL, 0);
}
}
else
{
_e_fm2_live_file_add(sd->obj,
ecore_file_get_file(ll->data),
NULL, 0);
// snprintf(buf, sizeof(buf), "%s/.order",
// sd->realpath);
// f = fopen(buf, "a");
// if (f)
// { // {
// fprintf(f, "%s\n", ecore_file_get_file(ll->data)); // /* FIXME: error - file exists */
// fclose(f); // }
// else
// {
/*FOPME*/
// if (ecore_file_mv(ll->data, buf))
// _e_fm2_live_file_add(sd->obj,
// ecore_file_get_file(ll->data),
// NULL, 0);
// } // }
} }
else
_e_fm2_live_file_add(sd->obj,
ecore_file_get_file(ll->data),
NULL, 0);
} }
else else
{ {
/* file is in target dir - move into subdir */ /* file is in target dir - move into subdir */
snprintf(buf, sizeof(buf), "%s/%s", snprintf(buf, sizeof(buf), "%s/%s",
sd->realpath, ecore_file_get_file(ll->data)); sd->realpath, ecore_file_get_file(ll->data));
if (ecore_file_exists(buf)) e_fm2_fop_move_add(sd->obj,
{ ll->data, buf,
/* FIXME: error - file exists */ NULL, 0, 1);
} // if (ecore_file_exists(buf))
else // {
{ // /* FIXME: error - file exists */
if (ecore_file_mv(ll->data, buf)) // }
_e_fm2_live_file_add(sd->obj, // else
ecore_file_get_file(ll->data), // {
NULL, 0); /*FOPME*/
} // if (ecore_file_mv(ll->data, buf))
// _e_fm2_live_file_add(sd->obj,
// ecore_file_get_file(ll->data),
// NULL, 0);
// }
} }
free(d); free(d);
} }
} }
/* FIXME: disable refresh - modify icons in-place */
// refresh = 1; /* refresh src fm */
/* FIXME: disable refresh - modify icons in-place */
// e_fm2_refresh(sd->obj); /* refresh dst fm */
} }
else if (sd->drop_icon) /* inot or before/after an icon */ else if (sd->drop_icon) /* inot or before/after an icon */
{ {
@ -3090,17 +3098,16 @@ _e_fm2_cb_dnd_drop(void *data, const char *type, void *event)
snprintf(buf, sizeof(buf), "%s/%s/%s", snprintf(buf, sizeof(buf), "%s/%s/%s",
sd->realpath, sd->drop_icon->info.file, ecore_file_get_file(ll->data)); sd->realpath, sd->drop_icon->info.file, ecore_file_get_file(ll->data));
printf("mv %s %s\n", ll->data, buf); printf("mv %s %s\n", ll->data, buf);
if (ecore_file_exists(buf)) e_fm2_fop_move_add(sd->obj,
{ ll->data, buf,
/* FIXME: error - file exists */ NULL, 0, 0);
} // if (ecore_file_exists(buf))
else // {
ecore_file_mv(ll->data, buf); // /* FIXME: error - file exists */
// }
// else
///*FOPME*/ ecore_file_mv(ll->data, buf);
} }
/* FIXME: disable refresh - modify icons in-place */
// refresh = 1; /* refresh src fm */
/* FIXME: disable refresh - modify icons in-place */
// e_fm2_refresh(sd->obj); /* refresh dst fm */
} }
else else
{ {
@ -3110,80 +3117,95 @@ _e_fm2_cb_dnd_drop(void *data, const char *type, void *event)
{ {
for (ll = fsel; ll; ll = ll->next) for (ll = fsel; ll; ll = ll->next)
{ {
snprintf(buf, sizeof(buf), "%s/%s",
sd->realpath, ecore_file_get_file(ll->data));
d = ecore_file_get_dir(ll->data); d = ecore_file_get_dir(ll->data);
if (d) if (d)
{ {
if (!strcmp(d, sd->realpath)) if (!strcmp(sd->realpath, d))
{ {
printf("listrm %s\n", ecore_file_get_file(ll->data)); _e_fm2_live_file_del(sd->obj,
_e_fm2_live_file_del(sd->obj, ecore_file_get_file(ll->data)); ecore_file_get_file(ll->data));
} }
else else
{ {
snprintf(buf, sizeof(buf), "%s/%s", if (sd->config->view.link_drop)
sd->realpath, ecore_file_get_file(ll->data)); e_fm2_fop_link_add(sd->obj, ll->data, buf);
ecore_file_symlink(ll->data, buf); else
e_fm2_fop_move_add(sd->obj,
ll->data, buf,
NULL, 0, 0);
} }
free(d); free(d);
} }
// d = ecore_file_get_dir(ll->data);
// if (d)
// {
// if (!strcmp(d, sd->realpath))
// {
// printf("listrm %s\n", ecore_file_get_file(ll->data));
// _e_fm2_live_file_del(sd->obj, ecore_file_get_file(ll->data));
// }
// else
// {
///*FOPME*/ ecore_file_symlink(ll->data, buf);
// }
// free(d);
// }
} }
if (sd->drop_after == 0) if (sd->drop_after == 0)
{ {
for (ll = evas_list_last(fsel); ll; ll = ll->prev) for (ll = evas_list_last(fsel); ll; ll = ll->prev)
{ {
printf("listadd %s, before %s\n", ecore_file_get_file(ll->data), sd->drop_icon->info.file); e_fm2_fop_add_add(sd->obj, ll->data, sd->drop_icon->info.file, 0);
_e_fm2_live_file_add(sd->obj, // printf("listadd %s, before %s\n", ecore_file_get_file(ll->data), sd->drop_icon->info.file);
ecore_file_get_file(ll->data), // _e_fm2_live_file_add(sd->obj,
sd->drop_icon->info.file, 0); // ecore_file_get_file(ll->data),
// sd->drop_icon->info.file, 0);
} }
} }
else else
{ {
for (ll = fsel; ll; ll = ll->next) for (ll = fsel; ll; ll = ll->next)
{ {
printf("listadd %s, after %s\n", ecore_file_get_file(ll->data), sd->drop_icon->info.file); e_fm2_fop_add_add(sd->obj, ll->data, sd->drop_icon->info.file, 1);
_e_fm2_live_file_add(sd->obj, // printf("listadd %s, after %s\n", ecore_file_get_file(ll->data), sd->drop_icon->info.file);
ecore_file_get_file(ll->data), // _e_fm2_live_file_add(sd->obj,
sd->drop_icon->info.file, 1); // ecore_file_get_file(ll->data),
// sd->drop_icon->info.file, 1);
} }
} }
/* FIXME: disable refresh - modify icons in-place */
// e_fm2_refresh(sd->obj); /* refresh dst fm */
} }
else /* no order file */ else /* no order file */
{ {
/* shouldnt happen */
for (ll = fsel; ll; ll = ll->next) for (ll = fsel; ll; ll = ll->next)
{ {
/* move the file into the subdir */ /* move the file into the subdir */
snprintf(buf, sizeof(buf), "%s/%s", snprintf(buf, sizeof(buf), "%s/%s",
sd->realpath, ecore_file_get_file(ll->data)); sd->realpath, ecore_file_get_file(ll->data));
printf("mv %s %s\n", ll->data, buf); printf("mv %s %s\n", ll->data, buf);
if (ecore_file_exists(buf)) e_fm2_fop_move_add(sd->obj,
{ ll->data, buf,
/* FIXME: error - file exists */ NULL, 0, 1);
} // if (ecore_file_exists(buf))
else // {
{ // /* FIXME: error - file exists */
if (ecore_file_mv(ll->data, buf)) // }
_e_fm2_live_file_add(sd->obj, // else
ecore_file_get_file(ll->data), // {
NULL, 0); ///*FOPME*/ if (ecore_file_mv(ll->data, buf))
} // _e_fm2_live_file_add(sd->obj,
// ecore_file_get_file(ll->data),
// NULL, 0);
// }
} }
/* FIXME: disable refresh - modify icons in-place */
// refresh = 1; /* refresh src fm */
/* FIXME: disable refresh - modify icons in-place */
// e_fm2_refresh(sd->obj); /* refresh dst fm */
} }
} }
} }
} }
_e_fm2_dnd_drop_hide(sd->obj); _e_fm2_dnd_drop_hide(sd->obj);
_e_fm2_dnd_drop_all_hide(sd->obj); _e_fm2_dnd_drop_all_hide(sd->obj);
/* FIXME: disable refresh */
for (l = _e_fm2_list; l; l = l->next) for (l = _e_fm2_list; l; l = l->next)
// _e_fm2_dnd_finish(l->data, refresh);
_e_fm2_dnd_finish(l->data, 0); _e_fm2_dnd_finish(l->data, 0);
} }
@ -5527,18 +5549,56 @@ _e_fm2_fop_process(E_Fm2_Fop *fop)
break; break;
case FOP_MOVE: case FOP_MOVE:
/* FIXME: handle moves */ /* FIXME: handle moves */
if (ecore_file_exists(fi->file2))
{
/* FIXME: error - file exists */
}
else
{
if (ecore_file_mv(fi->file, fi->file2))
{
if ((fi->fop->obj) && (fi->file_add))
_e_fm2_live_file_add(fi->fop->obj,
fi->file, fi->file3, fi->after);
}
else
{
/* FIXME: error - move failed */
}
}
break;
case FOP_LINK:
if (!ecore_file_symlink(fi->file, fi->file2))
{
/* FIXME: error - symlink failed */
}
break;
case FOP_ADD:
if (fi->fop->obj)
_e_fm2_live_file_add(fi->fop->obj,
ecore_file_get_file(fi->file),
fi->file3, fi->after);
break; break;
default: default:
break; break;
} }
/* remove and free */ /* remove and free */
// printf("DONE: %s\n", fi->file);
fop->items = evas_list_remove_list(fop->items, fop->items); fop->items = evas_list_remove_list(fop->items, fop->items);
if (fi->file) if (fi->file)
{ {
evas_stringshare_del(fi->file); evas_stringshare_del(fi->file);
fi->file = NULL; fi->file = NULL;
} }
if (fi->file2)
{
evas_stringshare_del(fi->file2);
fi->file2 = NULL;
}
if (fi->file3)
{
evas_stringshare_del(fi->file3);
fi->file3 = NULL;
}
if (fi->dir) if (fi->dir)
{ {
closedir(fi->dir); closedir(fi->dir);

View File

@ -43,6 +43,7 @@ struct _E_Fm2_Config
unsigned char no_subdir_jump; unsigned char no_subdir_jump;
unsigned char no_subdir_drop; unsigned char no_subdir_drop;
unsigned char always_order; unsigned char always_order;
unsigned char link_drop;
} view; } view;
/* display of icons */ /* display of icons */
struct { struct {
@ -134,6 +135,9 @@ EAPI void e_fm2_pan_child_size_get(Evas_Object *obj, Evas_Coord
EAPI void e_fm2_all_icons_update(void); EAPI void e_fm2_all_icons_update(void);
EAPI void e_fm2_fop_delete_add(Evas_Object *obj, E_Fm2_Icon_Info *ici); EAPI void e_fm2_fop_delete_add(Evas_Object *obj, E_Fm2_Icon_Info *ici);
EAPI void e_fm2_fop_move_add(Evas_Object *obj, const char *src, const char *dst, const char *rel, int after, int file_add);
EAPI void e_fm2_fop_link_add(Evas_Object *obj, const char *src, const char *dst);
EAPI void e_fm2_fop_add_add(Evas_Object *obj, const char *file, const char *rel, int after);
#endif #endif
#endif #endif

View File

@ -101,7 +101,6 @@ e_fwin_new(E_Container *con, const char *dev, const char *path)
fmc.view.selector = 0; fmc.view.selector = 0;
fmc.view.single_click = 0; fmc.view.single_click = 0;
fmc.view.no_subdir_jump = 0; fmc.view.no_subdir_jump = 0;
fmc.view.always_order = 1;
fmc.icon.list.w = 24; fmc.icon.list.w = 24;
fmc.icon.list.h = 24; fmc.icon.list.h = 24;
fmc.icon.fixed.w = 1; fmc.icon.fixed.w = 1;

View File

@ -711,7 +711,8 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
fmc.view.no_subdir_jump = 0; fmc.view.no_subdir_jump = 0;
fmc.view.extra_file_source = cfdata->path_everything; fmc.view.extra_file_source = cfdata->path_everything;
fmc.view.always_order = 1; fmc.view.always_order = 1;
fmc.icon.list.w = 24; fmc.view.link_drop = 1;
fmc.icon.list.w = 24;
fmc.icon.list.h = 24; fmc.icon.list.h = 24;
fmc.icon.fixed.w = 1; fmc.icon.fixed.w = 1;
fmc.icon.fixed.h = 1; fmc.icon.fixed.h = 1;

View File

@ -398,6 +398,7 @@ e_widget_fsel_add(Evas *evas, const char *dev, const char *path, char *selected,
fmc.view.no_subdir_jump = 1; fmc.view.no_subdir_jump = 1;
fmc.view.no_subdir_drop = 1; fmc.view.no_subdir_drop = 1;
fmc.view.extra_file_source = NULL; fmc.view.extra_file_source = NULL;
fmc.view.link_drop = 1;
fmc.icon.list.w = 24; fmc.icon.list.w = 24;
fmc.icon.list.h = 24; fmc.icon.list.h = 24;
fmc.icon.fixed.w = 1; fmc.icon.fixed.w = 1;