Enlightenment CVS committal Author : raster Project : e17 Module : apps/e
Dir : e17/apps/e/src/modules/ibox Modified Files: e_mod_config.c e_mod_main.c e_mod_main.h Log Message: 2 pending patches in my inbox. 1. "allow overlap" patch for modules - needs better names in the gui (Allow windows to overlap maybe - as allow overlap is very vague) 2. itray module (buggy - buggy - beware. i know why. beware i said!) 3. TODO items =================================================================== RCS file: /cvsroot/enlightenment/e17/apps/e/src/modules/ibox/e_mod_config.c,v retrieving revision 1.14 retrieving revision 1.15 diff -u -3 -r1.14 -r1.15 --- e_mod_config.c 14 Jan 2006 16:10:57 -0000 1.14 +++ e_mod_config.c 20 Jan 2006 04:04:13 -0000 1.15 @@ -12,6 +12,7 @@ int iconsize; double follow_speed; double autoscroll_speed; + int allow_overlap; }; struct _Cfg_File_Data @@ -55,6 +56,7 @@ cfdata->iconsize = ib->conf->iconsize; cfdata->follow_speed = ib->conf->follow_speed; cfdata->autoscroll_speed = ib->conf->autoscroll_speed; + cfdata->allow_overlap = ib->conf->allow_overlap; } static void * @@ -93,6 +95,9 @@ e_widget_list_object_append(o, ob, 1, 1, 0.5); ob = e_widget_check_add(evas, _("Auto Fit Icons"), &(cfdata->autofit)); e_widget_list_object_append(o, ob, 1, 1, 0.5); + + ob = e_widget_check_add(evas, _("Allow Overlap"), &(cfdata->allow_overlap)); + e_widget_list_object_append(o, ob, 1, 1, 0.5); return o; } @@ -120,6 +125,12 @@ { ib->conf->width = IBOX_WIDTH_FIXED; } + + if (cfdata->allow_overlap && !ib->conf->allow_overlap) + ib->conf->allow_overlap = 1; + else if (!cfdata->allow_overlap && ib->conf->allow_overlap) + ib->conf->allow_overlap = 0; + e_border_button_bindings_grab_all(); e_config_save_queue(); @@ -160,6 +171,12 @@ ob = e_widget_slider_add(evas, 1, 0, _("%1.2f px/s"), 0.0, 1.0, 0.01, 0, &(cfdata->autoscroll_speed), NULL,200); e_widget_framelist_object_append(of, ob); e_widget_list_object_append(o, of, 1, 1, 0.5); + + of = e_widget_framelist_add(evas, _("Extras"), 0); + ob = e_widget_check_add(evas, _("Allow Overlap"), &(cfdata->allow_overlap)); + e_widget_framelist_object_append(of, ob); + e_widget_list_object_append(o, of, 1, 1, 0.5); + return o; } @@ -200,6 +217,11 @@ { ib->conf->autoscroll_speed = cfdata->autoscroll_speed; } + + if (cfdata->allow_overlap && !ib->conf->allow_overlap) + ib->conf->allow_overlap = 1; + else if (!cfdata->allow_overlap && ib->conf->allow_overlap) + ib->conf->allow_overlap = 0; e_border_button_bindings_grab_all(); e_config_save_queue(); =================================================================== RCS file: /cvsroot/enlightenment/e17/apps/e/src/modules/ibox/e_mod_main.c,v retrieving revision 1.40 retrieving revision 1.41 diff -u -3 -r1.40 -r1.41 --- e_mod_main.c 7 Jan 2006 23:45:40 -0000 1.40 +++ e_mod_main.c 20 Jan 2006 04:04:13 -0000 1.41 @@ -203,6 +203,7 @@ E_CONFIG_VAL(D, T, autoscroll_speed, DOUBLE); E_CONFIG_VAL(D, T, iconsize, INT); E_CONFIG_VAL(D, T, width, INT); + E_CONFIG_VAL(D, T, allow_overlap, INT); E_CONFIG_LIST(D, T, boxes, conf_box_edd); ib->conf = e_config_domain_load("module.ibox", conf_edd); @@ -214,11 +215,13 @@ ib->conf->autoscroll_speed = 0.95; ib->conf->iconsize = 24; ib->conf->width = IBOX_WIDTH_AUTO; + ib->conf->allow_overlap = 0; } E_CONFIG_LIMIT(ib->conf->follow_speed, 0.01, 1.0); E_CONFIG_LIMIT(ib->conf->autoscroll_speed, 0.01, 1.0); E_CONFIG_LIMIT(ib->conf->iconsize, 2, 400); E_CONFIG_LIMIT(ib->conf->width, -2, -1); + E_CONFIG_LIMIT(ib->conf->allow_overlap, 0, 1); _ibox_config_menu_new(ib); @@ -396,6 +399,12 @@ policy = E_GADMAN_POLICY_EDGES | E_GADMAN_POLICY_HMOVE | E_GADMAN_POLICY_VMOVE; if (ibb->ibox->conf->width == IBOX_WIDTH_FIXED) policy |= E_GADMAN_POLICY_VSIZE; + + if (ibb->ibox->conf->allow_overlap == 0) + policy &= ~E_GADMAN_POLICY_ALLOW_OVERLAP; + else + policy |= E_GADMAN_POLICY_ALLOW_OVERLAP; + e_gadman_client_policy_set(ibb->gmc, policy); e_gadman_client_min_size_set(ibb->gmc, 8, 8); e_gadman_client_max_size_set(ibb->gmc, 3200, 3200); @@ -710,6 +719,12 @@ e_box_align_set(ibb->item_object, 0.5, 0.5); policy = E_GADMAN_POLICY_EDGES | E_GADMAN_POLICY_HMOVE | E_GADMAN_POLICY_VMOVE; + + if (ibb->ibox->conf->allow_overlap == 0) + policy &= ~E_GADMAN_POLICY_ALLOW_OVERLAP; + else + policy |= E_GADMAN_POLICY_ALLOW_OVERLAP; + if ((edge == E_GADMAN_EDGE_BOTTOM) || (edge == E_GADMAN_EDGE_TOP)) { @@ -753,6 +768,12 @@ E_Gadman_Policy policy; policy = E_GADMAN_POLICY_EDGES | E_GADMAN_POLICY_HMOVE | E_GADMAN_POLICY_VMOVE; + + if (ibb->ibox->conf->allow_overlap == 0) + policy &= ~E_GADMAN_POLICY_ALLOW_OVERLAP; + else + policy |= E_GADMAN_POLICY_ALLOW_OVERLAP; + if ((e_gadman_client_edge_get(ibb->gmc) == E_GADMAN_EDGE_BOTTOM) || (e_gadman_client_edge_get(ibb->gmc) == E_GADMAN_EDGE_TOP)) { =================================================================== RCS file: /cvsroot/enlightenment/e17/apps/e/src/modules/ibox/e_mod_main.h,v retrieving revision 1.11 retrieving revision 1.12 diff -u -3 -r1.11 -r1.12 --- e_mod_main.h 6 Jan 2006 21:39:28 -0000 1.11 +++ e_mod_main.h 20 Jan 2006 04:04:13 -0000 1.12 @@ -19,6 +19,7 @@ int follower; double autoscroll_speed; int iconsize; + int allow_overlap; int width; Evas_List *boxes; }; ------------------------------------------------------- This SF.net email is sponsored by: Splunk Inc. Do you grep through log files for problems? Stop! Download the new AJAX search engine that makes searching your log files as easy as surfing the web. DOWNLOAD SPLUNK! http://sel.as-us.falkag.net/sel?cmd=lnk&kid=103432&bid=230486&dat=121642 _______________________________________________ enlightenment-cvs mailing list enlightenment-cvs@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs