summaryrefslogtreecommitdiff
path: root/0002-x11-Implement-drag-to-top-to-maximize-gesture-on-emu.patch
diff options
context:
space:
mode:
Diffstat (limited to '0002-x11-Implement-drag-to-top-to-maximize-gesture-on-emu.patch')
-rw-r--r--0002-x11-Implement-drag-to-top-to-maximize-gesture-on-emu.patch135
1 files changed, 0 insertions, 135 deletions
diff --git a/0002-x11-Implement-drag-to-top-to-maximize-gesture-on-emu.patch b/0002-x11-Implement-drag-to-top-to-maximize-gesture-on-emu.patch
deleted file mode 100644
index 6758a5f..0000000
--- a/0002-x11-Implement-drag-to-top-to-maximize-gesture-on-emu.patch
+++ /dev/null
@@ -1,135 +0,0 @@
-From 41b73e409f7e30b8ba3b961013debaaf584b499c Mon Sep 17 00:00:00 2001
-From: Carlos Garnacho <carlosg@gnome.org>
-Date: Thu, 13 Mar 2014 21:12:55 +0100
-Subject: [PATCH 2/3] x11: Implement "drag to top to maximize" gesture on
- emulated window dragging
-
-And the counterpart to unmaximize when dragging a maximized window, if
-touch devices aren't going to use EWMH moveresize, having this one at least
-makes things feel a bit less awkward.
-
-https://bugzilla.gnome.org/show_bug.cgi?id=709914
----
- gdk/x11/gdkwindow-x11.c | 74 ++++++++++++++++++++++++++++++++++++++++++++++---
- 1 file changed, 70 insertions(+), 4 deletions(-)
-
-diff --git a/gdk/x11/gdkwindow-x11.c b/gdk/x11/gdkwindow-x11.c
-index 08ef713..83b3c7b 100644
---- a/gdk/x11/gdkwindow-x11.c
-+++ b/gdk/x11/gdkwindow-x11.c
-@@ -4872,12 +4872,58 @@ get_move_resize_data (GdkDisplay *display,
- }
-
- static void
-+check_maximize (MoveResizeData *mv_resize,
-+ gdouble x_root,
-+ gdouble y_root)
-+{
-+ GdkWindowState state;
-+ gint y;
-+
-+ if (mv_resize->is_resize)
-+ return;
-+
-+ state = gdk_window_get_state (mv_resize->moveresize_window);
-+
-+ if (state & GDK_WINDOW_STATE_MAXIMIZED)
-+ return;
-+
-+ y = mv_resize->moveresize_orig_y + (y_root - mv_resize->moveresize_y);
-+
-+ if (y < 10)
-+ gdk_window_maximize (mv_resize->moveresize_window);
-+}
-+
-+static void
-+check_unmaximize (MoveResizeData *mv_resize,
-+ gdouble x_root,
-+ gdouble y_root)
-+{
-+ GdkWindowState state;
-+ gint dx, dy;
-+
-+ if (mv_resize->is_resize)
-+ return;
-+
-+ state = gdk_window_get_state (mv_resize->moveresize_window);
-+
-+ if ((state & GDK_WINDOW_STATE_MAXIMIZED) == 0)
-+ return;
-+
-+ dx = x_root - mv_resize->moveresize_x;
-+ dy = y_root - mv_resize->moveresize_y;
-+
-+ if (ABS (dx) > 20 || ABS (dy) > 20)
-+ gdk_window_unmaximize (mv_resize->moveresize_window);
-+}
-+
-+static void
- update_pos (MoveResizeData *mv_resize,
- gint new_root_x,
- gint new_root_y)
- {
- gint dx, dy;
-
-+ check_unmaximize (mv_resize, new_root_x, new_root_y);
- dx = new_root_x - mv_resize->moveresize_x;
- dy = new_root_y - mv_resize->moveresize_y;
-
-@@ -5066,7 +5112,12 @@ _gdk_x11_moveresize_handle_event (XEvent *event)
- * get a permanently stuck grab.
- */
- if ((event->xmotion.state & button_mask) == 0)
-- finish_drag (mv_resize);
-+ {
-+ check_maximize (mv_resize,
-+ event->xmotion.x_root / impl->window_scale,
-+ event->xmotion.y_root / impl->window_scale);
-+ finish_drag (mv_resize);
-+ }
- break;
-
- case ButtonRelease:
-@@ -5075,7 +5126,12 @@ _gdk_x11_moveresize_handle_event (XEvent *event)
- event->xbutton.y_root / impl->window_scale);
-
- if (event->xbutton.button == mv_resize->moveresize_button)
-- finish_drag (mv_resize);
-+ {
-+ check_maximize (mv_resize,
-+ event->xmotion.x_root / impl->window_scale,
-+ event->xmotion.y_root / impl->window_scale);
-+ finish_drag (mv_resize);
-+ }
- break;
-
- #if defined (HAVE_XGENERICEVENTS) && defined (XINPUT_2)
-@@ -5091,13 +5147,23 @@ _gdk_x11_moveresize_handle_event (XEvent *event)
- update_pos (mv_resize, xev->root_x / impl->window_scale, xev->root_y / impl->window_scale);
- state = _gdk_x11_device_xi2_translate_state (&xev->mods, &xev->buttons, &xev->group);
- if ((state & button_mask) == 0)
-- finish_drag (mv_resize);
-+ {
-+ check_maximize (mv_resize,
-+ xev->root_x / impl->window_scale,
-+ xev->root_y / impl->window_scale);
-+ finish_drag (mv_resize);
-+ }
- break;
-
- case XI_ButtonRelease:
- update_pos (mv_resize, xev->root_x / impl->window_scale, xev->root_y / impl->window_scale);
- if (xev->detail == mv_resize->moveresize_button)
-- finish_drag (mv_resize);
-+ {
-+ check_maximize (mv_resize,
-+ xev->root_x / impl->window_scale,
-+ xev->root_y / impl->window_scale);
-+ finish_drag (mv_resize);
-+ }
- break;
- }
- }
---
-1.9.0
-
bgstack15