Enlightenment CVS committal

Author  : kwo
Project : e16
Module  : e

Dir     : e16/e/src


Modified Files:
        E.h desktops.c ewins.c focus.c stacking.c 


Log Message:
Fix some more click-raises issues.
===================================================================
RCS file: /cvsroot/enlightenment/e16/e/src/E.h,v
retrieving revision 1.518
retrieving revision 1.519
diff -u -3 -r1.518 -r1.519
--- E.h 1 Dec 2005 17:00:24 -0000       1.518
+++ E.h 8 Dec 2005 18:45:39 -0000       1.519
@@ -873,7 +873,6 @@
 #define FOCUS_CLICK      12
 
 void                FocusEnable(int on);
-void                FocusEwinSetGrabs(EWin * ewin);
 void                FocusToEWin(EWin * ewin, int why);
 void                FocusHandleEnter(EWin * ewin, XEvent * ev);
 void                FocusHandleLeave(EWin * ewin, XEvent * ev);
@@ -881,6 +880,7 @@
 void                FocusHandleClick(EWin * ewin, Window win);
 void                FocusNewDeskBegin(void);
 void                FocusNewDesk(void);
+void                FocusGrabsUpdate(void);
 
 /* fonts.c */
 int                 FontConfigLoad(FILE * fs);
===================================================================
RCS file: /cvsroot/enlightenment/e16/e/src/desktops.c,v
retrieving revision 1.211
retrieving revision 1.212
diff -u -3 -r1.211 -r1.212
--- desktops.c  6 Dec 2005 19:09:47 -0000       1.211
+++ desktops.c  8 Dec 2005 18:45:40 -0000       1.212
@@ -1505,6 +1505,7 @@
      {
        dsk->stack.update_client_list = 0;
        HintsSetClientStacking();
+       FocusGrabsUpdate();
      }
    dsk->stack.dirty = 0;
    dsk->stack.latest = NULL;
===================================================================
RCS file: /cvsroot/enlightenment/e16/e/src/ewins.c,v
retrieving revision 1.133
retrieving revision 1.134
diff -u -3 -r1.133 -r1.134
--- ewins.c     27 Nov 2005 13:11:05 -0000      1.133
+++ ewins.c     8 Dec 2005 18:45:41 -0000       1.134
@@ -306,8 +306,6 @@
    if (!ewin->props.no_button_grabs)
       GrabButtonGrabs(ewin);
 
-   FocusEwinSetGrabs(ewin);
-
    if (ewin->state.shaded)
       EwinInstantShade(ewin, 1);
 
@@ -1340,8 +1338,6 @@
    if (lst)
       Efree(lst);
 
-   FocusEwinSetGrabs(ewin);
-
    if (call_depth == 1)
       ModulesSignal(ESIGNAL_EWIN_CHANGE, ewin);
 
@@ -1375,8 +1371,6 @@
    if (lst)
       Efree(lst);
 
-   FocusEwinSetGrabs(ewin);
-
    if (call_depth == 1)
       ModulesSignal(ESIGNAL_EWIN_CHANGE, ewin);
 
===================================================================
RCS file: /cvsroot/enlightenment/e16/e/src/focus.c,v
retrieving revision 1.135
retrieving revision 1.136
diff -u -3 -r1.135 -r1.136
--- focus.c     19 Nov 2005 20:43:09 -0000      1.135
+++ focus.c     8 Dec 2005 18:45:41 -0000       1.136
@@ -34,6 +34,7 @@
 
 static char         focus_inhibit = 1;
 static char         focus_is_set = 0;
+static char         focus_pending_update_grabs = 0;
 static int          focus_pending_why = 0;
 static EWin        *focus_pending_ewin = NULL;
 static EWin        *focus_pending_new = NULL;
@@ -201,7 +202,7 @@
       FocusToEWin(ewin, FOCUS_PREV);
 }
 
-void
+static void
 FocusEwinSetGrabs(EWin * ewin)
 {
    int                 set = 0;
@@ -249,7 +250,7 @@
    ewin->state.active = active;
    EwinBorderUpdateState(ewin);
 
-   FocusEwinSetGrabs(ewin);
+   FocusGrabsUpdate();
 
    if (active && ewin->state.attention)
      {
@@ -259,7 +260,7 @@
 }
 
 static void
-FocusFix(void)
+doFocusGrabsUpdate(void)
 {
    EWin               *const *lst, *ewin;
    int                 i, num;
@@ -270,6 +271,13 @@
        ewin = lst[i];
        FocusEwinSetGrabs(ewin);
      }
+   focus_pending_update_grabs = 0;
+}
+
+void
+FocusGrabsUpdate(void)
+{
+   focus_pending_update_grabs = 1;
 }
 
 static void
@@ -605,9 +613,6 @@
        RaiseEwin(ewin);
        FocusToEWin(ewin, FOCUS_CLICK);
 
-       /* Remove grabs if on top of stacking list */
-       FocusEwinSetGrabs(ewin);
-
        /* allow click to pass thorugh */
        if (EventDebug(EDBUG_TYPE_GRABS))
           Eprintf("FocusHandleClick %#lx %#lx\n", win,
@@ -670,7 +675,7 @@
        Conf.warplist.icon_mode = tmp_warp_icon_mode;
 
        Conf.focus.clickraises = tmp_clickalways;
-       FocusFix();
+       FocusGrabsUpdate();
      }
    autosave();
 }
@@ -879,9 +884,10 @@
        break;
 
      case ESIGNAL_IDLE:
-       if (focus_inhibit || !focus_pending_why)
-          break;
-       FocusSet();
+       if (!focus_inhibit && focus_pending_why)
+          FocusSet();
+       if (focus_pending_update_grabs)
+          doFocusGrabsUpdate();
        break;
      }
 }
@@ -962,7 +968,7 @@
        if (Conf.focus.mode != mode)
          {
             Conf.focus.mode = mode;
-            FocusFix();
+            FocusGrabsUpdate();
             autosave();
          }
      }
===================================================================
RCS file: /cvsroot/enlightenment/e16/e/src/stacking.c,v
retrieving revision 1.30
retrieving revision 1.31
diff -u -3 -r1.30 -r1.31
--- stacking.c  30 Oct 2005 19:40:49 -0000      1.30
+++ stacking.c  8 Dec 2005 18:45:41 -0000       1.31
@@ -475,6 +475,8 @@
           continue;
        if (eo->ilayer > eox->ilayer)
           continue;
+       if (EwinGetTransientFor((EWin *) eo) == _EwinGetClientXwin(ewin))
+          continue;
        return eo == eox;
      }
 




-------------------------------------------------------
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://ads.osdn.com/?ad_id=7637&alloc_id=16865&op=click
_______________________________________________
enlightenment-cvs mailing list
enlightenment-cvs@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs

Reply via email to