Merge branch 'backport' into work

This commit is contained in:
Dana Jansens 2008-02-26 03:15:21 -05:00
commit 7e47a57027
3 changed files with 42 additions and 27 deletions

View file

@ -877,7 +877,10 @@ static void event_handle_client(ObClient *client, XEvent *e)
con = mouse_button_frame_context(con, e->xbutton.button, con = mouse_button_frame_context(con, e->xbutton.button,
e->xbutton.state); e->xbutton.state);
if (e->type == ButtonRelease && e->xbutton.button == pb) /* button presses on CLIENT_CONTEXTs are not accompanied by a
release because they are Replayed to the client */
if ((e->type == ButtonRelease || CLIENT_CONTEXT(con, client)) &&
e->xbutton.button == pb)
pb = 0, px = py = -1, pcon = OB_FRAME_CONTEXT_NONE; pb = 0, px = py = -1, pcon = OB_FRAME_CONTEXT_NONE;
switch (con) { switch (con) {
@ -973,40 +976,47 @@ static void event_handle_client(ObClient *client, XEvent *e)
case OB_FRAME_CONTEXT_TLCORNER: case OB_FRAME_CONTEXT_TLCORNER:
case OB_FRAME_CONTEXT_TRCORNER: case OB_FRAME_CONTEXT_TRCORNER:
/* we've left the button area inside the titlebar */ /* we've left the button area inside the titlebar */
if (client->frame->max_hover || client->frame->desk_hover ||
client->frame->shade_hover || client->frame->iconify_hover ||
client->frame->close_hover)
{
client->frame->max_hover = FALSE; client->frame->max_hover = FALSE;
client->frame->desk_hover = FALSE; client->frame->desk_hover = FALSE;
client->frame->shade_hover = FALSE; client->frame->shade_hover = FALSE;
client->frame->iconify_hover = FALSE; client->frame->iconify_hover = FALSE;
client->frame->close_hover = FALSE; client->frame->close_hover = FALSE;
frame_adjust_state(client->frame); if (e->xcrossing.mode == NotifyGrab) {
client->frame->max_press = FALSE;
client->frame->desk_press = FALSE;
client->frame->shade_press = FALSE;
client->frame->iconify_press = FALSE;
client->frame->close_press = FALSE;
} }
frame_adjust_state(client->frame);
break; break;
case OB_FRAME_CONTEXT_MAXIMIZE: case OB_FRAME_CONTEXT_MAXIMIZE:
client->frame->max_hover = FALSE; client->frame->max_hover = FALSE;
if (e->xcrossing.mode == NotifyGrab)
client->frame->max_press = FALSE; client->frame->max_press = FALSE;
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;
case OB_FRAME_CONTEXT_ALLDESKTOPS: case OB_FRAME_CONTEXT_ALLDESKTOPS:
client->frame->desk_hover = FALSE; client->frame->desk_hover = FALSE;
if (e->xcrossing.mode == NotifyGrab)
client->frame->desk_press = FALSE; client->frame->desk_press = FALSE;
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;
case OB_FRAME_CONTEXT_SHADE: case OB_FRAME_CONTEXT_SHADE:
client->frame->shade_hover = FALSE; client->frame->shade_hover = FALSE;
if (e->xcrossing.mode == NotifyGrab)
client->frame->shade_press = FALSE; client->frame->shade_press = FALSE;
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;
case OB_FRAME_CONTEXT_ICONIFY: case OB_FRAME_CONTEXT_ICONIFY:
client->frame->iconify_hover = FALSE; client->frame->iconify_hover = FALSE;
if (e->xcrossing.mode == NotifyGrab)
client->frame->iconify_press = FALSE; client->frame->iconify_press = FALSE;
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;
case OB_FRAME_CONTEXT_CLOSE: case OB_FRAME_CONTEXT_CLOSE:
client->frame->close_hover = FALSE; client->frame->close_hover = FALSE;
if (e->xcrossing.mode == NotifyGrab)
client->frame->close_press = FALSE; client->frame->close_press = FALSE;
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;
@ -1046,26 +1056,31 @@ static void event_handle_client(ObClient *client, XEvent *e)
switch (con) { switch (con) {
case OB_FRAME_CONTEXT_MAXIMIZE: case OB_FRAME_CONTEXT_MAXIMIZE:
client->frame->max_hover = TRUE; client->frame->max_hover = TRUE;
if (e->xcrossing.mode == NotifyUngrab)
client->frame->max_press = (con == pcon); client->frame->max_press = (con == pcon);
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;
case OB_FRAME_CONTEXT_ALLDESKTOPS: case OB_FRAME_CONTEXT_ALLDESKTOPS:
client->frame->desk_hover = TRUE; client->frame->desk_hover = TRUE;
if (e->xcrossing.mode == NotifyUngrab)
client->frame->desk_press = (con == pcon); client->frame->desk_press = (con == pcon);
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;
case OB_FRAME_CONTEXT_SHADE: case OB_FRAME_CONTEXT_SHADE:
client->frame->shade_hover = TRUE; client->frame->shade_hover = TRUE;
if (e->xcrossing.mode == NotifyUngrab)
client->frame->shade_press = (con == pcon); client->frame->shade_press = (con == pcon);
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;
case OB_FRAME_CONTEXT_ICONIFY: case OB_FRAME_CONTEXT_ICONIFY:
client->frame->iconify_hover = TRUE; client->frame->iconify_hover = TRUE;
if (e->xcrossing.mode == NotifyUngrab)
client->frame->iconify_press = (con == pcon); client->frame->iconify_press = (con == pcon);
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;
case OB_FRAME_CONTEXT_CLOSE: case OB_FRAME_CONTEXT_CLOSE:
client->frame->close_hover = TRUE; client->frame->close_hover = TRUE;
if (e->xcrossing.mode == NotifyUngrab)
client->frame->close_press = (con == pcon); client->frame->close_press = (con == pcon);
frame_adjust_state(client->frame); frame_adjust_state(client->frame);
break; break;

View file

@ -56,6 +56,12 @@ typedef enum {
OB_FRAME_NUM_CONTEXTS OB_FRAME_NUM_CONTEXTS
} ObFrameContext; } ObFrameContext;
#define FRAME_CONTEXT(co, cl) ((cl && cl->type != OB_CLIENT_TYPE_DESKTOP) ? \
co == OB_FRAME_CONTEXT_FRAME : FALSE)
#define CLIENT_CONTEXT(co, cl) ((cl && cl->type == OB_CLIENT_TYPE_DESKTOP) ? \
co == OB_FRAME_CONTEXT_DESKTOP : \
co == OB_FRAME_CONTEXT_CLIENT)
/*! The decorations the client window wants to be displayed on it */ /*! The decorations the client window wants to be displayed on it */
typedef enum { typedef enum {
OB_FRAME_DECOR_TITLEBAR = 1 << 0, /*!< Display a titlebar */ OB_FRAME_DECOR_TITLEBAR = 1 << 0, /*!< Display a titlebar */

View file

@ -37,12 +37,6 @@ typedef struct {
GSList *actions[OB_NUM_MOUSE_ACTIONS]; /* lists of Action pointers */ GSList *actions[OB_NUM_MOUSE_ACTIONS]; /* lists of Action pointers */
} ObMouseBinding; } ObMouseBinding;
#define FRAME_CONTEXT(co, cl) ((cl && cl->type != OB_CLIENT_TYPE_DESKTOP) ? \
co == OB_FRAME_CONTEXT_FRAME : FALSE)
#define CLIENT_CONTEXT(co, cl) ((cl && cl->type == OB_CLIENT_TYPE_DESKTOP) ? \
co == OB_FRAME_CONTEXT_DESKTOP : \
co == OB_FRAME_CONTEXT_CLIENT)
/* Array of GSList*s of ObMouseBinding*s. */ /* Array of GSList*s of ObMouseBinding*s. */
static GSList *bound_contexts[OB_FRAME_NUM_CONTEXTS]; static GSList *bound_contexts[OB_FRAME_NUM_CONTEXTS];
/* TRUE when we have a grab on the pointer and need to replay the pointer event /* TRUE when we have a grab on the pointer and need to replay the pointer event