]> Dogcows Code - chaz/openbox/commitdiff
dont start a move/resize on clients that cant do it
authorDana Jansens <danakj@orodu.net>
Mon, 29 Sep 2003 07:41:11 +0000 (07:41 +0000)
committerDana Jansens <danakj@orodu.net>
Mon, 29 Sep 2003 07:41:11 +0000 (07:41 +0000)
openbox/moveresize.c

index 41bb2d2a61b64fad1ab9b7272c5e151c58f591cd..9f0f41ba7e51c546aea225c22b97f93fab07761b 100644 (file)
@@ -90,7 +90,13 @@ void moveresize_start(ObClient *c, int x, int y, guint b, guint32 cnr)
 {
     ObCursor cur;
 
-    if (moveresize_in_progress || !c->frame->visible)
+    moving = (cnr == prop_atoms.net_wm_moveresize_move ||
+              cnr == prop_atoms.net_wm_moveresize_move_keyboard);
+
+    if (moveresize_in_progress || !c->frame->visible ||
+        !(moving ?
+          (c->functions & OB_CLIENT_FUNC_MOVE) :
+          (c->functions & OB_CLIENT_FUNC_RESIZE)))
         return;
 
     moveresize_client = c;
@@ -116,15 +122,12 @@ void moveresize_start(ObClient *c, int x, int y, guint b, guint32 cnr)
                      c->area.width / 2, c->area.height / 2);
     */
 
-    if (corner == prop_atoms.net_wm_moveresize_move ||
-        corner == prop_atoms.net_wm_moveresize_move_keyboard) {
+    if (moving) {
         cur_x = start_cx;
         cur_y = start_cy;
-        moving = TRUE;
     } else {
         cur_x = start_cw;
         cur_y = start_ch;
-        moving = FALSE;
     }
 
     moveresize_in_progress = TRUE;
This page took 0.025923 seconds and 4 git commands to generate.