ecrustified for formatting

SVN revision: 55908
This commit is contained in:
Mike Blumenkrantz 2011-01-05 22:36:21 +00:00
parent 7aff5821e4
commit 346e271e07
4 changed files with 1533 additions and 1329 deletions

File diff suppressed because it is too large Load Diff

View File

@ -3,87 +3,93 @@
#include "e_mod_config.h" #include "e_mod_config.h"
#include "e_fm_device.h" #include "e_fm_device.h"
struct _E_Config_Dialog_Data struct _E_Config_Dialog_Data
{ {
/* general view mode */ /* general view mode */
struct struct
{ {
int mode; int mode;
int open_dirs_in_place; int open_dirs_in_place;
int selector; int selector;
int single_click; int single_click;
int no_subdir_jump; int no_subdir_jump;
int no_subdir_drop; int no_subdir_drop;
int always_order; int always_order;
int link_drop; int link_drop;
int fit_custom_pos; int fit_custom_pos;
int show_full_path; int show_full_path;
int show_desktop_icons; int show_desktop_icons;
int show_toolbar; int show_toolbar;
} view; } view;
/* display of icons */ /* display of icons */
struct struct
{ {
struct struct
{ {
int w, h; int w, h;
} icon, list, fixed; } icon, list, fixed;
struct struct
{ {
int show; int show;
} extension; } extension;
const char *key_hint; const char *key_hint;
} icon; } icon;
/* how to sort files */ /* how to sort files */
struct struct
{ {
struct struct
{ {
int case_sen; int case_sen;
struct struct
{ {
int first, last; int first, last;
} dirs; } dirs;
} sort; } sort;
} list; } list;
/* control how you can select files */ /* control how you can select files */
struct struct
{ {
int single; int single;
int windows_modifiers; int windows_modifiers;
} selection; } selection;
/* the background - if any, and how to handle it */ /* the background - if any, and how to handle it */
/* FIXME: not implemented yet */ /* FIXME: not implemented yet */
struct struct
{ {
const char *background; const char *background;
const char *frame, *icons; const char *frame, *icons;
int fixed; int fixed;
} theme; } theme;
struct struct
{ {
int desktop; int desktop;
int auto_mount; int auto_mount;
int auto_open; int auto_open;
} dbus; } dbus;
E_Config_Dialog *cfd; E_Config_Dialog *cfd;
}; };
static void *_create_data(E_Config_Dialog *cfd); static void *_create_data(E_Config_Dialog *cfd);
static void _fill_data(E_Config_Dialog_Data *cfdata); static void _fill_data(E_Config_Dialog_Data *cfdata);
static void _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata); static void _free_data(E_Config_Dialog *cfd,
static int _basic_apply(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata); E_Config_Dialog_Data *cfdata);
static int _basic_check_changed(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata); static int _basic_apply(E_Config_Dialog *cfd,
static Evas_Object *_basic_create(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata); E_Config_Dialog_Data *cfdata);
static int _basic_check_changed(E_Config_Dialog *cfd,
E_Config_Dialog_Data *cfdata);
static Evas_Object *_basic_create(E_Config_Dialog *cfd,
Evas *evas,
E_Config_Dialog_Data *cfdata);
E_Config_Dialog * E_Config_Dialog *
e_int_config_fileman(E_Container *con, const char *params __UNUSED__) e_int_config_fileman(E_Container *con,
const char *params __UNUSED__)
{ {
E_Config_Dialog *cfd; E_Config_Dialog *cfd;
E_Config_Dialog_View *v; E_Config_Dialog_View *v;
if (e_config_dialog_find("E", "fileman/fileman")) return NULL; if (e_config_dialog_find("E", "fileman/fileman")) return NULL;
v = E_NEW(E_Config_Dialog_View, 1); v = E_NEW(E_Config_Dialog_View, 1);
v->create_cfdata = _create_data; v->create_cfdata = _create_data;
@ -92,17 +98,17 @@ e_int_config_fileman(E_Container *con, const char *params __UNUSED__)
v->basic.create_widgets = _basic_create; v->basic.create_widgets = _basic_create;
v->basic.check_changed = _basic_check_changed; v->basic.check_changed = _basic_check_changed;
cfd = e_config_dialog_new(con, _("Fileman Settings"), "E", cfd = e_config_dialog_new(con, _("Fileman Settings"), "E",
"fileman/fileman", "fileman/fileman",
"system-file-manager", 0, v, NULL); "system-file-manager", 0, v, NULL);
return cfd; return cfd;
} }
static void * static void *
_create_data(E_Config_Dialog *cfd) _create_data(E_Config_Dialog *cfd)
{ {
E_Config_Dialog_Data *cfdata; E_Config_Dialog_Data *cfdata;
cfdata = E_NEW(E_Config_Dialog_Data, 1); cfdata = E_NEW(E_Config_Dialog_Data, 1);
cfd->cfdata = cfdata; cfd->cfdata = cfdata;
cfdata->cfd = cfd; cfdata->cfd = cfd;
@ -110,8 +116,8 @@ _create_data(E_Config_Dialog *cfd)
return cfdata; return cfdata;
} }
static void static void
_fill_data(E_Config_Dialog_Data *cfdata) _fill_data(E_Config_Dialog_Data *cfdata)
{ {
cfdata->view.mode = fileman_config->view.mode; cfdata->view.mode = fileman_config->view.mode;
cfdata->view.open_dirs_in_place = fileman_config->view.open_dirs_in_place; cfdata->view.open_dirs_in_place = fileman_config->view.open_dirs_in_place;
@ -130,15 +136,17 @@ _fill_data(E_Config_Dialog_Data *cfdata)
cfdata->dbus.auto_open = e_config->device_auto_open; cfdata->dbus.auto_open = e_config->device_auto_open;
} }
static void static void
_free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata) _free_data(E_Config_Dialog *cfd,
E_Config_Dialog_Data *cfdata)
{ {
E_FREE(cfd->data); E_FREE(cfd->data);
E_FREE(cfdata); E_FREE(cfdata);
} }
static int static int
_basic_apply(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata) _basic_apply(E_Config_Dialog *cfd __UNUSED__,
E_Config_Dialog_Data *cfdata)
{ {
fileman_config->view.mode = cfdata->view.mode; fileman_config->view.mode = cfdata->view.mode;
fileman_config->view.open_dirs_in_place = cfdata->view.open_dirs_in_place; fileman_config->view.open_dirs_in_place = cfdata->view.open_dirs_in_place;
@ -153,55 +161,58 @@ _basic_apply(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata)
/* Make these two equal so that icons are proportioned correctly */ /* Make these two equal so that icons are proportioned correctly */
fileman_config->icon.icon.w = cfdata->icon.icon.w; fileman_config->icon.icon.w = cfdata->icon.icon.w;
fileman_config->icon.icon.h = cfdata->icon.icon.w; fileman_config->icon.icon.h = cfdata->icon.icon.w;
fileman_config->list.sort.dirs.first = cfdata->list.sort.dirs.first; fileman_config->list.sort.dirs.first = cfdata->list.sort.dirs.first;
fileman_config->list.sort.dirs.last = !(cfdata->list.sort.dirs.first); fileman_config->list.sort.dirs.last = !(cfdata->list.sort.dirs.first);
fileman_config->list.sort.no_case = !(cfdata->list.sort.case_sen); fileman_config->list.sort.no_case = !(cfdata->list.sort.case_sen);
e_config->device_desktop = cfdata->dbus.desktop; e_config->device_desktop = cfdata->dbus.desktop;
if(e_config->device_desktop) if(e_config->device_desktop)
e_fm2_device_show_desktop_icons(); e_fm2_device_show_desktop_icons();
else else
e_fm2_device_hide_desktop_icons(); e_fm2_device_hide_desktop_icons();
e_config->device_auto_mount = cfdata->dbus.auto_mount; e_config->device_auto_mount = cfdata->dbus.auto_mount;
e_config->device_auto_open = cfdata->dbus.auto_open; e_config->device_auto_open = cfdata->dbus.auto_open;
e_config_save_queue(); e_config_save_queue();
/* FIXME: reload/refresh existing fm's */ /* FIXME: reload/refresh existing fm's */
e_fwin_reload_all(); e_fwin_reload_all();
return 1; return 1;
} }
static int static int
_basic_check_changed(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata) _basic_check_changed(E_Config_Dialog *cfd __UNUSED__,
E_Config_Dialog_Data *cfdata)
{ {
return return
((fileman_config->view.mode != cfdata->view.mode) || (fileman_config->view.mode != cfdata->view.mode) ||
(fileman_config->view.open_dirs_in_place != cfdata->view.open_dirs_in_place) || (fileman_config->view.open_dirs_in_place != cfdata->view.open_dirs_in_place) ||
(fileman_config->view.single_click != cfdata->view.single_click) || (fileman_config->view.single_click != cfdata->view.single_click) ||
(fileman_config->view.show_full_path != cfdata->view.show_full_path) || (fileman_config->view.show_full_path != cfdata->view.show_full_path) ||
(fileman_config->view.show_desktop_icons != cfdata->view.show_desktop_icons) || (fileman_config->view.show_desktop_icons != cfdata->view.show_desktop_icons) ||
(fileman_config->view.show_toolbar != cfdata->view.show_toolbar) || (fileman_config->view.show_toolbar != cfdata->view.show_toolbar) ||
(fileman_config->icon.extension.show != cfdata->icon.extension.show) || (fileman_config->icon.extension.show != cfdata->icon.extension.show) ||
(fileman_config->selection.windows_modifiers != cfdata->selection.windows_modifiers) || (fileman_config->selection.windows_modifiers != cfdata->selection.windows_modifiers) ||
(fileman_config->icon.icon.w != cfdata->icon.icon.w) || (fileman_config->icon.icon.w != cfdata->icon.icon.w) ||
(fileman_config->icon.icon.h != cfdata->icon.icon.w) || (fileman_config->icon.icon.h != cfdata->icon.icon.w) ||
(fileman_config->list.sort.dirs.first != cfdata->list.sort.dirs.first) || (fileman_config->list.sort.dirs.first != cfdata->list.sort.dirs.first) ||
(fileman_config->list.sort.dirs.last != !(cfdata->list.sort.dirs.first)) || (fileman_config->list.sort.dirs.last != !(cfdata->list.sort.dirs.first)) ||
(fileman_config->list.sort.no_case != !(cfdata->list.sort.case_sen)) || (fileman_config->list.sort.no_case != !(cfdata->list.sort.case_sen)) ||
(e_config->device_desktop != cfdata->dbus.desktop) || (e_config->device_desktop != cfdata->dbus.desktop) ||
(e_config->device_auto_mount != cfdata->dbus.auto_mount) || (e_config->device_auto_mount != cfdata->dbus.auto_mount) ||
(e_config->device_auto_open != cfdata->dbus.auto_open)); (e_config->device_auto_open != cfdata->dbus.auto_open);
} }
static Evas_Object * static Evas_Object *
_basic_create(E_Config_Dialog *cfd __UNUSED__, Evas *evas, E_Config_Dialog_Data *cfdata) _basic_create(E_Config_Dialog *cfd __UNUSED__,
Evas *evas,
E_Config_Dialog_Data *cfdata)
{ {
Evas_Object *o, *ob, *of, *otb; Evas_Object *o, *ob, *of, *otb;
E_Radio_Group *rg; E_Radio_Group *rg;
otb = e_widget_toolbook_add(evas, 48 * e_scale, 48 * e_scale); otb = e_widget_toolbook_add(evas, 48 * e_scale, 48 * e_scale);
o = e_widget_list_add(evas, 0, 0); o = e_widget_list_add(evas, 0, 0);
@ -223,66 +234,67 @@ _basic_create(E_Config_Dialog *cfd __UNUSED__, Evas *evas, E_Config_Dialog_Data
ob = e_widget_radio_add(evas, _("List"), 5, rg); ob = e_widget_radio_add(evas, _("List"), 5, rg);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5); e_widget_list_object_append(o, of, 1, 1, 0.5);
ob = e_widget_label_add(evas, _("Icon Size")); ob = e_widget_label_add(evas, _("Icon Size"));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_slider_add(evas, 1, 0, _("%1.0f"), 16.0, 256.0, 1.0, 0, ob = e_widget_slider_add(evas, 1, 0, _("%1.0f"), 16.0, 256.0, 1.0, 0,
NULL, &(cfdata->icon.icon.w), 150); NULL, &(cfdata->icon.icon.w), 150);
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
e_widget_toolbook_page_append(otb, NULL, _("View"), o, 0, 0, 0, 0, 0.5, 0.0); e_widget_toolbook_page_append(otb, NULL, _("View"), o, 0, 0, 0, 0, 0.5, 0.0);
o = e_widget_list_add(evas, 1, 0); o = e_widget_list_add(evas, 1, 0);
ob = e_widget_check_add(evas, _("Open Dirs In Place"), ob = e_widget_check_add(evas, _("Open Dirs In Place"),
&(cfdata->view.open_dirs_in_place)); &(cfdata->view.open_dirs_in_place));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Sort Dirs First"), ob = e_widget_check_add(evas, _("Sort Dirs First"),
&(cfdata->list.sort.dirs.first)); &(cfdata->list.sort.dirs.first));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Case Sensitive"), ob = e_widget_check_add(evas, _("Case Sensitive"),
&(cfdata->list.sort.case_sen)); &(cfdata->list.sort.case_sen));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Use Single Click"), ob = e_widget_check_add(evas, _("Use Single Click"),
&(cfdata->view.single_click)); &(cfdata->view.single_click));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Use Alternate Selection Modifiers"), ob = e_widget_check_add(evas, _("Use Alternate Selection Modifiers"),
&(cfdata->selection.windows_modifiers)); &(cfdata->selection.windows_modifiers));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Show Icon Extension"), ob = e_widget_check_add(evas, _("Show Icon Extension"),
&(cfdata->icon.extension.show)); &(cfdata->icon.extension.show));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Show Full Path"), ob = e_widget_check_add(evas, _("Show Full Path"),
&(cfdata->view.show_full_path)); &(cfdata->view.show_full_path));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Show Desktop Icons"), ob = e_widget_check_add(evas, _("Show Desktop Icons"),
&(cfdata->view.show_desktop_icons)); &(cfdata->view.show_desktop_icons));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Show Toolbar"), ob = e_widget_check_add(evas, _("Show Toolbar"),
&(cfdata->view.show_toolbar)); &(cfdata->view.show_toolbar));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
e_widget_toolbook_page_append(otb, NULL, _("Behavior"), o, 0, 0, 0, 0, 0.5, 0.0); e_widget_toolbook_page_append(otb, NULL, _("Behavior"), o, 0, 0, 0, 0, 0.5, 0.0);
o = e_widget_list_add(evas, 2, 0); o = e_widget_list_add(evas, 2, 0);
#ifdef HAVE_EUKIT #ifdef HAVE_EUKIT
ob = e_widget_check_add(evas, _("Show UDisks icons on desktop"), ob = e_widget_check_add(evas, _("Show UDisks icons on desktop"),
#else #else
ob = e_widget_check_add(evas, _("Show HAL icons on desktop"), ob = e_widget_check_add(evas, _("Show HAL icons on desktop"),
#endif #endif
&(cfdata->dbus.desktop)); &(cfdata->dbus.desktop));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Mount volumes on insert"), ob = e_widget_check_add(evas, _("Mount volumes on insert"),
&(cfdata->dbus.auto_mount)); &(cfdata->dbus.auto_mount));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
ob = e_widget_check_add(evas, _("Open filemanager on mount"), ob = e_widget_check_add(evas, _("Open filemanager on mount"),
&(cfdata->dbus.auto_open)); &(cfdata->dbus.auto_open));
e_widget_list_object_append(o, ob, 1, 1, 0.5); e_widget_list_object_append(o, ob, 1, 1, 0.5);
e_widget_toolbook_page_append(otb, NULL, _("HAL"), o, 0, 0, 0, 0, 0.5, 0.0); e_widget_toolbook_page_append(otb, NULL, _("HAL"), o, 0, 0, 0, 0, 0.5, 0.0);
e_widget_toolbook_page_show(otb, 0); e_widget_toolbook_page_show(otb, 0);
return otb; return otb;
} }

View File

@ -11,17 +11,18 @@ typedef struct _E_Fileman_DBus_Daemon E_Fileman_DBus_Daemon;
struct _E_Fileman_DBus_Daemon struct _E_Fileman_DBus_Daemon
{ {
E_DBus_Connection *conn; E_DBus_Connection *conn;
E_DBus_Interface *iface; E_DBus_Interface *iface;
E_DBus_Object *obj; E_DBus_Object *obj;
struct struct
{ {
DBusPendingCall *request_name; DBusPendingCall *request_name;
} pending; } pending;
}; };
static DBusMessage * static DBusMessage *
_e_fileman_dbus_daemon_error(DBusMessage *message, const char *msg) _e_fileman_dbus_daemon_error(DBusMessage *message,
const char *msg)
{ {
return dbus_message_new_error(message, E_FILEMAN_ERROR, msg); return dbus_message_new_error(message, E_FILEMAN_ERROR, msg);
} }
@ -34,8 +35,8 @@ _e_fileman_dbus_daemon_object_init(E_Fileman_DBus_Daemon *d)
d->obj = e_dbus_object_add(d->conn, E_FILEMAN_PATH, d); d->obj = e_dbus_object_add(d->conn, E_FILEMAN_PATH, d);
if (!d->obj) if (!d->obj)
{ {
fprintf(stderr, "ERROR: cannot add object to %s\n", E_FILEMAN_PATH); fprintf(stderr, "ERROR: cannot add object to %s\n", E_FILEMAN_PATH);
return; return;
} }
e_dbus_object_interface_attach(d->obj, d->iface); e_dbus_object_interface_attach(d->obj, d->iface);
@ -49,8 +50,8 @@ _e_fileman_dbus_daemon_free(E_Fileman_DBus_Daemon *d)
if (d->obj) if (d->obj)
{ {
e_dbus_object_interface_detach(d->obj, d->iface); e_dbus_object_interface_detach(d->obj, d->iface);
e_dbus_object_free(d->obj); e_dbus_object_free(d->obj);
} }
if (d->iface) if (d->iface)
@ -63,7 +64,8 @@ _e_fileman_dbus_daemon_free(E_Fileman_DBus_Daemon *d)
} }
DBusMessage * DBusMessage *
_e_fileman_dbus_daemon_open_directory_cb(E_DBus_Object *obj __UNUSED__, DBusMessage *message) _e_fileman_dbus_daemon_open_directory_cb(E_DBus_Object *obj __UNUSED__,
DBusMessage *message)
{ {
DBusMessageIter itr; DBusMessageIter itr;
const char *directory = NULL, *p; const char *directory = NULL, *p;
@ -83,29 +85,28 @@ _e_fileman_dbus_daemon_open_directory_cb(E_DBus_Object *obj __UNUSED__, DBusMess
if (!zone) if (!zone)
return _e_fileman_dbus_daemon_error(message, "could not find a zone."); return _e_fileman_dbus_daemon_error(message, "could not find a zone.");
p = strchr(directory, '/'); p = strchr(directory, '/');
if (p) if (p)
{ {
int len = p - directory + 1; int len = p - directory + 1;
dev = malloc(len + 1); dev = malloc(len + 1);
if (!dev) if (!dev)
return _e_fileman_dbus_daemon_error return _e_fileman_dbus_daemon_error
(message, "could not allocate memory."); (message, "could not allocate memory.");
memcpy(dev, directory, len); memcpy(dev, directory, len);
dev[len] = '\0'; dev[len] = '\0';
if ((dev[0] != '/') && (dev[0] != '~')) if ((dev[0] != '/') && (dev[0] != '~'))
dev[len - 1] = '\0'; /* remove trailing '/' */ dev[len - 1] = '\0'; /* remove trailing '/' */
directory += p - directory; directory += p - directory;
} }
else else
{ {
dev = strdup(directory); dev = strdup(directory);
directory = "/"; directory = "/";
} }
e_fwin_new(zone->container, dev, directory); e_fwin_new(zone->container, dev, directory);
@ -114,7 +115,9 @@ _e_fileman_dbus_daemon_open_directory_cb(E_DBus_Object *obj __UNUSED__, DBusMess
} }
static void static void
_e_fileman_dbus_daemon_request_name_cb(void *data, DBusMessage *msg, DBusError *err) _e_fileman_dbus_daemon_request_name_cb(void *data,
DBusMessage *msg,
DBusError *err)
{ {
E_Fileman_DBus_Daemon *d = data; E_Fileman_DBus_Daemon *d = data;
dbus_uint32_t ret; dbus_uint32_t ret;
@ -124,37 +127,39 @@ _e_fileman_dbus_daemon_request_name_cb(void *data, DBusMessage *msg, DBusError *
if (dbus_error_is_set(err)) if (dbus_error_is_set(err))
{ {
fprintf(stderr, "ERROR: FILEMAN: RequestName failed: %s\n", fprintf(stderr, "ERROR: FILEMAN: RequestName failed: %s\n",
err->message); err->message);
dbus_error_free(err); dbus_error_free(err);
return; return;
} }
dbus_error_init(&new_err); dbus_error_init(&new_err);
dbus_message_get_args(msg, &new_err, DBUS_TYPE_UINT32, &ret, dbus_message_get_args(msg, &new_err, DBUS_TYPE_UINT32, &ret,
DBUS_TYPE_INVALID); DBUS_TYPE_INVALID);
if (dbus_error_is_set(&new_err)) if (dbus_error_is_set(&new_err))
{ {
fprintf(stderr, fprintf(stderr,
"ERROR: FILEMAN: could not get arguments of RequestName: %s\n", "ERROR: FILEMAN: could not get arguments of RequestName: %s\n",
new_err.message); new_err.message);
dbus_error_free(&new_err); dbus_error_free(&new_err);
return; return;
} }
switch (ret) switch (ret)
{ {
case DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER: case DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER:
case DBUS_REQUEST_NAME_REPLY_ALREADY_OWNER: case DBUS_REQUEST_NAME_REPLY_ALREADY_OWNER:
_e_fileman_dbus_daemon_object_init(d); _e_fileman_dbus_daemon_object_init(d);
break; break;
case DBUS_REQUEST_NAME_REPLY_IN_QUEUE: case DBUS_REQUEST_NAME_REPLY_IN_QUEUE:
//XXX mark daemon as queued? //XXX mark daemon as queued?
break; break;
case DBUS_REQUEST_NAME_REPLY_EXISTS: case DBUS_REQUEST_NAME_REPLY_EXISTS:
//XXX exit? //XXX exit?
break; break;
} }
} }
@ -166,8 +171,8 @@ _e_fileman_dbus_daemon_new(void)
d = calloc(1, sizeof(*d)); d = calloc(1, sizeof(*d));
if (!d) if (!d)
{ {
perror("ERROR: FILEMAN: cannot allocate fileman dbus daemon memory."); perror("ERROR: FILEMAN: cannot allocate fileman dbus daemon memory.");
return NULL; return NULL;
} }
d->conn = e_dbus_bus_get(DBUS_BUS_SESSION); d->conn = e_dbus_bus_get(DBUS_BUS_SESSION);
@ -179,21 +184,21 @@ _e_fileman_dbus_daemon_new(void)
goto error; goto error;
d->pending.request_name = e_dbus_request_name d->pending.request_name = e_dbus_request_name
(d->conn, E_FILEMAN_BUS_NAME, DBUS_NAME_FLAG_REPLACE_EXISTING, (d->conn, E_FILEMAN_BUS_NAME, DBUS_NAME_FLAG_REPLACE_EXISTING,
_e_fileman_dbus_daemon_request_name_cb, d); _e_fileman_dbus_daemon_request_name_cb, d);
if (!d->pending.request_name) if (!d->pending.request_name)
goto error; goto error;
const struct const struct
{ {
const char *method; const char *method;
const char *signature; const char *signature;
const char *ret_signature; const char *ret_signature;
E_DBus_Method_Cb func; E_DBus_Method_Cb func;
} *itr, desc[] = { } *itr, desc[] = {
{"OpenDirectory", "s", "", _e_fileman_dbus_daemon_open_directory_cb}, {"OpenDirectory", "s", "", _e_fileman_dbus_daemon_open_directory_cb},
{NULL} {NULL}
}; };
for (itr = desc; itr->method; itr++) for (itr = desc; itr->method; itr++)
e_dbus_interface_method_add e_dbus_interface_method_add
@ -201,13 +206,12 @@ _e_fileman_dbus_daemon_new(void)
return d; return d;
error: error:
fprintf(stderr, "ERROR: FILEMAN: failed to create daemon at %p\n", d); fprintf(stderr, "ERROR: FILEMAN: failed to create daemon at %p\n", d);
_e_fileman_dbus_daemon_free(d); _e_fileman_dbus_daemon_free(d);
return NULL; return NULL;
} }
static E_Fileman_DBus_Daemon *_daemon = NULL; static E_Fileman_DBus_Daemon *_daemon = NULL;
void void
@ -230,3 +234,4 @@ e_fileman_dbus_shutdown(void)
_daemon = NULL; _daemon = NULL;
e_dbus_shutdown(); e_dbus_shutdown();
} }

View File

@ -5,15 +5,25 @@
#include "e_mod_dbus.h" #include "e_mod_dbus.h"
/* actual module specifics */ /* actual module specifics */
static void _e_mod_action_fileman_cb(E_Object *obj, const char *params); static void _e_mod_action_fileman_cb(E_Object *obj,
static void _e_mod_menu_gtk_cb(void *data, E_Menu *m, E_Menu_Item *mi); const char *params);
static void _e_mod_menu_virtual_cb(void *data, E_Menu *m, E_Menu_Item *mi); static void _e_mod_menu_gtk_cb(void *data,
static void _e_mod_menu_volume_cb(void *data, E_Menu *m, E_Menu_Item *mi); E_Menu *m,
static void _e_mod_menu_add(void *data, E_Menu *m); E_Menu_Item *mi);
static void _e_mod_fileman_config_load(void); static void _e_mod_menu_virtual_cb(void *data,
static void _e_mod_fileman_config_free(void); E_Menu *m,
E_Menu_Item *mi);
static void _e_mod_menu_volume_cb(void *data,
E_Menu *m,
E_Menu_Item *mi);
static void _e_mod_menu_add(void *data,
E_Menu *m);
static void _e_mod_fileman_config_load(void);
static void _e_mod_fileman_config_free(void);
static Eina_Bool _e_mod_cb_config_timer(void *data); static Eina_Bool _e_mod_cb_config_timer(void *data);
static Eina_Bool _e_mod_zone_add(void *data, int type, void *event); static Eina_Bool _e_mod_zone_add(void *data,
int type,
void *event);
static E_Module *conf_module = NULL; static E_Module *conf_module = NULL;
static E_Action *act = NULL; static E_Action *act = NULL;
@ -27,7 +37,7 @@ Config *fileman_config = NULL;
EAPI E_Module_Api e_modapi = EAPI E_Module_Api e_modapi =
{ {
E_MODULE_API_VERSION, E_MODULE_API_VERSION,
"Fileman" "Fileman"
}; };
EAPI void * EAPI void *
@ -37,64 +47,64 @@ e_modapi_init(E_Module *m)
E_Manager *man; E_Manager *man;
E_Container *con; E_Container *con;
E_Zone *zone; E_Zone *zone;
conf_module = m; conf_module = m;
//eina_init(); //eina_init();
/* Setup Entry in Config Panel */ /* Setup Entry in Config Panel */
e_configure_registry_category_add("fileman", 100, _("Files"), e_configure_registry_category_add("fileman", 100, _("Files"),
NULL, "system-file-manager"); NULL, "system-file-manager");
e_configure_registry_item_add("fileman/fileman", 10, _("File Manager"), e_configure_registry_item_add("fileman/fileman", 10, _("File Manager"),
NULL, "system-file-manager", NULL, "system-file-manager",
e_int_config_fileman); e_int_config_fileman);
/* Setup Config edd */ /* Setup Config edd */
_e_mod_fileman_config_load(); _e_mod_fileman_config_load();
/* add module supplied action */ /* add module supplied action */
act = e_action_add("fileman"); act = e_action_add("fileman");
if (act) if (act)
{ {
act->func.go = _e_mod_action_fileman_cb; act->func.go = _e_mod_action_fileman_cb;
e_action_predef_name_set(_("Launch"), _("File Manager"), e_action_predef_name_set(_("Launch"), _("File Manager"),
"fileman", NULL, "syntax: /path/to/dir or ~/path/to/dir or favorites or desktop, examples: /boot/grub, ~/downloads", 1); "fileman", NULL, "syntax: /path/to/dir or ~/path/to/dir or favorites or desktop, examples: /boot/grub, ~/downloads", 1);
} }
maug = e_int_menus_menu_augmentation_add_sorted maug = e_int_menus_menu_augmentation_add_sorted
("main/1", _("Files"),_e_mod_menu_add, NULL, NULL, NULL); ("main/1", _("Files"), _e_mod_menu_add, NULL, NULL, NULL);
e_module_delayed_set(m, 1); e_module_delayed_set(m, 1);
/* Hook into zones */ /* Hook into zones */
for (l = e_manager_list(); l; l = l->next) for (l = e_manager_list(); l; l = l->next)
{ {
man = l->data; man = l->data;
for (ll = man->containers; ll; ll = ll->next) for (ll = man->containers; ll; ll = ll->next)
{ {
con = ll->data; con = ll->data;
for (lll = con->zones; lll; lll = lll->next) for (lll = con->zones; lll; lll = lll->next)
{ {
zone = lll->data; zone = lll->data;
if (e_fwin_zone_find(zone)) continue; if (e_fwin_zone_find(zone)) continue;
if ((zone->container->num == 0) && (zone->num == 0) && if ((zone->container->num == 0) && (zone->num == 0) &&
(fileman_config->view.show_desktop_icons)) (fileman_config->view.show_desktop_icons))
e_fwin_zone_new(zone, "desktop", "/"); e_fwin_zone_new(zone, "desktop", "/");
else else
{ {
char buf[256]; char buf[256];
if (fileman_config->view.show_desktop_icons) if (fileman_config->view.show_desktop_icons)
{ {
snprintf(buf, sizeof(buf), "%i", snprintf(buf, sizeof(buf), "%i",
(zone->container->num + zone->num)); (zone->container->num + zone->num));
e_fwin_zone_new(zone, "desktop", buf); e_fwin_zone_new(zone, "desktop", buf);
} }
} }
} }
} }
} }
zone_add_handler = ecore_event_handler_add(E_EVENT_ZONE_ADD, zone_add_handler = ecore_event_handler_add(E_EVENT_ZONE_ADD,
_e_mod_zone_add, NULL); _e_mod_zone_add, NULL);
/* FIXME: add system event for new zone creation, and on creation, add an fwin to the zone */ /* FIXME: add system event for new zone creation, and on creation, add an fwin to the zone */
e_fileman_dbus_init(); e_fileman_dbus_init();
@ -114,40 +124,40 @@ e_modapi_shutdown(E_Module *m __UNUSED__)
ecore_event_handler_del(zone_add_handler); ecore_event_handler_del(zone_add_handler);
zone_add_handler = NULL; zone_add_handler = NULL;
/* Unhook zone fm */ /* Unhook zone fm */
for (l = e_manager_list(); l; l = l->next) for (l = e_manager_list(); l; l = l->next)
{ {
man = l->data; man = l->data;
for (ll = man->containers; ll; ll = ll->next) for (ll = man->containers; ll; ll = ll->next)
{ {
con = ll->data; con = ll->data;
for (lll = con->zones; lll; lll = lll->next) for (lll = con->zones; lll; lll = lll->next)
{ {
zone = lll->data; zone = lll->data;
if (!zone) continue; if (!zone) continue;
e_fwin_zone_shutdown(zone); e_fwin_zone_shutdown(zone);
} }
} }
} }
/* remove module-supplied menu additions */ /* remove module-supplied menu additions */
if (maug) if (maug)
{ {
e_int_menus_menu_augmentation_del("main/1", maug); e_int_menus_menu_augmentation_del("main/1", maug);
maug = NULL; maug = NULL;
} }
/* remove module-supplied action */ /* remove module-supplied action */
if (act) if (act)
{ {
e_action_predef_name_del(_("Launch"), _("File Manager")); e_action_predef_name_del(_("Launch"), _("File Manager"));
e_action_del("fileman"); e_action_del("fileman");
act = NULL; act = NULL;
} }
/* remove fileman category from config panel */ /* remove fileman category from config panel */
e_configure_registry_item_del("fileman/fileman"); e_configure_registry_item_del("fileman/fileman");
e_configure_registry_category_del("fileman"); e_configure_registry_category_del("fileman");
_e_mod_fileman_config_free(); _e_mod_fileman_config_free();
E_CONFIG_DD_FREE(conf_edd); E_CONFIG_DD_FREE(conf_edd);
@ -166,62 +176,65 @@ e_modapi_save(E_Module *m __UNUSED__)
/* action callback */ /* action callback */
static void static void
_e_mod_action_fileman_cb(E_Object *obj, const char *params) _e_mod_action_fileman_cb(E_Object *obj,
const char *params)
{ {
E_Zone *zone = NULL; E_Zone *zone = NULL;
if (obj) if (obj)
{ {
if (obj->type == E_MANAGER_TYPE) if (obj->type == E_MANAGER_TYPE)
zone = e_util_zone_current_get((E_Manager *)obj); zone = e_util_zone_current_get((E_Manager *)obj);
else if (obj->type == E_CONTAINER_TYPE) else if (obj->type == E_CONTAINER_TYPE)
zone = e_util_zone_current_get(((E_Container *)obj)->manager); zone = e_util_zone_current_get(((E_Container *)obj)->manager);
else if (obj->type == E_ZONE_TYPE) else if (obj->type == E_ZONE_TYPE)
zone = e_util_zone_current_get(((E_Zone *)obj)->container->manager); zone = e_util_zone_current_get(((E_Zone *)obj)->container->manager);
else else
zone = e_util_zone_current_get(e_manager_current_get()); zone = e_util_zone_current_get(e_manager_current_get());
} }
if (!zone) zone = e_util_zone_current_get(e_manager_current_get()); if (!zone) zone = e_util_zone_current_get(e_manager_current_get());
if (zone) if (zone)
{ {
if (params && params[0] == '/') if (params && params[0] == '/')
e_fwin_new(zone->container, "/", params); e_fwin_new(zone->container, "/", params);
else if (params && params[0] == '~') else if (params && params[0] == '~')
e_fwin_new(zone->container, "~/", params + 1); e_fwin_new(zone->container, "~/", params + 1);
else if (params) else if (params)
{ {
char *path; char *path;
path = e_util_shell_env_path_eval(params); path = e_util_shell_env_path_eval(params);
if (path) if (path)
{ {
e_fwin_new(zone->container, path, "/"); e_fwin_new(zone->container, path, "/");
free(path); free(path);
} }
} }
else else
e_fwin_new(zone->container, "favorites", "/"); e_fwin_new(zone->container, "favorites", "/");
} }
} }
/* menu item callback(s) */ /* menu item callback(s) */
//~ static int //~ static int
//~ _e_mod_fileman_defer_cb(void *data) //~ _e_mod_fileman_defer_cb(void *data)
//~ { //~ {
//~ E_Zone *zone; //~ E_Zone *zone;
//~ zone = data; //~ zone = data;
//~ if (zone) e_fwin_new(zone->container, "favorites", "/"); //~ if (zone) e_fwin_new(zone->container, "favorites", "/");
//~ return 0; //~ return 0;
//~ } //~ }
//~ static void //~ static void
//~ _e_mod_fileman_cb(void *data, E_Menu *m, E_Menu_Item *mi) //~ _e_mod_fileman_cb(void *data, E_Menu *m, E_Menu_Item *mi)
//~ { //~ {
//~ ecore_idle_enterer_add(_e_mod_fileman_defer_cb, m->zone); //~ ecore_idle_enterer_add(_e_mod_fileman_defer_cb, m->zone);
//~ } //~ }
static void static void
_e_mod_menu_gtk_cb(void *data, E_Menu *m, E_Menu_Item *mi __UNUSED__) _e_mod_menu_gtk_cb(void *data,
E_Menu *m,
E_Menu_Item *mi __UNUSED__)
{ {
char *path; char *path;
@ -231,20 +244,24 @@ _e_mod_menu_gtk_cb(void *data, E_Menu *m, E_Menu_Item *mi __UNUSED__)
} }
static void static void
_e_mod_menu_virtual_cb(void *data, E_Menu *m, E_Menu_Item *mi __UNUSED__) _e_mod_menu_virtual_cb(void *data,
E_Menu *m,
E_Menu_Item *mi __UNUSED__)
{ {
if (m->zone) e_fwin_new(m->zone->container, data, "/"); if (m->zone) e_fwin_new(m->zone->container, data, "/");
} }
static void static void
_e_mod_menu_volume_cb(void *data, E_Menu *m, E_Menu_Item *mi __UNUSED__) _e_mod_menu_volume_cb(void *data,
E_Menu *m,
E_Menu_Item *mi __UNUSED__)
{ {
E_Volume *vol = data; E_Volume *vol = data;
if (vol->mounted) if (vol->mounted)
{ {
if (m->zone) if (m->zone)
e_fwin_new(m->zone->container, NULL, vol->mount_point); e_fwin_new(m->zone->container, NULL, vol->mount_point);
} }
else else
{ {
@ -257,58 +274,60 @@ _e_mod_menu_volume_cb(void *data, E_Menu *m, E_Menu_Item *mi __UNUSED__)
} }
static void static void
_e_mod_fileman_parse_gtk_bookmarks(E_Menu *m, Eina_Bool need_separator) _e_mod_fileman_parse_gtk_bookmarks(E_Menu *m,
Eina_Bool need_separator)
{ {
char line[PATH_MAX]; char line[PATH_MAX];
char buf[PATH_MAX]; char buf[PATH_MAX];
E_Menu_Item *mi; E_Menu_Item *mi;
Efreet_Uri *uri; Efreet_Uri *uri;
char *alias; char *alias;
FILE* fp; FILE *fp;
snprintf(buf, sizeof(buf), "%s/.gtk-bookmarks", e_user_homedir_get()); snprintf(buf, sizeof(buf), "%s/.gtk-bookmarks", e_user_homedir_get());
fp = fopen(buf, "r"); fp = fopen(buf, "r");
if (fp) if (fp)
{ {
while(fgets(line, sizeof(line), fp)) while(fgets(line, sizeof(line), fp))
{ {
alias = NULL; alias = NULL;
line[strlen(line) - 1] = '\0'; line[strlen(line) - 1] = '\0';
alias = strchr(line, ' '); alias = strchr(line, ' ');
if (alias) if (alias)
{ {
line[alias-line] = '\0'; line[alias - line] = '\0';
alias++; alias++;
} }
uri = efreet_uri_decode(line); uri = efreet_uri_decode(line);
if (uri && uri->path) if (uri && uri->path)
{ {
if (ecore_file_exists(uri->path)) if (ecore_file_exists(uri->path))
{ {
if (need_separator) if (need_separator)
{ {
mi = e_menu_item_new(m); mi = e_menu_item_new(m);
e_menu_item_separator_set(mi, 1); e_menu_item_separator_set(mi, 1);
need_separator = 0; need_separator = 0;
} }
mi = e_menu_item_new(m); mi = e_menu_item_new(m);
e_menu_item_label_set(mi, alias ? alias : e_menu_item_label_set(mi, alias ? alias :
ecore_file_file_get(uri->path)); ecore_file_file_get(uri->path));
e_util_menu_item_theme_icon_set(mi, "folder"); e_util_menu_item_theme_icon_set(mi, "folder");
e_menu_item_callback_set(mi, _e_mod_menu_gtk_cb, e_menu_item_callback_set(mi, _e_mod_menu_gtk_cb,
(void *)eina_stringshare_add(uri->path)); (void *)eina_stringshare_add(uri->path));
} }
} }
if (uri) efreet_uri_free(uri); if (uri) efreet_uri_free(uri);
} }
fclose(fp); fclose(fp);
} }
} }
/* menu item add hook */ /* menu item add hook */
void void
_e_mod_menu_generate(void *data __UNUSED__, E_Menu *m) _e_mod_menu_generate(void *data __UNUSED__,
E_Menu *m)
{ {
E_Menu_Item *mi; E_Menu_Item *mi;
E_Volume *vol; E_Volume *vol;
@ -350,20 +369,20 @@ _e_mod_menu_generate(void *data __UNUSED__, E_Menu *m)
Eina_Bool volumes_visible = 0; Eina_Bool volumes_visible = 0;
EINA_LIST_FOREACH(e_fm2_device_volume_list_get(), l, vol) EINA_LIST_FOREACH(e_fm2_device_volume_list_get(), l, vol)
{ {
if (vol->mount_point && !strcmp(vol->mount_point, "/")) continue; if (vol->mount_point && !strcmp(vol->mount_point, "/")) continue;
if (need_separator) if (need_separator)
{ {
mi = e_menu_item_new(m); mi = e_menu_item_new(m);
e_menu_item_separator_set(mi, 1); e_menu_item_separator_set(mi, 1);
need_separator = 0; need_separator = 0;
} }
mi = e_menu_item_new(m); mi = e_menu_item_new(m);
e_menu_item_label_set(mi, vol->label); e_menu_item_label_set(mi, vol->label);
e_util_menu_item_theme_icon_set(mi, vol->icon); e_util_menu_item_theme_icon_set(mi, vol->icon);
e_menu_item_callback_set(mi, _e_mod_menu_volume_cb, vol); e_menu_item_callback_set(mi, _e_mod_menu_volume_cb, vol);
volumes_visible = 1; volumes_visible = 1;
} }
/* Favorites */ /* Favorites */
@ -376,7 +395,8 @@ _e_mod_menu_generate(void *data __UNUSED__, E_Menu *m)
} }
void void
_e_mod_menu_add(void *data __UNUSED__, E_Menu *m) _e_mod_menu_add(void *data __UNUSED__,
E_Menu *m)
{ {
#ifdef ENABLE_FILES #ifdef ENABLE_FILES
E_Menu_Item *mi; E_Menu_Item *mi;
@ -392,8 +412,8 @@ _e_mod_menu_add(void *data __UNUSED__, E_Menu *m)
} }
/* Abstract fileman config load/create to one function for maintainability */ /* Abstract fileman config load/create to one function for maintainability */
static void static void
_e_mod_fileman_config_load(void) _e_mod_fileman_config_load(void)
{ {
conf_edd = E_CONFIG_DD_NEW("Fileman_Config", Config); conf_edd = E_CONFIG_DD_NEW("Fileman_Config", Config);
#undef T #undef T
@ -429,83 +449,83 @@ _e_mod_fileman_config_load(void)
E_CONFIG_VAL(D, T, theme.frame, STR); E_CONFIG_VAL(D, T, theme.frame, STR);
E_CONFIG_VAL(D, T, theme.icons, STR); E_CONFIG_VAL(D, T, theme.icons, STR);
E_CONFIG_VAL(D, T, theme.fixed, UCHAR); E_CONFIG_VAL(D, T, theme.fixed, UCHAR);
fileman_config = e_config_domain_load("module.fileman", conf_edd); fileman_config = e_config_domain_load("module.fileman", conf_edd);
if (fileman_config) if (fileman_config)
{ {
if ((fileman_config->config_version >> 16) < MOD_CONFIG_FILE_EPOCH) if ((fileman_config->config_version >> 16) < MOD_CONFIG_FILE_EPOCH)
{ {
_e_mod_fileman_config_free(); _e_mod_fileman_config_free();
ecore_timer_add(1.0, _e_mod_cb_config_timer, ecore_timer_add(1.0, _e_mod_cb_config_timer,
_("Fileman Module Settings data needed upgrading. Your old configuration<br>" _("Fileman Module Settings data needed upgrading. Your old configuration<br>"
"has been wiped and a new set of defaults initialized. This<br>" "has been wiped and a new set of defaults initialized. This<br>"
"will happen regularly during development, so don't report a<br>" "will happen regularly during development, so don't report a<br>"
"bug. This simply means Fileman module needs new configuration<br>" "bug. This simply means Fileman module needs new configuration<br>"
"data by default for usable functionality that your old<br>" "data by default for usable functionality that your old<br>"
"configuration simply lacks. This new set of defaults will fix<br>" "configuration simply lacks. This new set of defaults will fix<br>"
"that by adding it in. You can re-configure things now to your<br>" "that by adding it in. You can re-configure things now to your<br>"
"liking. Sorry for the hiccup in your configuration.<br>")); "liking. Sorry for the hiccup in your configuration.<br>"));
} }
else if (fileman_config->config_version > MOD_CONFIG_FILE_VERSION) else if (fileman_config->config_version > MOD_CONFIG_FILE_VERSION)
{ {
_e_mod_fileman_config_free(); _e_mod_fileman_config_free();
ecore_timer_add(1.0, _e_mod_cb_config_timer, ecore_timer_add(1.0, _e_mod_cb_config_timer,
_("Your Fileman Module configuration is NEWER than Fileman Module version. This is very<br>" _("Your Fileman Module configuration is NEWER than Fileman Module version. This is very<br>"
"strange. This should not happen unless you downgraded<br>" "strange. This should not happen unless you downgraded<br>"
"the Fileman Module or copied the configuration from a place where<br>" "the Fileman Module or copied the configuration from a place where<br>"
"a newer version of the Fileman Module was running. This is bad and<br>" "a newer version of the Fileman Module was running. This is bad and<br>"
"as a precaution your configuration has been now restored to<br>" "as a precaution your configuration has been now restored to<br>"
"defaults. Sorry for the inconvenience.<br>")); "defaults. Sorry for the inconvenience.<br>"));
} }
} }
if (!fileman_config) if (!fileman_config)
{ {
fileman_config = E_NEW(Config, 1); fileman_config = E_NEW(Config, 1);
fileman_config->config_version = (MOD_CONFIG_FILE_EPOCH << 16); fileman_config->config_version = (MOD_CONFIG_FILE_EPOCH << 16);
} }
#define IFMODCFG(v) \ #define IFMODCFG(v) \
if ((fileman_config->config_version & 0xffff) < (v)) { if ((fileman_config->config_version & 0xffff) < (v)) {
#define IFMODCFGEND } #define IFMODCFGEND }
IFMODCFG(0x008d); IFMODCFG(0x008d);
fileman_config->view.mode = E_FM2_VIEW_MODE_GRID_ICONS; fileman_config->view.mode = E_FM2_VIEW_MODE_GRID_ICONS;
fileman_config->view.open_dirs_in_place = 0; fileman_config->view.open_dirs_in_place = 0;
fileman_config->view.selector = 0; fileman_config->view.selector = 0;
fileman_config->view.single_click = 0; fileman_config->view.single_click = 0;
fileman_config->view.no_subdir_jump = 0; fileman_config->view.no_subdir_jump = 0;
fileman_config->view.show_full_path = 0; fileman_config->view.show_full_path = 0;
fileman_config->view.show_desktop_icons = 1; fileman_config->view.show_desktop_icons = 1;
fileman_config->icon.icon.w = 48; fileman_config->icon.icon.w = 48;
fileman_config->icon.icon.h = 48; fileman_config->icon.icon.h = 48;
fileman_config->icon.fixed.w = 0; fileman_config->icon.fixed.w = 0;
fileman_config->icon.fixed.h = 0; fileman_config->icon.fixed.h = 0;
fileman_config->icon.extension.show = 1; fileman_config->icon.extension.show = 1;
fileman_config->list.sort.no_case = 1; fileman_config->list.sort.no_case = 1;
fileman_config->list.sort.dirs.first = 1; fileman_config->list.sort.dirs.first = 1;
fileman_config->list.sort.dirs.last = 0; fileman_config->list.sort.dirs.last = 0;
fileman_config->selection.single = 0; fileman_config->selection.single = 0;
fileman_config->selection.windows_modifiers = 0; fileman_config->selection.windows_modifiers = 0;
IFMODCFGEND; IFMODCFGEND;
IFMODCFG(0x0101); IFMODCFG(0x0101);
fileman_config->view.show_toolbar = 0; fileman_config->view.show_toolbar = 0;
IFMODCFGEND; IFMODCFGEND;
fileman_config->config_version = MOD_CONFIG_FILE_VERSION; fileman_config->config_version = MOD_CONFIG_FILE_VERSION;
/* UCHAR's give nasty compile warnings about comparisons so not gonna limit those */ /* UCHAR's give nasty compile warnings about comparisons so not gonna limit those */
E_CONFIG_LIMIT(fileman_config->view.mode, E_FM2_VIEW_MODE_ICONS, E_FM2_VIEW_MODE_LIST); E_CONFIG_LIMIT(fileman_config->view.mode, E_FM2_VIEW_MODE_ICONS, E_FM2_VIEW_MODE_LIST);
E_CONFIG_LIMIT(fileman_config->icon.icon.w, 16, 256); E_CONFIG_LIMIT(fileman_config->icon.icon.w, 16, 256);
E_CONFIG_LIMIT(fileman_config->icon.icon.h, 16, 256); E_CONFIG_LIMIT(fileman_config->icon.icon.h, 16, 256);
E_CONFIG_LIMIT(fileman_config->icon.list.w, 16, 256); E_CONFIG_LIMIT(fileman_config->icon.list.w, 16, 256);
E_CONFIG_LIMIT(fileman_config->icon.list.h, 16, 256); E_CONFIG_LIMIT(fileman_config->icon.list.h, 16, 256);
e_config_save_queue(); e_config_save_queue();
} }
static void static void
_e_mod_fileman_config_free(void) _e_mod_fileman_config_free(void)
{ {
if (fileman_config->theme.background) if (fileman_config->theme.background)
eina_stringshare_del(fileman_config->theme.background); eina_stringshare_del(fileman_config->theme.background);
@ -513,7 +533,7 @@ _e_mod_fileman_config_free(void)
eina_stringshare_del(fileman_config->theme.frame); eina_stringshare_del(fileman_config->theme.frame);
if (fileman_config->theme.icons) if (fileman_config->theme.icons)
eina_stringshare_del(fileman_config->theme.icons); eina_stringshare_del(fileman_config->theme.icons);
E_FREE(fileman_config); E_FREE(fileman_config);
} }
static Eina_Bool static Eina_Bool
@ -524,28 +544,31 @@ _e_mod_cb_config_timer(void *data)
} }
static Eina_Bool static Eina_Bool
_e_mod_zone_add(__UNUSED__ void *data, int type, void *event) _e_mod_zone_add(__UNUSED__ void *data,
int type,
void *event)
{ {
E_Event_Zone_Add *ev; E_Event_Zone_Add *ev;
E_Zone *zone; E_Zone *zone;
if (type != E_EVENT_ZONE_ADD) return ECORE_CALLBACK_PASS_ON; if (type != E_EVENT_ZONE_ADD) return ECORE_CALLBACK_PASS_ON;
ev = event; ev = event;
zone = ev->zone; zone = ev->zone;
if (e_fwin_zone_find(zone)) return ECORE_CALLBACK_PASS_ON; if (e_fwin_zone_find(zone)) return ECORE_CALLBACK_PASS_ON;
if ((zone->container->num == 0) && (zone->num == 0) && if ((zone->container->num == 0) && (zone->num == 0) &&
(fileman_config->view.show_desktop_icons)) (fileman_config->view.show_desktop_icons))
e_fwin_zone_new(zone, "desktop", "/"); e_fwin_zone_new(zone, "desktop", "/");
else else
{ {
char buf[256]; char buf[256];
if (fileman_config->view.show_desktop_icons) if (fileman_config->view.show_desktop_icons)
{ {
snprintf(buf, sizeof(buf), "%i", snprintf(buf, sizeof(buf), "%i",
(zone->container->num + zone->num)); (zone->container->num + zone->num));
e_fwin_zone_new(zone, "desktop", buf); e_fwin_zone_new(zone, "desktop", buf);
} }
} }
return ECORE_CALLBACK_PASS_ON; return ECORE_CALLBACK_PASS_ON;
} }