#include #include "e_mod_win.h" #include "e_slipshelf.h" #include "e_slipwin.h" #include "e_mod_layout.h" #include "e_kbd.h" #include "e_kbd_int.h" #include "e_busywin.h" #include "e_busycover.h" #include "e_cfg.h" #include "e_flaunch.h" // FIXME: need e_kbd_init() as optional and a way to select internal or // externally execced kbd /* internal calls */ static void _cb_cfg_exec(const void *data, E_Container *con, const char *params, Efreet_Desktop *desktop); static void _desktop_run(Efreet_Desktop *desktop); static int _cb_zone_move_resize(void *data, int type, void *event); static void _cb_resize(void); static void _cb_run(void *data); static int _cb_event_border_add(void *data, int type, void *event); static int _cb_event_border_remove(void *data, int type, void *event); static int _cb_event_exe_del(void *data, int type, void *event); static int _cb_run_timeout(void *data); static int _have_borders(void); static void _cb_slipshelf_home(const void *data, E_Slipshelf *ess, E_Slipshelf_Action action); static void _cb_slipshelf_close(const void *data, E_Slipshelf *ess, E_Slipshelf_Action action); static void _cb_slipshelf_apps(const void *data, E_Slipshelf *ess, E_Slipshelf_Action action); static void _cb_slipshelf_keyboard(const void *data, E_Slipshelf *ess, E_Slipshelf_Action action); static void _cb_slipwin_select(const void *data, E_Slipwin *esw, E_Border *bd); static void _cb_slipshelf_select(const void *data, E_Slipshelf *ess, E_Border *bd); static void _cb_slipshelf_add(const void *data, E_Slipshelf *ess, E_Border *bd); static void _cb_slipshelf_del(const void *data, E_Slipshelf *ess, E_Border *bd); static void _cb_slipshelf_home2(const void *data, E_Slipshelf *ess, E_Border *bd); static void _cb_selected(void *data, Evas_Object *obj, void *event_info); static int _cb_efreet_desktop_list_change(void *data, int type, void *event); static int _cb_efreet_desktop_change(void *data, int type, void *event); static void _apps_unpopulate(void); static void _apps_populate(void); static int _cb_update_deferred(void *data); static void _e_illume_pan_set(Evas_Object *obj, Evas_Coord x, Evas_Coord y); static void _e_illume_pan_get(Evas_Object *obj, Evas_Coord *x, Evas_Coord *y); static void _e_illume_pan_max_get(Evas_Object *obj, Evas_Coord *x, Evas_Coord *y); static void _e_illume_pan_child_size_get(Evas_Object *obj, Evas_Coord *w, Evas_Coord *h); static void _e_illume_pan_scroll_update(void); /* state */ /* public for cfg */ E_Slipshelf *slipshelf = NULL; static E_Module *mod = NULL; static E_Zone *zone = NULL; static Evas *evas = NULL; static Evas_Object *sf = NULL; static Evas_Object *bx = NULL; static Evas_Object *fm = NULL; static Evas_List *desks = NULL; static Evas_List *handlers = NULL; static Evas_List *sels = NULL; static E_Slipwin *slipwin = NULL; static Ecore_Timer *defer = NULL; static E_Kbd *vkbd = NULL; static E_Kbd_Int *vkbd_int = NULL; static E_Busywin *busywin = NULL; static E_Busywin *busycover = NULL; static E_Flaunch *flaunch = NULL; /* called from the module core */ void _e_mod_win_init(E_Module *m) { mod = m; zone = e_util_container_zone_number_get(0, 0); ecore_x_window_background_color_set(zone->container->manager->root, 0, 0, 0); slipshelf = e_slipshelf_new(zone, e_module_dir_get(m)); e_slipshelf_default_title_set(slipshelf, "ILLUME"); if (!_have_borders()) e_slipshelf_action_enabled_set(slipshelf, E_SLIPSHELF_ACTION_APPS, 0); e_slipshelf_action_callback_set(slipshelf, E_SLIPSHELF_ACTION_HOME, _cb_slipshelf_home, NULL); e_slipshelf_action_callback_set(slipshelf, E_SLIPSHELF_ACTION_CLOSE, _cb_slipshelf_close, NULL); e_slipshelf_action_callback_set(slipshelf, E_SLIPSHELF_ACTION_APPS, _cb_slipshelf_apps, NULL); e_slipshelf_action_callback_set(slipshelf, E_SLIPSHELF_ACTION_KEYBOARD, _cb_slipshelf_keyboard, NULL); e_slipshelf_border_select_callback_set(slipshelf, _cb_slipshelf_select, NULL); e_slipshelf_border_add_callback_set(slipshelf, _cb_slipshelf_add, NULL); e_slipshelf_border_del_callback_set(slipshelf, _cb_slipshelf_del, NULL); e_slipshelf_border_home_callback_set(slipshelf, _cb_slipshelf_home2, NULL); slipwin = e_slipwin_new(zone, e_module_dir_get(m)); e_slipwin_border_select_callback_set(slipwin, _cb_slipwin_select, NULL); vkbd = e_kbd_new(zone, e_module_dir_get(m), e_module_dir_get(m), e_module_dir_get(m)); // FIXME: run kbd app or use internal #if 0 //enable for now to test internal kbd vkbd_int = e_kbd_int_new(e_module_dir_get(m), e_module_dir_get(m), e_module_dir_get(m)); #endif // busywin = e_busywin_new(zone, e_module_dir_get(m)); busycover = e_busycover_new(zone, e_module_dir_get(m)); flaunch = e_flaunch_new(zone, e_module_dir_get(m)); e_flaunch_desktop_exec_callabck_set(flaunch, _desktop_run); handlers = evas_list_append (handlers, ecore_event_handler_add (E_EVENT_BORDER_ADD, _cb_event_border_add, NULL)); handlers = evas_list_append (handlers, ecore_event_handler_add (E_EVENT_BORDER_REMOVE, _cb_event_border_remove, NULL)); handlers = evas_list_append (handlers, ecore_event_handler_add (ECORE_EXE_EVENT_DEL, _cb_event_exe_del, NULL)); handlers = evas_list_append (handlers, ecore_event_handler_add (EFREET_EVENT_DESKTOP_LIST_CHANGE, _cb_efreet_desktop_list_change, NULL)); handlers = evas_list_append (handlers, ecore_event_handler_add (EFREET_EVENT_DESKTOP_CHANGE, _cb_efreet_desktop_change, NULL)); handlers = evas_list_append (handlers, ecore_event_handler_add (E_EVENT_ZONE_MOVE_RESIZE, _cb_zone_move_resize, NULL)); evas = zone->container->bg_evas; _apps_unpopulate(); _apps_populate(); e_configure_registry_custom_desktop_exec_callback_set(_cb_cfg_exec, NULL); } void _e_mod_win_shutdown(void) { e_object_del(E_OBJECT(flaunch)); flaunch = NULL; if (busywin) { e_object_del(E_OBJECT(busywin)); busywin = NULL; } if (busycover) { e_object_del(E_OBJECT(busycover)); busycover = NULL; } if (vkbd_int) { e_kbd_int_free(vkbd_int); vkbd_int = NULL; } e_object_del(E_OBJECT(vkbd)); vkbd = NULL; e_configure_registry_custom_desktop_exec_callback_set(NULL, NULL); _apps_unpopulate(); if (sf) evas_object_del(sf); if (bx) evas_object_del(bx); if (fm) evas_object_del(fm); e_object_del(E_OBJECT(slipshelf)); slipshelf = NULL; e_object_del(E_OBJECT(slipwin)); slipwin = NULL; } void _e_mod_win_cfg_update(void) { _apps_unpopulate(); _apps_populate(); } void _e_mod_win_slipshelf_cfg_update(void) { if (slipshelf) e_object_del(E_OBJECT(slipshelf)); slipshelf = e_slipshelf_new(zone, e_module_dir_get(mod)); e_slipshelf_default_title_set(slipshelf, "ILLUME"); if (!_have_borders()) e_slipshelf_action_enabled_set(slipshelf, E_SLIPSHELF_ACTION_APPS, 0); e_slipshelf_action_callback_set(slipshelf, E_SLIPSHELF_ACTION_HOME, _cb_slipshelf_home, NULL); e_slipshelf_action_callback_set(slipshelf, E_SLIPSHELF_ACTION_CLOSE, _cb_slipshelf_close, NULL); e_slipshelf_action_callback_set(slipshelf, E_SLIPSHELF_ACTION_APPS, _cb_slipshelf_apps, NULL); e_slipshelf_action_callback_set(slipshelf, E_SLIPSHELF_ACTION_KEYBOARD, _cb_slipshelf_keyboard, NULL); e_slipshelf_border_select_callback_set(slipshelf, _cb_slipshelf_select, NULL); e_slipshelf_border_add_callback_set(slipshelf, _cb_slipshelf_add, NULL); e_slipshelf_border_del_callback_set(slipshelf, _cb_slipshelf_del, NULL); e_slipshelf_border_home_callback_set(slipshelf, _cb_slipshelf_home2, NULL); _cb_resize(); _e_mod_layout_apply_all(); } /* internal calls */ static int _cb_zone_move_resize(void *data, int type, void *event) { _cb_resize(); return 1; } static void _cb_resize(void) { Evas_Coord mw, mh; int x, y, w, h; e_slipshelf_safe_app_region_get(zone, &x, &y, &w, &h); w = zone->w; h = zone->y + zone->h - y; h -= flaunch->height; if (bx) { e_box_min_size_get(bx, &mw, &mh); if (mw < w) mw = w; evas_object_move(sf, x, y); evas_object_resize(bx, mw, mh); evas_object_resize(sf, w, h); } else { evas_object_move(sf, x, y); evas_object_resize(sf, w, h); } } typedef struct _Instance Instance; struct _Instance { Efreet_Desktop *desktop; E_Border *border; Ecore_Timer *timeout; int startup_id; pid_t pid; void *handle; }; static Evas_List *instances = NULL; static void _cb_cfg_exec(const void *data, E_Container *con, const char *params, Efreet_Desktop *desktop) { _desktop_run(desktop); } static void _desktop_run(Efreet_Desktop *desktop) { Evas_List *l, *borders; E_Exec_Instance *eins; Instance *ins; char *exename, *p; printf("...RUN %s\n", desktop->exec); for (l = instances; l; l = l->next) { ins = l->data; if (ins->desktop == desktop) { if (ins->border) { printf("FLIPPED to EXE\n"); _e_mod_layout_border_show(ins->border); } return; } } exename = NULL; p = strchr(desktop->exec, ' '); if (!p) exename = strdup(desktop->exec); else { exename = malloc(p - desktop->exec + 1); if (exename) { strncpy(exename, desktop->exec, p - desktop->exec); exename[p - desktop->exec] = 0; } } if (exename) { p = strrchr(exename, '/'); if (p) strcpy(exename, p + 1); } printf("exe = %s\n", exename); borders = e_border_client_list(); for (l = borders; l; l = l->next) { E_Border *bd; bd = l->data; printf(" ... has pid %i startup_id %i\n", bd->client.netwm.pid, bd->client.netwm.startup_id); if (e_exec_startup_id_pid_find(bd->client.netwm.pid, bd->client.netwm.startup_id) == desktop) { printf("FLIPPED to EXE (backup1)\n"); _e_mod_layout_border_show(bd); if (exename) free(exename); return; } if (bd->client.icccm.command.argv) printf(" ... has argv0 = %s\n", bd->client.icccm.command.argv[0]); if ((exename) && (bd->client.icccm.command.argv) && ((!strcmp(exename, bd->client.icccm.command.argv[0])))) { printf("FLIPPED to EXE (backup2)\n"); _e_mod_layout_border_show(bd); if (exename) free(exename); return; } } if (exename) free(exename); ins = calloc(1, sizeof(Instance)); if (!ins) return; eins = e_exec(zone, desktop, NULL, NULL, "illume-launcher"); printf("eins = %p\n", eins); ins->desktop = desktop; if (eins) { ins->startup_id = eins->startup_id; ins->pid = ecore_exe_pid_get(eins->exe); } printf("id = %i, pid = %i\n", ins->startup_id, ins->pid); ins->timeout = ecore_timer_add(20.0, _cb_run_timeout, ins); { char buf[256]; snprintf(buf, sizeof(buf), "Starting %s", desktop->name); // ins->handle = e_busywin_push(busywin, buf, NULL); ins->handle = e_busycover_push(busycover, buf, NULL); } instances = evas_list_append(instances, ins); } static void _cb_run(void *data) { Efreet_Desktop *desktop; desktop = data; _desktop_run(desktop); } static int _cb_event_border_add(void *data, int type, void *event) { E_Event_Border_Add *ev; Efreet_Desktop *desktop; Instance *ins; Evas_List *l; ev = event; e_slipshelf_action_enabled_set(slipshelf, E_SLIPSHELF_ACTION_APPS, 1); desktop = e_exec_startup_id_pid_find(ev->border->client.netwm.pid, ev->border->client.netwm.startup_id); printf("ADD bd %p, desktop = %p, id = %i\n", ev->border, desktop, ev->border->client.netwm.startup_id); for (l = instances; l; l = l->next) { ins = l->data; if (!ins->border) { if ((ins->startup_id == ev->border->client.netwm.startup_id) || (ins->pid == ev->border->client.netwm.pid)) { ins->border = ev->border; if (ins->handle) { // e_busywin_pop(busywin, ins->handle); e_busycover_pop(busycover, ins->handle); ins->handle = NULL; } printf("found bd for ins\n"); if (ins->timeout) ecore_timer_del(ins->timeout); ins->timeout = NULL; // FIXME; if gadget is disabled, enable it return 1; } } } return 1; } static int _cb_event_border_remove(void *data, int type, void *event) { E_Event_Border_Remove *ev; Instance *ins; Evas_List *l; ev = event; printf("bd del %p, list = %p\n", ev->border, e_border_client_list()); if (!_have_borders()) e_slipshelf_action_enabled_set(slipshelf, E_SLIPSHELF_ACTION_APPS, 0); for (l = instances; l; l = l->next) { ins = l->data; if (ins->border == ev->border) { if (ins->handle) { // e_busywin_pop(busywin, ins->handle); e_busycover_pop(busycover, ins->handle); ins->handle = NULL; } ins->border = NULL; return 1; } } return 1; } static int _cb_event_exe_del(void *data, int type, void *event) { Ecore_Exe_Event_Del *ev; Instance *ins; Evas_List *l; ev = event; for (l = instances; l; l = l->next) { ins = l->data; if (ins->pid == ev->pid) { if (ins->handle) { // e_busywin_pop(busywin, ins->handle); e_busycover_pop(busycover, ins->handle); ins->handle = NULL; } printf("remove pid\n"); instances = evas_list_remove_list(instances, l); if (ins->timeout) ecore_timer_del(ins->timeout); free(ins); return 1; } } return 1; } static int _cb_run_timeout(void *data) { Instance *ins; ins = data; if (ins->handle) { // e_busywin_pop(busywin, ins->handle); e_busycover_pop(busycover, ins->handle); ins->handle = NULL; } if (!ins->border) { instances = evas_list_remove(instances, ins); free(ins); return 0; } ins->timeout = NULL; return 0; } static int _have_borders(void) { Evas_List *borders, *l; int num = 0; borders = e_border_client_list(); for (l = borders; l; l = l->next) { E_Border *bd; bd = l->data; if (e_object_is_del(E_OBJECT(bd))) continue; if ((!bd->client.icccm.accepts_focus) && (!bd->client.icccm.take_focus)) continue; if (bd->client.netwm.state.skip_taskbar) continue; if (bd->user_skip_winlist) continue; num++; } return num; } static void _cb_slipshelf_home(const void *data, E_Slipshelf *ess, E_Slipshelf_Action action) { Evas_List *l, *borders; borders = e_border_client_list(); for (l = borders; l; l = l->next) { E_Border *bd; bd = l->data; if (e_object_is_del(E_OBJECT(bd))) continue; if ((!bd->client.icccm.accepts_focus) && (!bd->client.icccm.take_focus)) continue; if (bd->client.netwm.state.skip_taskbar) continue; if (bd->user_skip_winlist) continue; _e_mod_layout_border_hide(bd); } } static void _cb_slipshelf_close(const void *data, E_Slipshelf *ess, E_Slipshelf_Action action) { E_Border *bd; bd = e_border_focused_get(); if (bd) { if (e_object_is_del(E_OBJECT(bd))) return; if ((!bd->client.icccm.accepts_focus) && (!bd->client.icccm.take_focus)) return; if (bd->client.netwm.state.skip_taskbar) return; if (bd->user_skip_winlist) return; _e_mod_layout_border_close(bd); } } static void _cb_slipshelf_apps(const void *data, E_Slipshelf *ess, E_Slipshelf_Action action) { if (!_have_borders()) return; e_slipwin_show(slipwin); } static void _cb_slipshelf_keyboard(const void *data, E_Slipshelf *ess, E_Slipshelf_Action action) { printf("KBD toggle %i\n", (int)vkbd->visible); if (vkbd->visible) e_kbd_hide(vkbd); else e_kbd_show(vkbd); } static void _cb_slipwin_select(const void *data, E_Slipwin *esw, E_Border *bd) { if (bd) _e_mod_layout_border_show(bd); } static void _cb_slipshelf_select(const void *data, E_Slipshelf *ess, E_Border *bd) { if (bd) _e_mod_layout_border_show(bd); } static void _cb_slipshelf_add(const void *data, E_Slipshelf *ess, E_Border *bd) { printf("FIXME: implement add\n"); } static void _cb_slipshelf_del(const void *data, E_Slipshelf *ess, E_Border *bd) { if (!bd) return; if (e_object_is_del(E_OBJECT(bd))) return; if ((!bd->client.icccm.accepts_focus) && (!bd->client.icccm.take_focus)) return; if (bd->client.netwm.state.skip_taskbar) return; if (bd->user_skip_winlist) return; _e_mod_layout_border_close(bd); } static void _cb_slipshelf_home2(const void *data, E_Slipshelf *ess, E_Border *bd) { Evas_List *l, *borders; borders = e_border_client_list(); for (l = borders; l; l = l->next) { E_Border *bd; bd = l->data; if (e_object_is_del(E_OBJECT(bd))) continue; if ((!bd->client.icccm.accepts_focus) && (!bd->client.icccm.take_focus)) continue; if (bd->client.netwm.state.skip_taskbar) continue; if (bd->user_skip_winlist) continue; _e_mod_layout_border_hide(bd); } } static void _apps_unpopulate(void) { char buf[PATH_MAX], *homedir; Ecore_List *files; while (sels) { // printf("DEL %p\n", sels->data); evas_object_del(sels->data); sels = evas_list_remove_list(sels, sels); } while (desks) { Efreet_Desktop *desktop; desktop = desks->data; efreet_desktop_free(desktop); desks = evas_list_remove_list(desks, desks); } if (bx) evas_object_del(bx); bx = NULL; if (fm) evas_object_del(fm); fm = NULL; if (sf) evas_object_del(sf); sf = NULL; homedir = e_user_homedir_get(); snprintf(buf, sizeof(buf), "%s/.e/e/appshadow", homedir); files = ecore_file_ls(buf); if (files) { char *file; ecore_list_first_goto(files); while ((file = ecore_list_current(files))) { snprintf(buf, sizeof(buf), "%s/.e/e/appshadow/%s", homedir, file); ecore_file_unlink(buf); ecore_list_next(files); } ecore_list_destroy(files); } } static void _apps_fm_config(Evas_Object *o) { E_Fm2_Config fmc; memset(&fmc, 0, sizeof(E_Fm2_Config)); fmc.view.mode = E_FM2_VIEW_MODE_GRID_ICONS; fmc.view.open_dirs_in_place = 1; fmc.view.selector = 0; fmc.view.single_click = illume_cfg->launcher.single_click; fmc.view.no_subdir_jump = 1; fmc.icon.extension.show = 0; fmc.icon.icon.w = illume_cfg->launcher.icon_size; fmc.icon.icon.h = illume_cfg->launcher.icon_size; fmc.icon.fixed.w = illume_cfg->launcher.icon_size; fmc.icon.fixed.h = illume_cfg->launcher.icon_size; fmc.list.sort.no_case = 0; fmc.list.sort.dirs.first = 1; fmc.list.sort.dirs.last = 0; fmc.selection.single = 1; fmc.selection.windows_modifiers = 0; e_fm2_config_set(o, &fmc); } static void _apps_populate(void) { Evas_Coord mw, mh, sfw, sfh; Evas_Object *o; char buf[PATH_MAX], *homedir; int num = 0; sf = e_scrollframe_add(evas); e_scrollframe_single_dir_set(sf, 1); evas_object_move(sf, zone->x, zone->y); evas_object_resize(sf, zone->w, zone->h); evas_object_show(sf); e_scrollframe_custom_theme_set(sf, "base/theme/fileman", "e/modules/illume/launcher/scrollview"); if (illume_cfg->launcher.mode == 0) { bx = e_box_add(evas); e_box_orientation_set(bx, 0); e_box_homogenous_set(bx, 1); e_box_freeze(bx); e_scrollframe_child_set(sf, bx); } else { homedir = e_user_homedir_get(); snprintf(buf, sizeof(buf), "%s/.e/e/appshadow", homedir); ecore_file_mkpath(buf); fm = e_fm2_add(evas); _apps_fm_config(fm); e_scrollframe_extern_pan_set(sf, fm, _e_illume_pan_set, _e_illume_pan_get, _e_illume_pan_max_get, _e_illume_pan_child_size_get); } e_scrollframe_child_viewport_size_get(sf, &sfw, &sfh); { Efreet_Menu *menu, *entry, *subentry; Efreet_Desktop *desktop; char *label, *icon, *plabel; Ecore_List *settings_desktops, *system_desktops; settings_desktops = efreet_util_desktop_category_list("Settings"); system_desktops = efreet_util_desktop_category_list("System"); menu = efreet_menu_get(); if (menu) { ecore_list_first_goto(menu->entries); while ((entry = ecore_list_next(menu->entries))) { if (entry->type != EFREET_MENU_ENTRY_MENU) continue; desktop = entry->desktop; plabel = NULL; if (entry->name) plabel = strdup(entry->name); if (!plabel) plabel = strdup("???"); if (illume_cfg->launcher.mode == 0) { o = e_slidesel_add(evas); e_slidesel_item_distance_set(o, 128); } ecore_list_first_goto(entry->entries); while ((subentry = ecore_list_next(entry->entries))) { if (subentry->type != EFREET_MENU_ENTRY_DESKTOP) continue; label = icon = NULL; desktop = subentry->desktop; if (!desktop) continue; if ((settings_desktops) && (system_desktops) && (ecore_list_goto(settings_desktops, desktop)) && (ecore_list_goto(system_desktops, desktop))) continue; if ((desktop) && (desktop->x)) { icon = ecore_hash_get(desktop->x, "X-Application-Screenshot"); if (icon) icon = strdup(icon); } if ((!icon) && (subentry->icon)) { if (subentry->icon[0] == '/') icon = strdup(subentry->icon); else icon = efreet_icon_path_find(e_config->icon_theme, subentry->icon, "512x512"); } if (subentry->name) label = strdup(subentry->name); if (desktop) { if (!label) label = strdup(desktop->generic_name); if ((!icon) && (desktop->icon)) icon = efreet_icon_path_find(e_config->icon_theme, desktop->icon, "512x512"); } if (!icon) icon = efreet_icon_path_find(e_config->icon_theme, "hires.jpg", "512x512"); if (!icon) icon = strdup("DEFAULT"); if (!label) label = strdup("???"); // printf("app: %s / %s\n icon: %s\n", plabel, label, icon); snprintf(buf, sizeof(buf), "%s / %s", plabel, label); desks = evas_list_append(desks, desktop); efreet_desktop_ref(desktop); if (illume_cfg->launcher.mode == 0) { e_slidesel_item_add(o, buf, icon, _cb_run, desktop); } else { if (desktop) { snprintf(buf, sizeof(buf), "%s/.e/e/appshadow/%04x.desktop", homedir, num); ecore_file_symlink(desktop->orig_path, buf); } num++; } if (label) free(label); if (icon) free(icon); } if (plabel) free(plabel); if (illume_cfg->launcher.mode == 0) { e_box_pack_end(bx, o); // e_box_pack_options_set(o, 1, 1, 0, 0, 0.5, 0.5, // 420, 215, 420, 215); e_box_pack_options_set(o, 1, 1, 0, 0, 0.5, 0.5, sfw, illume_cfg->launcher.icon_size * 2, sfw, illume_cfg->launcher.icon_size * 2); evas_object_show(o); sels = evas_list_append(sels, o); } } } } if (illume_cfg->launcher.mode == 0) { e_box_thaw(bx); } _cb_resize(); if (illume_cfg->launcher.mode == 0) { // e_scrollframe_child_set(sf, bx); evas_object_show(bx); } else { /* FIXME: hacked to copy fileman - make illume themed */ //// e_scrollframe_custom_theme_set(sf, "base/theme/fileman", //// "e/fileman/desktop/scrollframe"); // e_scrollframe_extern_pan_set(sf, fm, // _e_illume_pan_set, // _e_illume_pan_get, // _e_illume_pan_max_get, // _e_illume_pan_child_size_get); homedir = e_user_homedir_get(); snprintf(buf, sizeof(buf), "%s/.e/e/appshadow", homedir); e_fm2_path_set(fm, NULL, buf); evas_object_show(fm); evas_object_smart_callback_add(fm, "selected", _cb_selected, NULL); } } static void _cb_selected(void *data, Evas_Object *obj, void *event_info) { Evas_List *selected, *l; selected = e_fm2_selected_list_get(obj); if (!selected) return; for (l = selected; l; l = l->next) { E_Fm2_Icon_Info *ici; Efreet_Desktop *desktop; ici = l->data; desktop = efreet_desktop_get(ici->real_link); if (desktop) _desktop_run(desktop); } evas_list_free(selected); } static int _cb_efreet_desktop_list_change(void *data, int type, void *event) { printf("list... change\n"); if (defer) ecore_timer_del(defer); defer = ecore_timer_add(1.0, _cb_update_deferred, NULL); return 1; } static int _cb_efreet_desktop_change(void *data, int type, void *event) { printf("desktop... change\n"); // if (bx) // { if (defer) ecore_timer_del(defer); defer = ecore_timer_add(1.0, _cb_update_deferred, NULL); // } return 1; } static int _cb_update_deferred(void *data) { _apps_unpopulate(); _apps_populate(); printf("deferred update done\n"); defer = NULL; return 0; } static void _e_illume_pan_set(Evas_Object *obj, Evas_Coord x, Evas_Coord y) { // E_Fwin *fwin; // // fwin = evas_object_data_get(obj, "fwin"); e_fm2_pan_set(obj, x, y); // if (x > fwin->fm_pan.max_x) x = fwin->fm_pan.max_x; // if (y > fwin->fm_pan.max_y) y = fwin->fm_pan.max_y; // if (x < 0) x = 0; // if (y < 0) y = 0; // fwin->fm_pan.x = x; // fwin->fm_pan.y = y; // _e_illume_pan_scroll_update(fwin); } static void _e_illume_pan_get(Evas_Object *obj, Evas_Coord *x, Evas_Coord *y) { // E_Fwin *fwin; // // fwin = evas_object_data_get(obj, "fwin"); e_fm2_pan_get(obj, x, y); // fwin->fm_pan.x = *x; // fwin->fm_pan.y = *y; } static void _e_illume_pan_max_get(Evas_Object *obj, Evas_Coord *x, Evas_Coord *y) { // E_Fwin *fwin; // // fwin = evas_object_data_get(obj, "fwin"); e_fm2_pan_max_get(obj, x, y); // fwin->fm_pan.max_x = *x; // fwin->fm_pan.max_y = *y; // _e_illume_pan_scroll_update(fwin); } static void _e_illume_pan_child_size_get(Evas_Object *obj, Evas_Coord *w, Evas_Coord *h) { // E_Fwin *fwin; // fwin = evas_object_data_get(obj, "fwin"); e_fm2_pan_child_size_get(obj, w, h); // fwin->fm_pan.w = *w; // fwin->fm_pan.h = *h; // _e_illume_pan_scroll_update(fwin); } static void _e_illume_pan_scroll_update(void) { /* Edje_Message_Int_Set *msg; if ((fwin->fm_pan.x == fwin->fm_pan_last.x) && (fwin->fm_pan.y == fwin->fm_pan_last.y) && (fwin->fm_pan.max_x == fwin->fm_pan_last.max_x) && (fwin->fm_pan.max_y == fwin->fm_pan_last.max_y) && (fwin->fm_pan.w == fwin->fm_pan_last.w) && (fwin->fm_pan.h == fwin->fm_pan_last.h)) return; msg = alloca(sizeof(Edje_Message_Int_Set) - sizeof(int) + (6 * sizeof(int))); msg->count = 6; msg->val[0] = fwin->fm_pan.x; msg->val[1] = fwin->fm_pan.y; msg->val[2] = fwin->fm_pan.max_x; msg->val[3] = fwin->fm_pan.max_y; msg->val[4] = fwin->fm_pan.w; msg->val[5] = fwin->fm_pan.h; if (fwin->under_obj) edje_object_message_send(fwin->under_obj, EDJE_MESSAGE_INT_SET, 1, msg); if (fwin->over_obj) edje_object_message_send(fwin->over_obj, EDJE_MESSAGE_INT_SET, 1, msg); if (fwin->scrollframe_obj) edje_object_message_send(e_scrollframe_edje_object_get(fwin->scrollframe_obj), EDJE_MESSAGE_INT_SET, 1, msg); fwin->fm_pan_last.x = fwin->fm_pan.x; fwin->fm_pan_last.y = fwin->fm_pan.y; fwin->fm_pan_last.max_x = fwin->fm_pan.max_x; fwin->fm_pan_last.max_y = fwin->fm_pan.max_y; fwin->fm_pan_last.w = fwin->fm_pan.w; fwin->fm_pan_last.h = fwin->fm_pan.h; */ }