DH,
Is there any way to make these categories collapsable? I'de think
that once your E is setup initially you'de want the giant list of 40
config modules mostly out of the way.
-ZGold
On 11/2/07, Enlightenment CVS <[EMAIL PROTECTED]> wrote:
> Enlightenment CVS committal
>
> Author : devilhorns
> Project : e17
> Module : apps/e
>
> Dir : e17/apps/e/src/bin
>
>
> Modified Files:
> e_int_config_modules.c
>
>
> Log Message:
> Modify dialog to sort modules into categories.
>
> ===================================================================
> RCS file: /cvs/e/e17/apps/e/src/bin/e_int_config_modules.c,v
> retrieving revision 1.77
> retrieving revision 1.78
> diff -u -3 -r1.77 -r1.78
> --- e_int_config_modules.c 31 Oct 2007 19:48:30 -0000 1.77
> +++ e_int_config_modules.c 2 Nov 2007 07:00:17 -0000 1.78
> @@ -6,7 +6,7 @@
> typedef struct _CFModule
> {
> const char *short_name, *name, *comment;
> - const char *icon, *orig_path;
> + const char *icon, *orig_path, *type;
> int enabled, selected;
> } CFModule;
>
> @@ -34,6 +34,8 @@
> static void _btn_cb_unload (void *data, void *data2);
> static void _btn_cb_load (void *data, void *data2);
> static int _upd_hdl_cb (void *data, int type, void *event);
> +static void _fill_list (Evas_Object *obj, const char *type, int
> enabled);
> +static int _find_module_category (const char *type, int enabled);
>
> /* Hash callback Protos */
> static Evas_Bool _modules_hash_cb_free (Evas_Hash *hash __UNUSED__,
> @@ -192,6 +194,7 @@
> ecore_list_first_goto(files);
> while ((mod = ecore_list_next(files)))
> {
> + const char *type;
> char buf[4096];
> Efreet_Desktop *desktop;
> CFModule *module;
> @@ -210,9 +213,18 @@
> module->short_name = evas_stringshare_add(mod);
> if (desktop->name) module->name = evas_stringshare_add(desktop->name);
> if (desktop->icon) module->icon = evas_stringshare_add(desktop->icon);
> - if (desktop->comment) module->comment =
> evas_stringshare_add(desktop->comment);
> + if (desktop->comment)
> + module->comment = evas_stringshare_add(desktop->comment);
> if (desktop->orig_path)
> module->orig_path = evas_stringshare_add(desktop->orig_path);
> + if (desktop->x)
> + {
> + type = ecore_hash_get(desktop->x, "X-Enlightenment-ModuleType");
> + if (type)
> + module->type = evas_stringshare_add(type);
> + }
> + else
> + module->type = evas_stringshare_add("shelf");
> if (e_module_find(mod)) module->enabled = 1;
>
> modules = evas_hash_direct_add(modules,
> @@ -240,7 +252,6 @@
> _fill_avail_list(E_Config_Dialog_Data *cfdata)
> {
> Evas *evas;
> - Evas_List *l = NULL;
> Evas_Coord w;
>
> if (!cfdata) return;
> @@ -251,60 +262,44 @@
> e_widget_ilist_freeze(cfdata->o_avail);
> e_widget_ilist_clear(cfdata->o_avail);
>
> - for (l = modules_list; l; l = l->next)
> + if (_find_module_category("appearance", 0))
> {
> - CFModule *module = NULL;
> - Evas_Object *ic = NULL;
> - char *name, *icon, *path;
> - char buf[4096];
> -
> - name = l->data;
> - if (!name) continue;
> - module = evas_hash_find(modules, name);
> - if ((!module) || (module->enabled) || (!module->icon)) continue;
> - /*
> - icon = efreet_icon_path_find(e_config->icon_theme,
> - module->icon, "24x24");
> - if ((!icon) && (module->orig_path))
> - {
> - path = ecore_file_dir_get(module->orig_path);
> - snprintf(buf, sizeof(buf), "%s/%s.edj", path, module->icon);
> - icon = strdup(buf);
> - free(path);
> - }
> - */
> - if (module->orig_path)
> - {
> - path = ecore_file_dir_get(module->orig_path);
> - snprintf(buf, sizeof(buf), "%s/%s.edj", path, module->icon);
> - icon = strdup(buf);
> - free(path);
> - }
> - if (icon)
> - {
> - ic = e_util_icon_add(icon, evas);
> - free(icon);
> - }
> - if (module->name)
> - e_widget_ilist_append(cfdata->o_avail, ic, module->name, NULL,
> NULL, NULL);
> - else if (module->short_name)
> - e_widget_ilist_append(cfdata->o_avail, ic, module->short_name,
> NULL, NULL, NULL);
> + e_widget_ilist_header_append(cfdata->o_avail, NULL, _("Appearance"));
> + _fill_list(cfdata->o_avail, "appearance", 0);
> }
> -
> + if (_find_module_category("config", 0))
> + {
> + e_widget_ilist_header_append(cfdata->o_avail, NULL,
> _("Configuration"));
> + _fill_list(cfdata->o_avail, "config", 0);
> + }
> + if (_find_module_category("shelf", 0))
> + {
> + e_widget_ilist_header_append(cfdata->o_avail, NULL, _("Shelf"));
> + _fill_list(cfdata->o_avail, "shelf", 0);
> + }
> + if (_find_module_category("system", 0))
> + {
> + e_widget_ilist_header_append(cfdata->o_avail, NULL, _("System"));
> + _fill_list(cfdata->o_avail, "system", 0);
> + }
> + if (_find_module_category("fileman", 0))
> + {
> + e_widget_ilist_header_append(cfdata->o_avail, NULL, _("Fileman"));
> + _fill_list(cfdata->o_avail, "fileman", 0);
> + }
> +
> e_widget_ilist_go(cfdata->o_avail);
> e_widget_min_size_get(cfdata->o_avail, &w, NULL);
> e_widget_min_size_set(cfdata->o_avail, w, 200);
> e_widget_ilist_thaw(cfdata->o_avail);
> edje_thaw();
> evas_event_thaw(evas);
> - if (l) evas_list_free(l);
> }
>
> static void
> _fill_loaded_list(E_Config_Dialog_Data *cfdata)
> {
> Evas *evas;
> - Evas_List *l = NULL;
> Evas_Coord w;
>
> if (!cfdata) return;
> @@ -315,44 +310,30 @@
> e_widget_ilist_freeze(cfdata->o_loaded);
> e_widget_ilist_clear(cfdata->o_loaded);
>
> - for (l = modules_list; l; l = l->next)
> + if (_find_module_category("appearance", 1))
> {
> - CFModule *module = NULL;
> - Evas_Object *ic = NULL;
> - char *name, *icon, *path;
> - char buf[4096];
> -
> - name = l->data;
> - if (!name) continue;
> - module = evas_hash_find(modules, name);
> - if ((!module) || (!module->enabled) || (!module->icon)) continue;
> - /*
> - icon = efreet_icon_path_find(e_config->icon_theme,
> - module->icon, "24x24");
> - if ((!icon) && (module->orig_path))
> - {
> - path = ecore_file_dir_get(module->orig_path);
> - snprintf(buf, sizeof(buf), "%s/%s.edj", path, module->icon);
> - icon = strdup(buf);
> - free(path);
> - }
> - */
> - if (module->orig_path)
> - {
> - path = ecore_file_dir_get(module->orig_path);
> - snprintf(buf, sizeof(buf), "%s/%s.edj", path, module->icon);
> - icon = strdup(buf);
> - free(path);
> - }
> - if (icon)
> - {
> - ic = e_util_icon_add(icon, evas);
> - free(icon);
> - }
> - if (module->name)
> - e_widget_ilist_append(cfdata->o_loaded, ic, module->name, NULL,
> NULL, NULL);
> - else if (module->short_name)
> - e_widget_ilist_append(cfdata->o_loaded, ic, module->short_name,
> NULL, NULL, NULL);
> + e_widget_ilist_header_append(cfdata->o_loaded, NULL, _("Appearance"));
> + _fill_list(cfdata->o_loaded, "appearance", 1);
> + }
> + if (_find_module_category("config", 1))
> + {
> + e_widget_ilist_header_append(cfdata->o_loaded, NULL,
> _("Configuration"));
> + _fill_list(cfdata->o_loaded, "config", 1);
> + }
> + if (_find_module_category("shelf", 1))
> + {
> + e_widget_ilist_header_append(cfdata->o_loaded, NULL, _("Shelf"));
> + _fill_list(cfdata->o_loaded, "shelf", 1);
> + }
> + if (_find_module_category("system", 1))
> + {
> + e_widget_ilist_header_append(cfdata->o_loaded, NULL, _("System"));
> + _fill_list(cfdata->o_loaded, "system", 1);
> + }
> + if (_find_module_category("fileman", 1))
> + {
> + e_widget_ilist_header_append(cfdata->o_loaded, NULL, _("Fileman"));
> + _fill_list(cfdata->o_loaded, "fileman", 1);
> }
>
> e_widget_ilist_go(cfdata->o_loaded);
> @@ -361,7 +342,6 @@
> e_widget_ilist_thaw(cfdata->o_loaded);
> edje_thaw();
> evas_event_thaw(evas);
> - if (l) evas_list_free(l);
> }
>
> static void
> @@ -510,6 +490,78 @@
> return 1;
> }
>
> +static void
> +_fill_list(Evas_Object *obj, const char *type, int enabled)
> +{
> + Evas *evas;
> + Evas_List *l = NULL;
> +
> + evas = evas_object_evas_get(obj);
> + for (l = modules_list; l; l = l->next)
> + {
> + CFModule *module = NULL;
> + Evas_Object *ic = NULL;
> + char *name, *icon, *path;
> + char buf[4096];
> +
> + name = l->data;
> + if (!name) continue;
> + module = evas_hash_find(modules, name);
> + if ((!module) || (module->enabled != enabled) || (!module->icon))
> + continue;
> + if (module->type)
> + {
> + if (strcmp(module->type, type)) continue;
> + }
> + else
> + if (strcmp(type, "shelf")) continue;
> +
> + if (module->orig_path)
> + {
> + path = ecore_file_dir_get(module->orig_path);
> + snprintf(buf, sizeof(buf), "%s/%s.edj", path, module->icon);
> + icon = strdup(buf);
> + free(path);
> + }
> + if (icon)
> + {
> + ic = e_util_icon_add(icon, evas);
> + free(icon);
> + }
> + if (module->name)
> + e_widget_ilist_append(obj, ic, module->name, NULL, NULL, NULL);
> + else if (module->short_name)
> + e_widget_ilist_append(obj, ic, module->short_name, NULL, NULL,
> NULL);
> + }
> + if (l) evas_list_free(l);
> +}
> +
> +static int
> +_find_module_category(const char *type, int enabled)
> +{
> + Evas_List *l = NULL;
> +
> + for (l = modules_list; l; l = l->next)
> + {
> + CFModule *module = NULL;
> + char *name;
> +
> + name = l->data;
> + if (!name) continue;
> + module = evas_hash_find(modules, name);
> + if ((!module) || (module->enabled != enabled) || (!module->icon))
> + continue;
> + if (module->type)
> + {
> + if (strcmp(module->type, type)) continue;
> + return 1;
> + }
> + else
> + if (!strcmp(type, "shelf")) return 1;
> + }
> + return 0;
> +}
> +
> /* Hash callback Functions */
> static Evas_Bool
> _modules_hash_cb_free(Evas_Hash *hash __UNUSED__, const char *key __UNUSED__,
> @@ -524,6 +576,7 @@
> if (module->icon) evas_stringshare_del(module->icon);
> if (module->comment) evas_stringshare_del(module->comment);
> if (module->orig_path) evas_stringshare_del(module->orig_path);
> + if (module->type) evas_stringshare_del(module->type);
> E_FREE(module);
> return 1;
> }
>
>
>
> -------------------------------------------------------------------------
> This SF.net email is sponsored by: Splunk Inc.
> Still grepping through log files to find problems? Stop.
> Now Search log events and configuration files using AJAX and a browser.
> Download your FREE copy of Splunk now >> http://get.splunk.com/
> _______________________________________________
> enlightenment-cvs mailing list
> [EMAIL PROTECTED]
> https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs
>
--
Zachary Goldberg
Computer Science Major
School of Engineering at the University of Pennsylvania
Philadelphia PA
-------------------------------------------------------------------------
This SF.net email is sponsored by: Splunk Inc.
Still grepping through log files to find problems? Stop.
Now Search log events and configuration files using AJAX and a browser.
Download your FREE copy of Splunk now >> http://get.splunk.com/
_______________________________________________
enlightenment-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/enlightenment-devel